Re: [PATCH 0/9] KEYS: Blacklisting & UEFI database load
From: joeyli
Date: Sat Mar 10 2018 - 22:21:42 EST
On Wed, Mar 07, 2018 at 07:28:37AM -0800, James Bottomley wrote:
> On Wed, 2018-03-07 at 08:18 -0500, Mimi Zohar wrote:
> > On Tue, 2018-03-06 at 15:05 +0100, Jiri Slaby wrote:
> > > what's the status of this please? Distributors (I checked SUSE,
> > > RedHat and Ubuntu) have to carry these patches and every of them
> > > have to forward-port the patches to new kernels. So are you going
> > > to resend the PR to have this merged?
> [...]
> > Just because I trust the platform keys prior to booting the kernel,
> > doesn't mean that I *want* to trust those keys once booted. ÂThere
> > are, however, places where we need access to those keys to verify a
> > signature (eg. kexec kernel image).
>
> Which is essentially the reason I always give when these patches come
> back
>
Josh Boyer's "MODSIGN: Allow the "db" UEFI variable to be suppressed"
patch checks MokIgnoreDB variable to ignore db:
https://git.kernel.org/pub/scm/linux/kernel/git/dhowells/linux-fs.git/commit/?h=keys-uefi&id=7c395b30a33a617c5cc2cdd419300af71277b79a
I think that we can consider to use MokAllowDB. Which means that kernel
ignores DB by default.
> > Nayna Jain's "certs: define a trusted platform keyring" patch set
> > introduces a new, separate keyring for these platform keys.
>
> Perhaps, to break the deadlock, we should ask JiÅÃ what the reason is
> the distros want these keys to be trusted. ÂApart from the Microsoft
> key, it will also give you an OEM key in your trusted keyring. ÂIs it
> something to do with OEM supplied modules?
>
As I remember that some manufacturers uses certificate in db to
sign their kernel module. We need to discuss with them for switching
to mok. Currently I do not know all use cases for using db.
There have some benefits for using db:
- User does not need to deal with shim-mokmanager to enroll mok.
Target machine doesn't need to reboot and user doesn't need to
face to mokmanager UI.
- The db is a authenticated variable, it's still secure when secure
boot is disabled.
The db is a authenticated variable that it can only be modified
by manufacturer's key. Kernel can trust it when secure boot
is disabled. It's useful for we do not need to taint kernel
for loading a manufacturer's kernel module even secure boot is
disabled.
- Do not need to worry about the space of NVRAM and the EFI firmware
implementation for writing a boot time variable.
But I also agree that we should not trust all keys (like Microsoft key)
in db by default.
Thanks a lot!
Joey Lee