x86/ima: check EFI SetupMode too
authorMimi Zohar <zohar@linux.ibm.com>
Wed, 24 Apr 2019 17:05:46 +0000 (13:05 -0400)
committerMimi Zohar <zohar@linux.ibm.com>
Thu, 30 May 2019 03:20:46 +0000 (23:20 -0400)
Checking "SecureBoot" mode is not sufficient, also check "SetupMode".

Fixes: 399574c64eaf ("x86/ima: retry detecting secure boot mode")
Reported-by: Matthew Garrett <mjg59@google.com>
Signed-off-by: Mimi Zohar <zohar@linux.ibm.com>
arch/x86/kernel/ima_arch.c

index 64b973f..4c40783 100644 (file)
@@ -11,10 +11,11 @@ extern struct boot_params boot_params;
 static enum efi_secureboot_mode get_sb_mode(void)
 {
        efi_char16_t efi_SecureBoot_name[] = L"SecureBoot";
+       efi_char16_t efi_SetupMode_name[] = L"SecureBoot";
        efi_guid_t efi_variable_guid = EFI_GLOBAL_VARIABLE_GUID;
        efi_status_t status;
        unsigned long size;
-       u8 secboot;
+       u8 secboot, setupmode;
 
        size = sizeof(secboot);
 
@@ -36,7 +37,14 @@ static enum efi_secureboot_mode get_sb_mode(void)
                return efi_secureboot_mode_unknown;
        }
 
-       if (secboot == 0) {
+       size = sizeof(setupmode);
+       status = efi.get_variable(efi_SetupMode_name, &efi_variable_guid,
+                                 NULL, &size, &setupmode);
+
+       if (status != EFI_SUCCESS)      /* ignore unknown SetupMode */
+               setupmode = 0;
+
+       if (secboot == 0 || setupmode == 1) {
                pr_info("ima: secureboot mode disabled\n");
                return efi_secureboot_mode_disabled;
        }