forked from rpms/shim-unsigned-aarch64
61 lines
1.8 KiB
Diff
61 lines
1.8 KiB
Diff
|
From 9ab0d796bdc9cefdaa3b0df7434845d26c43d894 Mon Sep 17 00:00:00 2001
|
||
|
From: Patrick Uiterwijk <patrick@puiterwijk.org>
|
||
|
Date: Mon, 5 Nov 2018 14:51:16 +0100
|
||
|
Subject: [PATCH 1/3] Make sure that MOK variables always get mirrored
|
||
|
|
||
|
Without this, if a Mok variable doesn't exist in Boot Services, it will also
|
||
|
not be copied to Runtime, even if we have data to be added to it (vendor cert).
|
||
|
This patch makes sure that if we have extra data to append, we still mirror
|
||
|
the variable.
|
||
|
|
||
|
Signed-off-by: Patrick Uiterwijk <patrick@puiterwijk.org>
|
||
|
---
|
||
|
mok.c | 20 ++++++++++++++++----
|
||
|
1 file changed, 16 insertions(+), 4 deletions(-)
|
||
|
|
||
|
diff --git a/mok.c b/mok.c
|
||
|
index 38675211e0e..00dd1ad3034 100644
|
||
|
--- a/mok.c
|
||
|
+++ b/mok.c
|
||
|
@@ -223,11 +223,26 @@ EFI_STATUS import_mok_state(EFI_HANDLE image_handle)
|
||
|
UINT32 attrs = 0;
|
||
|
BOOLEAN delete = FALSE, present, addend;
|
||
|
|
||
|
+ addend = (v->addend_source && v->addend_size &&
|
||
|
+ *v->addend_source && *v->addend_size)
|
||
|
+ ? TRUE : FALSE;
|
||
|
+
|
||
|
efi_status = get_variable_attr(v->name,
|
||
|
&v->data, &v->data_size,
|
||
|
*v->guid, &attrs);
|
||
|
- if (efi_status == EFI_NOT_FOUND)
|
||
|
+ if (efi_status == EFI_NOT_FOUND) {
|
||
|
+ if (v->rtname && addend) {
|
||
|
+ efi_status = mirror_one_mok_variable(v);
|
||
|
+ if (EFI_ERROR(efi_status) &&
|
||
|
+ ret != EFI_SECURITY_VIOLATION)
|
||
|
+ ret = efi_status;
|
||
|
+ }
|
||
|
+ /*
|
||
|
+ * after possibly adding, we can continue, no
|
||
|
+ * further checks to be done.
|
||
|
+ */
|
||
|
continue;
|
||
|
+ }
|
||
|
if (EFI_ERROR(efi_status)) {
|
||
|
perror(L"Could not verify %s: %r\n", v->name,
|
||
|
efi_status);
|
||
|
@@ -272,9 +287,6 @@ EFI_STATUS import_mok_state(EFI_HANDLE image_handle)
|
||
|
}
|
||
|
|
||
|
present = (v->data && v->data_size) ? TRUE : FALSE;
|
||
|
- addend = (v->addend_source && v->addend_size &&
|
||
|
- *v->addend_source && *v->addend_size)
|
||
|
- ? TRUE : FALSE;
|
||
|
|
||
|
if (v->flags & MOK_VARIABLE_MEASURE && present) {
|
||
|
/*
|
||
|
--
|
||
|
2.20.1
|
||
|
|