From: Roberto Sassu <roberto.sassu@huaweicloud.com>
To: Eric Snowberg <eric.snowberg@oracle.com>
Cc: Mimi Zohar <zohar@linux.ibm.com>,
Dmitry Kasatkin <dmitry.kasatkin@gmail.com>,
"corbet@lwn.net" <corbet@lwn.net>,
"mcgrof@kernel.org" <mcgrof@kernel.org>,
"petr.pavlu@suse.com" <petr.pavlu@suse.com>,
"samitolvanen@google.com" <samitolvanen@google.com>,
"da.gomez@samsung.com" <da.gomez@samsung.com>,
Andrew Morton <akpm@linux-foundation.org>,
"paul@paul-moore.com" <paul@paul-moore.com>,
"jmorris@namei.org" <jmorris@namei.org>,
"serge@hallyn.com" <serge@hallyn.com>,
"shuah@kernel.org" <shuah@kernel.org>,
"mcoquelin.stm32@gmail.com" <mcoquelin.stm32@gmail.com>,
"alexandre.torgue@foss.st.com" <alexandre.torgue@foss.st.com>,
"linux-integrity@vger.kernel.org"
<linux-integrity@vger.kernel.org>,
"linux-doc@vger.kernel.org" <linux-doc@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-api@vger.kernel.org" <linux-api@vger.kernel.org>,
"linux-modules@vger.kernel.org" <linux-modules@vger.kernel.org>,
"linux-security-module@vger.kernel.org"
<linux-security-module@vger.kernel.org>,
"linux-kselftest@vger.kernel.org"
<linux-kselftest@vger.kernel.org>,
"wufan@linux.microsoft.com" <wufan@linux.microsoft.com>,
"pbrobinson@gmail.com" <pbrobinson@gmail.com>,
"zbyszek@in.waw.pl" <zbyszek@in.waw.pl>,
"hch@lst.de" <hch@lst.de>,
"mjg59@srcf.ucam.org" <mjg59@srcf.ucam.org>,
"pmatilai@redhat.com" <pmatilai@redhat.com>,
"jannh@google.com" <jannh@google.com>,
"dhowells@redhat.com" <dhowells@redhat.com>,
"jikos@kernel.org" <jikos@kernel.org>,
"mkoutny@suse.com" <mkoutny@suse.com>,
"ppavlu@suse.com" <ppavlu@suse.com>,
"petr.vorel@gmail.com" <petr.vorel@gmail.com>,
"mzerqung@0pointer.de" <mzerqung@0pointer.de>,
"kgold@linux.ibm.com" <kgold@linux.ibm.com>,
Roberto Sassu <roberto.sassu@huawei.com>
Subject: Re: [PATCH v6 00/15] integrity: Introduce the Integrity Digest Cache
Date: Thu, 05 Dec 2024 17:16:41 +0100 [thread overview]
Message-ID: <d3b1c297e860339a00d3e11d1a777362833aadad.camel@huaweicloud.com> (raw)
In-Reply-To: <3a759c091ac097be84b882dd992e6e216ec11723.camel@huaweicloud.com>
On Thu, 2024-12-05 at 09:53 +0100, Roberto Sassu wrote:
> On Thu, 2024-12-05 at 00:57 +0000, Eric Snowberg wrote:
> >
> > > On Dec 4, 2024, at 3:44 AM, Roberto Sassu <roberto.sassu@huaweicloud.com> wrote:
> > >
> > > On Tue, 2024-12-03 at 20:06 +0000, Eric Snowberg wrote:
> > > >
> > > > > On Nov 26, 2024, at 3:41 AM, Roberto Sassu <roberto.sassu@huaweicloud.com> wrote:
> > > > >
> > > > > On Tue, 2024-11-26 at 00:13 +0000, Eric Snowberg wrote:
> > > > > >
> > > > > > > On Nov 19, 2024, at 3:49 AM, Roberto Sassu <roberto.sassu@huaweicloud.com> wrote:
> > > > > > >
> > > > > > > From: Roberto Sassu <roberto.sassu@huawei.com>
> > > > > > >
> > > > > > > The Integrity Digest Cache can also help IMA for appraisal. IMA can simply
> > > > > > > lookup the calculated digest of an accessed file in the list of digests
> > > > > > > extracted from package headers, after verifying the header signature. It is
> > > > > > > sufficient to verify only one signature for all files in the package, as
> > > > > > > opposed to verifying a signature for each file.
> > > > > >
> > > > > > Is there a way to maintain integrity over time? Today if a CVE is discovered
> > > > > > in a signed program, the program hash can be added to the blacklist keyring.
> > > > > > Later if IMA appraisal is used, the signature validation will fail just for that
> > > > > > program. With the Integrity Digest Cache, is there a way to do this?
> > > > >
> > > > > As far as I can see, the ima_check_blacklist() call is before
> > > > > ima_appraise_measurement(). If it fails, appraisal with the Integrity
> > > > > Digest Cache will not be done.
> > > >
> > > >
> > > > It is good the program hash would be checked beforehand and fail if it is
> > > > contained on the list.
> > > >
> > > > The .ima keyring may contain many keys. If one of the keys was later
> > > > revoked and added to the .blacklist, wouldn't this be missed? It would
> > > > be caught during signature validation when the file is later appraised, but
> > > > now this step isn't taking place. Correct?
> > >
> > > For files included in the digest lists, yes, there won't be detection
> > > of later revocation of a key. However, it will still work at package
> > > level/digest list level, since they are still appraised with a
> > > signature.
> > >
> > > We can add a mechanism (if it does not already exist) to invalidate the
> > > integrity status based on key revocation, which can be propagated to
> > > files verified with the affected digest lists.
> > >
> > > > With IMA appraisal, it is easy to maintain authenticity but challenging to
> > > > maintain integrity over time. In user-space there are constantly new CVEs.
> > > > To maintain integrity over time, either keys need to be rotated in the .ima
> > > > keyring or program hashes need to be frequently added to the .blacklist.
> > > > If neither is done, for an end-user on a distro, IMA-appraisal basically
> > > > guarantees authenticity.
> > > >
> > > > While I understand the intent of the series is to increase performance,
> > > > have you considered using this to give the end-user the ability to maintain
> > > > integrity of their system? What I mean is, instead of trying to import anything
> > > > from an RPM, just have the end-user provide this information in some format
> > > > to the Digest Cache. User-space tools could be built to collect and format
> > >
> > > This is already possible, digest-cache-tools
> > > (https://github.com/linux-integrity/digest-cache-tools) already allow
> > > to create a digest list with the file a user wants.
> > >
> > > But in this case, the user is vouching for having taken the correct
> > > measure of the file at the time it was added to the digest list. This
> > > would be instead automatically guaranteed by RPMs or other packages
> > > shipped with Linux distributions.
> > >
> > > To mitigate the concerns of CVEs, we can probably implement a rollback
> > > prevention mechanism, which would not allow to load a previous version
> > > of a digest list.
> >
> > IMHO, pursuing this with the end-user being in control of what is contained
> > within the Digest Cache vs what is contained in a distro would provide more
> > value. Allowing the end-user to easily update their Digest Cache in some way
> > without having to do any type of revocation for both old and vulnerable
> > applications with CVEs would be very beneficial.
>
> Yes, deleting the digest list would invalidate any integrity result
> done with that digest list.
>
> I developed also an rpm plugin that synchronizes the digest lists with
> installed software. Old vulnerable software cannot be verified anymore
> with the Integrity Digest Cache, since the rpm plugin deletes the old
> software digest lists.
>
> https://github.com/linux-integrity/digest-cache-tools/blob/main/rpm-plugin/digest_cache.c
>
> The good thing is that the Integrity Digest Cache can be easily
> controlled with filesystem operations (it works similarly to security
> blobs attached to kernel objects, like inodes and file descriptors).
>
> As soon as something changes (e.g. digest list written, link to the
> digest lists), this triggers a reset in the Integrity Digest Cache, so
> digest lists and files need to be verified again. Deleting the digest
> list causes the in-kernel digest cache to be wiped away too (when the
> reference count reaches zero).
>
> > Is there a belief the Digest Cache would be used without signed kernel
> > modules? Is the performance gain worth changing how kernel modules
> > get loaded at boot? Couldn't this part just be dropped for easier acceptance?
> > Integrity is already maintained with the current model of appended signatures.
>
> I don't like making exceptions in the design, and I recently realized
> that it should not be task of the users of the Integrity Digest Cache
> to limit themselves.
Forgot to mention that your use case is possible. The usage of the
Integrity Digest Cache must be explicitly enabled in the IMA policy. It
will be used if the matching rule has 'digest_cache=data' (its foreseen
to be used also for metadata).
For kernel modules, it is sufficient to not provide that keyword for
the MODULE_CHECK hook.
However, there is the possibility that you lose another advantage of
the Integrity Digest Cache, the predictability of the IMA PCR. By not
using digest caches, there is the risk that the IMA PCR will be
unstable, due to loading kernel modules in a different order at each
boot.
Roberto
> But the main problem was not the kernel modules themselves, but the
> infrastructure needed in user space to load them, which might not be
> available at the time a digest list parser needs to be loaded.
>
> I hope ksys_finit_module() does not cause too much resistance (however
> I need to document it better, as others noted). It is just a different
> way to pass the same parameters of the finit_module() system call.
>
> Thanks
>
> Roberto
next prev parent reply other threads:[~2024-12-05 16:17 UTC|newest]
Thread overview: 54+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-19 10:49 [PATCH v6 00/15] integrity: Introduce the Integrity Digest Cache Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 01/15] lib: Add TLV parser Roberto Sassu
2024-11-19 16:51 ` Randy Dunlap
2025-01-21 13:29 ` Thomas Weißschuh
2025-01-21 13:48 ` Roberto Sassu
2025-01-21 14:21 ` Thomas Weißschuh
2025-01-21 14:29 ` Roberto Sassu
2025-01-21 14:55 ` Roberto Sassu
2025-01-21 21:42 ` Thomas Weißschuh
2024-11-19 10:49 ` [PATCH v6 02/15] module: Introduce ksys_finit_module() Roberto Sassu
2024-11-19 12:14 ` Christoph Hellwig
2024-11-19 14:33 ` Roberto Sassu
2024-11-19 20:10 ` Luis Chamberlain
2024-11-20 9:16 ` Roberto Sassu
2024-11-20 9:18 ` Roberto Sassu
2024-11-25 23:40 ` Luis Chamberlain
2024-11-26 7:56 ` Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 03/15] integrity: Introduce the Integrity Digest Cache Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 04/15] digest_cache: Initialize digest caches Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 05/15] digest_cache: Add securityfs interface Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 06/15] digest_cache: Add hash tables and operations Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 07/15] digest_cache: Allow registration of digest list parsers Roberto Sassu
2024-11-19 16:46 ` Randy Dunlap
2024-11-19 16:48 ` Roberto Sassu
2024-11-25 23:53 ` Luis Chamberlain
2024-11-26 10:25 ` Roberto Sassu
2024-11-26 19:04 ` Luis Chamberlain
2024-11-27 9:51 ` Roberto Sassu
2024-11-27 19:53 ` Luis Chamberlain
2024-11-28 8:23 ` Roberto Sassu
2024-11-28 20:40 ` Luis Chamberlain
2024-11-29 8:30 ` Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 08/15] digest_cache: Parse tlv digest lists Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 09/15] digest_cache: Populate the digest cache from a digest list Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 10/15] digest_cache: Add management of verification data Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 11/15] digest_cache: Add support for directories Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 12/15] digest cache: Prefetch digest lists if requested Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 13/15] digest_cache: Reset digest cache on file/directory change Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 14/15] selftests/digest_cache: Add selftests for the Integrity Digest Cache Roberto Sassu
2024-11-19 10:49 ` [PATCH v6 15/15] docs: Add documentation of " Roberto Sassu
2024-11-19 20:03 ` [PATCH v6 00/15] integrity: Introduce " Luis Chamberlain
2024-11-26 0:13 ` Eric Snowberg
2024-11-26 10:41 ` Roberto Sassu
2024-12-03 20:06 ` Eric Snowberg
2024-12-04 10:44 ` Roberto Sassu
2024-12-05 0:57 ` Eric Snowberg
2024-12-05 8:53 ` Roberto Sassu
2024-12-05 16:16 ` Roberto Sassu [this message]
2024-12-05 19:41 ` Eric Snowberg
2024-12-06 10:06 ` Roberto Sassu
2024-12-06 15:15 ` Eric Snowberg
2024-12-06 15:26 ` Roberto Sassu
2024-11-27 17:30 ` Dr. Greg
2024-11-27 17:56 ` Roberto Sassu
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=d3b1c297e860339a00d3e11d1a777362833aadad.camel@huaweicloud.com \
--to=roberto.sassu@huaweicloud.com \
--cc=akpm@linux-foundation.org \
--cc=alexandre.torgue@foss.st.com \
--cc=corbet@lwn.net \
--cc=da.gomez@samsung.com \
--cc=dhowells@redhat.com \
--cc=dmitry.kasatkin@gmail.com \
--cc=eric.snowberg@oracle.com \
--cc=hch@lst.de \
--cc=jannh@google.com \
--cc=jikos@kernel.org \
--cc=jmorris@namei.org \
--cc=kgold@linux.ibm.com \
--cc=linux-api@vger.kernel.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-integrity@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-modules@vger.kernel.org \
--cc=linux-security-module@vger.kernel.org \
--cc=mcgrof@kernel.org \
--cc=mcoquelin.stm32@gmail.com \
--cc=mjg59@srcf.ucam.org \
--cc=mkoutny@suse.com \
--cc=mzerqung@0pointer.de \
--cc=paul@paul-moore.com \
--cc=pbrobinson@gmail.com \
--cc=petr.pavlu@suse.com \
--cc=petr.vorel@gmail.com \
--cc=pmatilai@redhat.com \
--cc=ppavlu@suse.com \
--cc=roberto.sassu@huawei.com \
--cc=samitolvanen@google.com \
--cc=serge@hallyn.com \
--cc=shuah@kernel.org \
--cc=wufan@linux.microsoft.com \
--cc=zbyszek@in.waw.pl \
--cc=zohar@linux.ibm.com \
/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;
as well as URLs for NNTP newsgroup(s).