84 lines
2.7 KiB
Diff
84 lines
2.7 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Dimitri John Ledkov <dimitri.ledkov@canonical.com>
|
||
|
Date: Fri, 4 Mar 2022 11:36:09 +0100
|
||
|
Subject: [PATCH] grub-core/loader/efi/linux.c: drop now unused
|
||
|
grub_linuxefi_secure_validate
|
||
|
|
||
|
Drop the now unused grub_linuxefi_secure_validate() as all prior users
|
||
|
of this API now rely on the shim-lock-verifier codepath instead.
|
||
|
|
||
|
This patch must not be ported to older editions of grub code bases
|
||
|
that do not have verifiers framework, or it is not builtin, or
|
||
|
shim-lock-verifier is an optional module.
|
||
|
|
||
|
Signed-off-by: Dimitri John Ledkov <dimitri.ledkov@canonical.com>
|
||
|
---
|
||
|
grub-core/loader/efi/linux.c | 40 ----------------------------------------
|
||
|
include/grub/efi/linux.h | 2 --
|
||
|
2 files changed, 42 deletions(-)
|
||
|
|
||
|
diff --git a/grub-core/loader/efi/linux.c b/grub-core/loader/efi/linux.c
|
||
|
index 9260731c10..9265cf4200 100644
|
||
|
--- a/grub-core/loader/efi/linux.c
|
||
|
+++ b/grub-core/loader/efi/linux.c
|
||
|
@@ -24,46 +24,6 @@
|
||
|
#include <grub/efi/pe32.h>
|
||
|
#include <grub/efi/linux.h>
|
||
|
|
||
|
-#define SHIM_LOCK_GUID \
|
||
|
- { 0x605dab50, 0xe046, 0x4300, {0xab, 0xb6, 0x3d, 0xd8, 0x10, 0xdd, 0x8b, 0x23} }
|
||
|
-
|
||
|
-struct grub_efi_shim_lock
|
||
|
-{
|
||
|
- grub_efi_status_t (*verify) (void *buffer, grub_uint32_t size);
|
||
|
-};
|
||
|
-typedef struct grub_efi_shim_lock grub_efi_shim_lock_t;
|
||
|
-
|
||
|
-// Returns 1 on success, -1 on error, 0 when not available
|
||
|
-int
|
||
|
-grub_linuxefi_secure_validate (void *data, grub_uint32_t size)
|
||
|
-{
|
||
|
- grub_efi_guid_t guid = SHIM_LOCK_GUID;
|
||
|
- grub_efi_shim_lock_t *shim_lock;
|
||
|
- grub_efi_status_t status;
|
||
|
-
|
||
|
- shim_lock = grub_efi_locate_protocol(&guid, NULL);
|
||
|
- grub_dprintf ("secureboot", "shim_lock: %p\n", shim_lock);
|
||
|
- if (!shim_lock)
|
||
|
- {
|
||
|
- grub_dprintf ("secureboot", "shim not available\n");
|
||
|
- return 0;
|
||
|
- }
|
||
|
-
|
||
|
- grub_dprintf ("secureboot", "Asking shim to verify kernel signature\n");
|
||
|
- status = shim_lock->verify (data, size);
|
||
|
- grub_dprintf ("secureboot", "shim_lock->verify(): %ld\n", (long int)status);
|
||
|
- if (status == GRUB_EFI_SUCCESS)
|
||
|
- {
|
||
|
- grub_dprintf ("secureboot", "Kernel signature verification passed\n");
|
||
|
- return 1;
|
||
|
- }
|
||
|
-
|
||
|
- grub_dprintf ("secureboot", "Kernel signature verification failed (0x%lx)\n",
|
||
|
- (unsigned long) status);
|
||
|
-
|
||
|
- return -1;
|
||
|
-}
|
||
|
-
|
||
|
#pragma GCC diagnostic push
|
||
|
#pragma GCC diagnostic ignored "-Wcast-align"
|
||
|
|
||
|
diff --git a/include/grub/efi/linux.h b/include/grub/efi/linux.h
|
||
|
index 0033d9305a..887b02fd9f 100644
|
||
|
--- a/include/grub/efi/linux.h
|
||
|
+++ b/include/grub/efi/linux.h
|
||
|
@@ -22,8 +22,6 @@
|
||
|
#include <grub/err.h>
|
||
|
#include <grub/symbol.h>
|
||
|
|
||
|
-int
|
||
|
-EXPORT_FUNC(grub_linuxefi_secure_validate) (void *data, grub_uint32_t size);
|
||
|
grub_err_t
|
||
|
EXPORT_FUNC(grub_efi_linux_boot) (void *kernel_address, grub_off_t offset,
|
||
|
void *kernel_param);
|