Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1469215pxb; Mon, 22 Feb 2021 02:48:16 -0800 (PST) X-Google-Smtp-Source: ABdhPJwjS29xKlGT8wduIoswi6THdb/RIMX0RQdwx+crnzEJyvDF11x2lHJO42tLdx4k1rmTU9yV X-Received: by 2002:aa7:d5d3:: with SMTP id d19mr20279359eds.216.1613990895998; Mon, 22 Feb 2021 02:48:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613990895; cv=none; d=google.com; s=arc-20160816; b=Ud7cVK3Cs718zkwJiai9HqppO3ZKPiT6wYStLJFQhHpVyBGo8WH1ykFZepGN1oOsAL 7ApsQWAcvt/4PErEAaySSdJu0IgWg/jOcSsOT9siQwoZcf03gIwCwKWBtQKZUxesPgDn Vv3Z4KekCO4i35Jyf0i4mQD3NYPjHFBhFk/7KLqtAxsDRGN8EAakZF7qKhIgwBSK/X0S zPp8K65NOPeeNVdKJbLv+WtkJGGrBXT2e4uGJnNXkI9ABAQYdVR68RUNo0rDuTaTwxVo 6LNuSff83LbXHuvrTXNt+L0jQBVELPObeJjVkJH0dYd+3pYFZmTjf0BoGZPi+ZQHzz1E 8U+g== 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=tyG8Uz5IPYlXaj14QQNzmnpRyVTWkqEWXfdv0zBuD+s=; b=U7pwDRCxv1bZVeLn1ONWyuQFRQVBtAZpdVPqiMBWatbPE1yvu3hjDv1hipDSlyz3xL WcHUZEpXzw34qVzXoV7kOxZkS39HIAp/wlNQYIqNJrnjWXOuEViVoDRm3pxL9X+ZS7up U/NT9XVMCmj2RogVEtNY/AtcULc2fARSq6O2AI1c7WD9lbDaX/parSKUqGYq84u8Mx/4 wPUNv387cv4OHlBenaDm1W58e8DCRoJCO8wyptl+tHSYlvON0de9420AIrSdLcLnGEwj GLgdjFTEAZAdln7KA/emQnwOJkfLDtuzDMwo1O8/66GWMUiCiZjzJd4zh+XCNiHwH2y9 bS+A== 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 md17si11348588ejb.38.2021.02.22.02.47.53; Mon, 22 Feb 2021 02:48:15 -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 S230348AbhBVKqy (ORCPT + 99 others); Mon, 22 Feb 2021 05:46:54 -0500 Received: from smtp-bc0a.mail.infomaniak.ch ([45.157.188.10]:50261 "EHLO smtp-bc0a.mail.infomaniak.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230117AbhBVKqy (ORCPT ); Mon, 22 Feb 2021 05:46:54 -0500 Received: from smtp-3-0000.mail.infomaniak.ch (unknown [10.4.36.107]) by smtp-3-3000.mail.infomaniak.ch (Postfix) with ESMTPS id 4Dkf3y0rb3zMq8Xb; Mon, 22 Feb 2021 11:46:06 +0100 (CET) Received: from ns3096276.ip-94-23-54.eu (unknown [23.97.221.149]) by smtp-3-0000.mail.infomaniak.ch (Postfix) with ESMTPA id 4Dkf3v4nPyzlh8Tp; Mon, 22 Feb 2021 11:46:03 +0100 (CET) Subject: Re: [PATCH v2 3/3] security: Add LSMs dependencies to CONFIG_LSM To: Masahiro Yamada Cc: Ondrej Mosnacek , James Morris , "Serge E . Hallyn" , Casey Schaufler , Nicolas Iooss , Linux Kbuild mailing list , Linux kernel mailing list , Linux Security Module list , Kees Cook References: <20210215181511.2840674-1-mic@digikod.net> <20210215181511.2840674-4-mic@digikod.net> <8809a929-980a-95d1-42dc-576ff54e2923@digikod.net> From: =?UTF-8?Q?Micka=c3=abl_Sala=c3=bcn?= Message-ID: <12b27829-5db0-e9a4-0c74-896c53445da4@digikod.net> Date: Mon, 22 Feb 2021 11:47:20 +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 15:45, Masahiro Yamada wrote: > On Sun, Feb 21, 2021 at 8:11 PM Mickaël Salaün wrote: >> >> >> On 21/02/2021 09:50, Masahiro Yamada wrote: >>> On Tue, Feb 16, 2021 at 4:03 AM Ondrej Mosnacek wrote: >>>> >>>> On Mon, Feb 15, 2021 at 7:17 PM Mickaël Salaün wrote: >>>>> From: Mickaël Salaün >>>>> >>>>> Thanks to the previous commit, this gives the opportunity to users, when >>>>> running make oldconfig, to update the list of enabled LSMs at boot time >>>>> if an LSM has just been enabled or disabled in the build. Moreover, >>>>> this list only makes sense if at least one LSM is enabled. >>>>> >>>>> 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-4-mic@digikod.net >>>>> --- >>>>> >>>>> Changes since v1: >>>>> * Add CONFIG_SECURITY as a dependency of CONFIG_LSM. This prevent an >>>>> error when building without any LSMs. >>>>> --- >>>>> security/Kconfig | 4 ++++ >>>>> 1 file changed, 4 insertions(+) >>>>> >>>>> diff --git a/security/Kconfig b/security/Kconfig >>>>> index 7561f6f99f1d..addcc1c04701 100644 >>>>> --- a/security/Kconfig >>>>> +++ b/security/Kconfig >>>>> @@ -277,6 +277,10 @@ endchoice >>>>> >>>>> config LSM >>>>> string "Ordered list of enabled LSMs" >>>>> + depends on SECURITY || SECURITY_LOCKDOWN_LSM || SECURITY_YAMA || \ >>>>> + SECURITY_LOADPIN || SECURITY_SAFESETID || INTEGRITY || \ >>>>> + SECURITY_SELINUX || SECURITY_SMACK || SECURITY_TOMOYO || \ >>>>> + SECURITY_APPARMOR || BPF_LSM >>>> >>>> This looks really awkward, since all of these already depend on >>>> SECURITY (if not, it's a bug)... I guarantee you that after some time >>>> someone will come, see that the weird boolean expression is equivalent >>>> to just SECURITY, and simplify it. >>> >>> >>> Currently, LSM does not depend on SECURITY. >>> So you can always define LSM irrespective of SECURITY, >>> which seems a bug. >>> >>> So, I agree with adding 'depends on SECURITY'. >>> >>> What he is trying to achieve in this series >>> seems wrong, of course. >> >> This may be wrong in the general case, but not for CONFIG_LSM. >> >>> >>> >>>> I assume the new mechanism wouldn't work as intended if there is just >>>> SECURITY? If not, then maybe you should rather specify this value >>>> dependency via some new field rather than abusing "depends on" (say, >>>> "value depends on"?). The fact that a seemingly innocent change to the >>>> config definition breaks your mechanism suggests that the design is >>>> flawed. >> >> Masahiro, what do you think about this suggested "value depends on"? > > > Of course, no. > > > See the help text in init/Kconfig: > > This choice is there only for converting CONFIG_DEFAULT_SECURITY > in old kernel configs to CONFIG_LSM in new kernel configs. Don't > change this choice unless you are creating a fresh kernel config, > for this choice will be ignored after CONFIG_LSM has been set. > > > When CONFIG_LSM is already set in the .config, > this choice is just ignored. > So, oldconfig is working as the help message says. > > If you think 2623c4fbe2ad1341ff2d1e12410d0afdae2490ca > is a pointless commit, you should ask Kees about it. This commit was for backward compatibility to not change the configured system behavior because of a new default configuration. Here I want to address a forward compatibility issue: when users want to enable an LSM, give them the opportunity to enable it at boot time too instead of silently ignoring this new configuration at boot time. Indeed, there is two kind of configurations: built time configuration with Kconfig, and boot time configuration with the content of CONFIG_LSM. However, there is no direct dependency between LSM toggles and CONFIG_LSM once it is set. I think a better solution would be to add a new CONFIG_LSM_AUTO boolean to automatically generate the content of CONFIG_LSM according to the (build/kconfig) enabled LSMs, while letting users the ability to manually configure CONFIG_LSM otherwise. What do you think? > >>>> >>>> I do think this would be a useful feature, but IMHO shouldn't be >>>> implemented like this. >>>> >>>>> default "lockdown,yama,loadpin,safesetid,integrity,smack,selinux,tomoyo,apparmor,bpf" if DEFAULT_SECURITY_SMACK >>>>> default "lockdown,yama,loadpin,safesetid,integrity,apparmor,selinux,smack,tomoyo,bpf" if DEFAULT_SECURITY_APPARMOR >>>>> default "lockdown,yama,loadpin,safesetid,integrity,tomoyo,bpf" if DEFAULT_SECURITY_TOMOYO >>>>> -- >>>>> 2.30.0 >>>>> >>>> >>>> -- >>>> Ondrej Mosnacek >>>> Software Engineer, Linux Security - SELinux kernel >>>> Red Hat, Inc. >>>> >>> >>> > -- > Best Regards > Masahiro Yamada >