From: Michael Chang <mchang@suse.com>
To: Dimitri John Ledkov <dimitri.ledkov@canonical.com>
Cc: The development of GNU GRUB <grub-devel@gnu.org>
Subject: Re: [PATCH] Add chainloaded image as shim's verifiable object
Date: Fri, 5 Mar 2021 21:34:30 +0800 [thread overview]
Message-ID: <20210305133430.GA30371@mercury> (raw)
In-Reply-To: <CADWks+bYZCws0V3D_aXJ1YN+=xVS6OGdY+Xq4xvJ9-ERYGrxjw@mail.gmail.com>
On Fri, Mar 05, 2021 at 12:21:49PM +0000, Dimitri John Ledkov wrote:
> This is not an oversight but intentional.
>
> Currently there is no chainloader support with SBAT as further
> development is required to ensure policy is applied correctly. Once
> SBAT support for chainloading is defined, it will be introduced.
Hm. What I heard is that shim wouldn't enfore SBAT validation for the
"indirect" image loaded by grub for now. So we should still able to
boot, eg, kernel and other efi image loaded by grub which is still in
lacking of SBAT support.
> And yes it is intended to continue to allow "boot windows" as the menu
> entry in grub.
So what is recommended solution in the interim ? We just can't afford
to release new grub version that cannot do the chainload ...
Thanks,
Michael
>
> On Fri, Mar 5, 2021 at 12:12 PM Michael Chang via Grub-devel
> <grub-devel@gnu.org> wrote:
> >
> > While attempting to dual boot Microsoft Windows with efi chainloader, it
> > failed with below error when secure boot was enabled.
> >
> > error ../../grub-core/kern/verifiers.c:119:verification requested but
> > nobody cares: /EFI/Microsoft/Boot/bootmgfw.efi.
> >
> > It is a regression, as previously it worked without problem.
> >
> > It turns out chainloading image has been locked down introduced by
> >
> > 578c95298 kern: Add lockdown support
> >
> > However we should consider it as verifiable object to shim to allow
> > booting in secure boot enabled mode. The chainloaded image could also
> > have trusted signature signed by vendor with their pubkey cert in db.
> > For that matters it's usage should not be locked down in secure boot,
> > and instead use shim to validate it's signature before running it.
> >
> > Signed-off-by: Michael Chang <mchang@suse.com>
> > ---
> > grub-core/kern/efi/sb.c | 1 +
> > grub-core/kern/lockdown.c | 1 -
> > 2 files changed, 1 insertion(+), 1 deletion(-)
> >
> > diff --git a/grub-core/kern/efi/sb.c b/grub-core/kern/efi/sb.c
> > index 41dadcd14..96d237722 100644
> > --- a/grub-core/kern/efi/sb.c
> > +++ b/grub-core/kern/efi/sb.c
> > @@ -129,6 +129,7 @@ shim_lock_verifier_init (grub_file_t io __attribute__ ((unused)),
> > case GRUB_FILE_TYPE_BSD_KERNEL:
> > case GRUB_FILE_TYPE_XNU_KERNEL:
> > case GRUB_FILE_TYPE_PLAN9_KERNEL:
> > + case GRUB_FILE_TYPE_EFI_CHAINLOADED_IMAGE:
> > *flags = GRUB_VERIFY_FLAGS_SINGLE_CHUNK;
> >
> > /* Fall through. */
> > diff --git a/grub-core/kern/lockdown.c b/grub-core/kern/lockdown.c
> > index 0bc70fd42..e1fd1c1e2 100644
> > --- a/grub-core/kern/lockdown.c
> > +++ b/grub-core/kern/lockdown.c
> > @@ -48,7 +48,6 @@ lockdown_verifier_init (grub_file_t io __attribute__ ((unused)),
> > case GRUB_FILE_TYPE_PXECHAINLOADER:
> > case GRUB_FILE_TYPE_PCCHAINLOADER:
> > case GRUB_FILE_TYPE_COREBOOT_CHAINLOADER:
> > - case GRUB_FILE_TYPE_EFI_CHAINLOADED_IMAGE:
> > case GRUB_FILE_TYPE_ACPI_TABLE:
> > case GRUB_FILE_TYPE_DEVICE_TREE_IMAGE:
> > *flags = GRUB_VERIFY_FLAGS_DEFER_AUTH;
> > --
> > 2.26.2
> >
> >
> > _______________________________________________
> > Grub-devel mailing list
> > Grub-devel@gnu.org
> > https://lists.gnu.org/mailman/listinfo/grub-devel
>
>
>
> --
> Regards,
>
> Dimitri.
>
next prev parent reply other threads:[~2021-03-05 13:34 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-03-05 12:11 [PATCH] Add chainloaded image as shim's verifiable object Michael Chang
2021-03-05 12:21 ` Dimitri John Ledkov
2021-03-05 13:34 ` Michael Chang [this message]
2021-03-05 13:49 ` Dimitri John Ledkov
2021-03-08 4:59 ` Michael Chang
2021-03-09 18:45 ` Thomas Frauendorfer
2021-03-10 2:33 ` Michael Chang
2021-03-05 12:32 ` Thomas Frauendorfer
2021-03-05 13:19 ` Michael Chang
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=20210305133430.GA30371@mercury \
--to=mchang@suse.com \
--cc=dimitri.ledkov@canonical.com \
--cc=grub-devel@gnu.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.