From: Song Liu <songliubraving@meta.com>
To: Paul Moore <paul@paul-moore.com>
Cc: Song Liu <songliubraving@meta.com>,
Casey Schaufler <casey@schaufler-ca.com>,
Song Liu <song@kernel.org>,
"linux-fsdevel@vger.kernel.org" <linux-fsdevel@vger.kernel.org>,
"linux-integrity@vger.kernel.org"
<linux-integrity@vger.kernel.org>,
"linux-security-module@vger.kernel.org"
<linux-security-module@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"roberto.sassu@huawei.com" <roberto.sassu@huawei.com>,
"dmitry.kasatkin@gmail.com" <dmitry.kasatkin@gmail.com>,
"eric.snowberg@oracle.com" <eric.snowberg@oracle.com>,
"jmorris@namei.org" <jmorris@namei.org>,
"serge@hallyn.com" <serge@hallyn.com>,
Kernel Team <kernel-team@meta.com>,
"brauner@kernel.org" <brauner@kernel.org>,
"jack@suse.cz" <jack@suse.cz>,
"viro@zeniv.linux.org.uk" <viro@zeniv.linux.org.uk>
Subject: Re: [RFC 0/2] ima: evm: Add kernel cmdline options to disable IMA/EVM
Date: Tue, 17 Dec 2024 23:33:29 +0000 [thread overview]
Message-ID: <6E598674-720E-40CE-B3F2-B480323C1926@fb.com> (raw)
In-Reply-To: <CAHC9VhRWhbFbeM0aNhatFTxZ+q0qKVKgPGUUKq4GuZMOzR2aJw@mail.gmail.com>
> On Dec 17, 2024, at 3:16 PM, Paul Moore <paul@paul-moore.com> wrote:
>
> On Tue, Dec 17, 2024 at 5:47 PM Song Liu <songliubraving@meta.com> wrote:
>>
>> If we use lsm= to control ima and evm, we will need the following
>> changes in ordered_lsm_parse(). We still need supporting logic
>> in ima and evm side, so that ima and evm are only initialized
>> when they are in lsm=.
>>
>> Does this sound the right way forward?
>
> Have you tested it? What happens? There is value in going through
> the testing process, especially if you haven't played much with the
> LSM code.
Yes, I tested both the original patches and the "lsm=xx" version.
>
> I'd also want to see a comment line in both places explaining why it
> is necessary to mark the LSM as enabled prior to actually adding it to
> @ordered_lsms. Something along the lines of only parsing the
> parameter once should be sufficient.
Please see below for the explanation. I will add different words in
the actual comments so they make more sense as comments
>
>> diff --git i/security/security.c w/security/security.c
>> index 09664e09fec9..00271be3b0c1 100644
>> --- i/security/security.c
>> +++ w/security/security.c
>> @@ -365,6 +365,9 @@ static void __init ordered_lsm_parse(const char *order, const char *origin)
>> if (strcmp(lsm->name, name) == 0) {
>> if (lsm->order == LSM_ORDER_MUTABLE)
>> append_ordered_lsm(lsm, origin);
>> + else if (lsm->order == LSM_ORDER_LAST)
>> + set_enabled(lsm, true);
We need a flag here, saying we want to enable the lsm. We cannot do
append_ordered_lsm() yet, otherwise, it will not be "last".
>> +
>> found = true;
>> }
>> }
>> @@ -386,7 +389,7 @@ static void __init ordered_lsm_parse(const char *order, const char *origin)
>>
>> /* LSM_ORDER_LAST is always last. */
>> for (lsm = __start_lsm_info; lsm < __end_lsm_info; lsm++) {
>> - if (lsm->order == LSM_ORDER_LAST)
>> + if (lsm->order == LSM_ORDER_LAST && is_enabled(lsm))
>> append_ordered_lsm(lsm, " last");
Before this change, lsm with order==LSM_ORDER_LAST is always considered
enabled, which is a bug (if I understand you and Casey correctly).
To fix this, we need a flag from above saying we actually want to enable
it.
I personally think it is fine to use set_enabled() to set the flag.
But I don't have a strong preference, we can add a different flag.
Does this make sense?
Thanks,
Song
next prev parent reply other threads:[~2024-12-17 23:33 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-17 20:25 [RFC 0/2] ima: evm: Add kernel cmdline options to disable IMA/EVM Song Liu
2024-12-17 20:25 ` [RFC 1/2] ima: Add kernel parameter to disable IMA Song Liu
2024-12-17 20:25 ` [RFC 2/2] evm: Add kernel parameter to disable EVM Song Liu
2024-12-17 21:29 ` [RFC 0/2] ima: evm: Add kernel cmdline options to disable IMA/EVM Casey Schaufler
2024-12-17 21:59 ` Paul Moore
2024-12-17 22:04 ` Song Liu
2024-12-17 22:47 ` Song Liu
2024-12-17 23:16 ` Paul Moore
2024-12-17 23:33 ` Song Liu [this message]
2024-12-18 6:41 ` Song Liu
2024-12-18 16:42 ` Casey Schaufler
2024-12-18 16:48 ` Song Liu
2024-12-17 22:02 ` Song Liu
2024-12-18 11:02 ` Mimi Zohar
2024-12-18 17:07 ` Song Liu
2024-12-19 15:40 ` Roberto Sassu
2024-12-19 17:46 ` Song Liu
2024-12-19 18:18 ` Mimi Zohar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=6E598674-720E-40CE-B3F2-B480323C1926@fb.com \
--to=songliubraving@meta.com \
--cc=brauner@kernel.org \
--cc=casey@schaufler-ca.com \
--cc=dmitry.kasatkin@gmail.com \
--cc=eric.snowberg@oracle.com \
--cc=jack@suse.cz \
--cc=jmorris@namei.org \
--cc=kernel-team@meta.com \
--cc=linux-fsdevel@vger.kernel.org \
--cc=linux-integrity@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-security-module@vger.kernel.org \
--cc=paul@paul-moore.com \
--cc=roberto.sassu@huawei.com \
--cc=serge@hallyn.com \
--cc=song@kernel.org \
--cc=viro@zeniv.linux.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox