loader/xnu: Don't allow loading extension and packages when locked down

The shim_lock verifier validates the XNU kernels but no its extensions
and packages. Prevent these to be loaded when the GRUB is locked down.

Signed-off-by: Javier Martinez Canillas <javierm@redhat.com>
Reviewed-by: Daniel Kiper <daniel.kiper@oracle.com>
This commit is contained in:
Javier Martinez Canillas 2021-02-24 14:44:38 +01:00 committed by Daniel Kiper
parent 5082708389
commit 9c5565135f

View File

@ -1485,20 +1485,23 @@ GRUB_MOD_INIT(xnu)
N_("Load XNU image.")); N_("Load XNU image."));
cmd_kernel64 = grub_register_command ("xnu_kernel64", grub_cmd_xnu_kernel64, cmd_kernel64 = grub_register_command ("xnu_kernel64", grub_cmd_xnu_kernel64,
0, N_("Load 64-bit XNU image.")); 0, N_("Load 64-bit XNU image."));
cmd_mkext = grub_register_command ("xnu_mkext", grub_cmd_xnu_mkext, 0, cmd_mkext = grub_register_command_lockdown ("xnu_mkext", grub_cmd_xnu_mkext, 0,
N_("Load XNU extension package.")); N_("Load XNU extension package."));
cmd_kext = grub_register_command ("xnu_kext", grub_cmd_xnu_kext, 0, cmd_kext = grub_register_command_lockdown ("xnu_kext", grub_cmd_xnu_kext, 0,
N_("Load XNU extension.")); N_("Load XNU extension."));
cmd_kextdir = grub_register_command ("xnu_kextdir", grub_cmd_xnu_kextdir, cmd_kextdir = grub_register_command_lockdown ("xnu_kextdir", grub_cmd_xnu_kextdir,
/* TRANSLATORS: OSBundleRequired is a /*
variable name in xnu extensions * TRANSLATORS: OSBundleRequired is
manifests. It behaves mostly like * a variable name in xnu extensions
GNU/Linux runlevels. * manifests. It behaves mostly like
*/ * GNU/Linux runlevels.
N_("DIRECTORY [OSBundleRequired]"), */
/* TRANSLATORS: There are many extensions N_("DIRECTORY [OSBundleRequired]"),
in extension directory. */ /*
N_("Load XNU extension directory.")); * TRANSLATORS: There are many extensions
* in extension directory.
*/
N_("Load XNU extension directory."));
cmd_ramdisk = grub_register_command ("xnu_ramdisk", grub_cmd_xnu_ramdisk, 0, cmd_ramdisk = grub_register_command ("xnu_ramdisk", grub_cmd_xnu_ramdisk, 0,
/* TRANSLATORS: ramdisk here isn't identifier. It can be translated. */ /* TRANSLATORS: ramdisk here isn't identifier. It can be translated. */
N_("Load XNU ramdisk. " N_("Load XNU ramdisk. "