Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp869270pxb; Sun, 21 Feb 2021 03:12:43 -0800 (PST) X-Google-Smtp-Source: ABdhPJzOBk+LPI2G2WmdX6f/SRNd99sQy4qc6UXGRYrZmjvFLXOyVgWRBSb3HFnPrB31Rjbo3mHJ X-Received: by 2002:a17:906:cf84:: with SMTP id um4mr16494783ejb.61.1613905962958; Sun, 21 Feb 2021 03:12:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613905962; cv=none; d=google.com; s=arc-20160816; b=Exth1jws2eotYsoaVo3eLkl1/YO1AivDBDZitZuEjGyxlzKb0mzL/6Zg+CwcU6PUfx fy/cs9bXFfFtzjTQ1QQrz6Wmg2siS17VGbjgNNR1VbJUL1+9oPB5+sFTjpIUJ6w44tHS nyHO7J94oveUv6sOmEGOjGs8zGutTD9oZSqeyju2VO3dyXGsWPltQcvLa74/x6yda51p OE92INVG7QPUDpoz5yDpyxiSJHHHVMMpmaYvIN2NjAlj5YYbE3sYJL70ZJRq70SQDTMC hvoMCe/TbrNnIY6wl9rZsac3S/5H8QUHxfHUKNDCWmDfRcMvZcXMx09LHOFXumG73Irq Sq9w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=RNjQHDwjHikV6G3NhzlN+LIdrhj46KeBBx/5zm/41ng=; b=LQSFYRa1+rKkwpleP9M2yz8i1oAuzYqbzSpRZDTYmwA3NBkDpBpVbsPdFLvtcNwDSw lIkrIf7ubpFypitRtgzi3a6t35Ckf1q44BGo823QjeMVSF8ILoAuguw5pZkRtoatjVOF hBl09XwMAKd4KRVAFclKEtbh4pZCGD21wd8OEfLe57TYRO2F8EFZha6Jflwdine6s3QI Sfqbd5vlKJ72M6BUQBS9ez6ebYN9tN22U/hba7NYt29+uBT+v0VRd2nCpg2CksJJsq9P GcJsdsrlVGys9ixSwpDzbUFHyTLy8bk/XCGLhmS/Cm4LxVvIg+FkmQ7ZHDjagI5pifcT giEA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y11si11194660edj.305.2021.02.21.03.12.20; Sun, 21 Feb 2021 03:12:42 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230016AbhBULJ4 (ORCPT + 99 others); Sun, 21 Feb 2021 06:09:56 -0500 Received: from smtp-190f.mail.infomaniak.ch ([185.125.25.15]:59229 "EHLO smtp-190f.mail.infomaniak.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229663AbhBULJw (ORCPT ); Sun, 21 Feb 2021 06:09:52 -0500 Received: from smtp-3-0001.mail.infomaniak.ch (unknown [10.4.36.108]) by smtp-2-3000.mail.infomaniak.ch (Postfix) with ESMTPS id 4Dk2cv5VJPzMqJfj; Sun, 21 Feb 2021 12:09:03 +0100 (CET) Received: from ns3096276.ip-94-23-54.eu (unknown [23.97.221.149]) by smtp-3-0001.mail.infomaniak.ch (Postfix) with ESMTPA id 4Dk2cs5QSGzlh8TL; Sun, 21 Feb 2021 12:09:01 +0100 (CET) Subject: Re: [PATCH v2 2/3] kconfig: Ask user if string needs to be changed when dependency changed To: Masahiro Yamada , Casey Schaufler Cc: James Morris , "Serge E . Hallyn" , Nicolas Iooss , Linux Kbuild mailing list , Linux Kernel Mailing List , linux-security-module , =?UTF-8?Q?Micka=c3=abl_Sala=c3=bcn?= References: <20210215181511.2840674-1-mic@digikod.net> <20210215181511.2840674-3-mic@digikod.net> From: =?UTF-8?Q?Micka=c3=abl_Sala=c3=bcn?= Message-ID: Date: Sun, 21 Feb 2021 12:10:14 +0100 User-Agent: MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 21/02/2021 09:47, Masahiro Yamada wrote: > On Tue, Feb 16, 2021 at 3:14 AM Mickaël Salaün wrote: >> >> From: Mickaël Salaün >> >> Content of string configuration may depend on related kernel >> configurations. Modify oldconfig and syncconfig to inform users about >> possible required configuration update and give them the opportunity to >> update it: >> * if dependencies of this string has changed (e.g. enabled or disabled), >> * and if the current value of this string is different than the (new) >> default one. >> >> This is particularly relevant for CONFIG_LSM which contains a list of >> LSMs enabled at boot, but users will not have a chance to update this >> list with a make oldconfig. > > If CONFIG_LSM already exists in the .config, > oldconfig does not show a prompt. > This is the expected behavior. It is not the behavior wished for LSM stacking. > > You are trying to fix your problem in a wrong way. > NACK. What do you suggest to ensure that users will be asked to update the CONFIG_LSM string if they add or remove an LSM? > > > >> >> Cc: Casey Schaufler >> Cc: James Morris >> Cc: Masahiro Yamada >> Cc: Serge E. Hallyn >> Signed-off-by: Mickaël Salaün >> Link: https://lore.kernel.org/r/20210215181511.2840674-3-mic@digikod.net >> --- >> scripts/kconfig/conf.c | 37 ++++++++++++++++++++++++++++++++++--- >> 1 file changed, 34 insertions(+), 3 deletions(-) >> >> diff --git a/scripts/kconfig/conf.c b/scripts/kconfig/conf.c >> index 18a233d27a8d..8633dacd39a9 100644 >> --- a/scripts/kconfig/conf.c >> +++ b/scripts/kconfig/conf.c >> @@ -82,6 +82,26 @@ static void xfgets(char *str, int size, FILE *in) >> printf("%s", str); >> } >> >> +static bool may_need_string_update(struct symbol *sym, const char *def) >> +{ >> + const struct symbol *dep_sym; >> + const struct expr *e; >> + >> + if (sym->type != S_STRING) >> + return false; >> + if (strcmp(def, sym_get_string_default(sym)) == 0) >> + return false; >> + /* >> + * The user may want to synchronize the content of a string related to >> + * changed dependencies (e.g. CONFIG_LSM). >> + */ >> + expr_list_for_each_sym(sym->dir_dep.expr, e, dep_sym) { >> + if (dep_sym->flags & SYMBOL_CHANGED) >> + return true; >> + } >> + return false; >> +} >> + >> static int conf_askvalue(struct symbol *sym, const char *def) >> { >> enum symbol_type type = sym_get_type(sym); >> @@ -102,7 +122,7 @@ static int conf_askvalue(struct symbol *sym, const char *def) >> switch (input_mode) { >> case oldconfig: >> case syncconfig: >> - if (sym_has_value(sym)) { >> + if (sym_has_value(sym) && !may_need_string_update(sym, def)) { >> printf("%s\n", def); >> return 0; >> } >> @@ -137,8 +157,19 @@ static int conf_string(struct menu *menu) >> printf("%*s%s ", indent - 1, "", menu->prompt->text); >> printf("(%s) ", sym->name); >> def = sym_get_string_value(sym); >> - if (def) >> - printf("[%s] ", def); >> + if (def) { >> + if (may_need_string_update(sym, def)) { >> + indent += 2; >> + printf("\n%*sDefault value is [%s]\n", >> + indent - 1, "", >> + sym_get_string_default(sym)); >> + printf("%*sCurrent value is [%s] ", >> + indent - 1, "", def); >> + indent -= 2; >> + } else { >> + printf("[%s] ", def); >> + } >> + } >> if (!conf_askvalue(sym, def)) >> return 0; >> switch (line[0]) { >> -- >> 2.30.0 >> > >