mirror of
https://github.com/tbsdtv/linux_media.git
synced 2025-07-23 12:43:29 +02:00
Merge tag 'efi-core-2020-10-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull EFI changes from Ingo Molnar: - Preliminary RISC-V enablement - the bulk of it will arrive via the RISCV tree. - Relax decompressed image placement rules for 32-bit ARM - Add support for passing MOK certificate table contents via a config table rather than a EFI variable. - Add support for 18 bit DIMM row IDs in the CPER records. - Work around broken Dell firmware that passes the entire Boot#### variable contents as the command line - Add definition of the EFI_MEMORY_CPU_CRYPTO memory attribute so we can identify it in the memory map listings. - Don't abort the boot on arm64 if the EFI RNG protocol is available but returns with an error - Replace slashes with exclamation marks in efivarfs file names - Split efi-pstore from the deprecated efivars sysfs code, so we can disable the latter on !x86. - Misc fixes, cleanups and updates. * tag 'efi-core-2020-10-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (26 commits) efi: mokvar: add missing include of asm/early_ioremap.h efi: efivars: limit availability to X86 builds efi: remove some false dependencies on CONFIG_EFI_VARS efi: gsmi: fix false dependency on CONFIG_EFI_VARS efi: efivars: un-export efivars_sysfs_init() efi: pstore: move workqueue handling out of efivars efi: pstore: disentangle from deprecated efivars module efi: mokvar-table: fix some issues in new code efi/arm64: libstub: Deal gracefully with EFI_RNG_PROTOCOL failure efivarfs: Replace invalid slashes with exclamation marks in dentries. efi: Delete deprecated parameter comments efi/libstub: Fix missing-prototypes in string.c efi: Add definition of EFI_MEMORY_CPU_CRYPTO and ability to report it cper,edac,efi: Memory Error Record: bank group/address and chip id edac,ghes,cper: Add Row Extension to Memory Error Record efi/x86: Add a quirk to support command line arguments on Dell EFI firmware efi/libstub: Add efi_warn and *_once logging helpers integrity: Load certs from the EFI MOK config table integrity: Move import of MokListRT certs to a separate routine efi: Support for MOK variable config table ...
This commit is contained in:
@@ -66,6 +66,65 @@ static __init void *get_cert_list(efi_char16_t *name, efi_guid_t *guid,
|
||||
}
|
||||
|
||||
/*
|
||||
* load_moklist_certs() - Load MokList certs
|
||||
*
|
||||
* Load the certs contained in the UEFI MokListRT database into the
|
||||
* platform trusted keyring.
|
||||
*
|
||||
* This routine checks the EFI MOK config table first. If and only if
|
||||
* that fails, this routine uses the MokListRT ordinary UEFI variable.
|
||||
*
|
||||
* Return: Status
|
||||
*/
|
||||
static int __init load_moklist_certs(void)
|
||||
{
|
||||
struct efi_mokvar_table_entry *mokvar_entry;
|
||||
efi_guid_t mok_var = EFI_SHIM_LOCK_GUID;
|
||||
void *mok;
|
||||
unsigned long moksize;
|
||||
efi_status_t status;
|
||||
int rc;
|
||||
|
||||
/* First try to load certs from the EFI MOKvar config table.
|
||||
* It's not an error if the MOKvar config table doesn't exist
|
||||
* or the MokListRT entry is not found in it.
|
||||
*/
|
||||
mokvar_entry = efi_mokvar_entry_find("MokListRT");
|
||||
if (mokvar_entry) {
|
||||
rc = parse_efi_signature_list("UEFI:MokListRT (MOKvar table)",
|
||||
mokvar_entry->data,
|
||||
mokvar_entry->data_size,
|
||||
get_handler_for_db);
|
||||
/* All done if that worked. */
|
||||
if (!rc)
|
||||
return rc;
|
||||
|
||||
pr_err("Couldn't parse MokListRT signatures from EFI MOKvar config table: %d\n",
|
||||
rc);
|
||||
}
|
||||
|
||||
/* Get MokListRT. It might not exist, so it isn't an error
|
||||
* if we can't get it.
|
||||
*/
|
||||
mok = get_cert_list(L"MokListRT", &mok_var, &moksize, &status);
|
||||
if (mok) {
|
||||
rc = parse_efi_signature_list("UEFI:MokListRT",
|
||||
mok, moksize, get_handler_for_db);
|
||||
kfree(mok);
|
||||
if (rc)
|
||||
pr_err("Couldn't parse MokListRT signatures: %d\n", rc);
|
||||
return rc;
|
||||
}
|
||||
if (status == EFI_NOT_FOUND)
|
||||
pr_debug("MokListRT variable wasn't found\n");
|
||||
else
|
||||
pr_info("Couldn't get UEFI MokListRT\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* load_uefi_certs() - Load certs from UEFI sources
|
||||
*
|
||||
* Load the certs contained in the UEFI databases into the platform trusted
|
||||
* keyring and the UEFI blacklisted X.509 cert SHA256 hashes into the blacklist
|
||||
* keyring.
|
||||
@@ -73,17 +132,16 @@ static __init void *get_cert_list(efi_char16_t *name, efi_guid_t *guid,
|
||||
static int __init load_uefi_certs(void)
|
||||
{
|
||||
efi_guid_t secure_var = EFI_IMAGE_SECURITY_DATABASE_GUID;
|
||||
efi_guid_t mok_var = EFI_SHIM_LOCK_GUID;
|
||||
void *db = NULL, *dbx = NULL, *mok = NULL;
|
||||
unsigned long dbsize = 0, dbxsize = 0, moksize = 0;
|
||||
void *db = NULL, *dbx = NULL;
|
||||
unsigned long dbsize = 0, dbxsize = 0;
|
||||
efi_status_t status;
|
||||
int rc = 0;
|
||||
|
||||
if (!efi_rt_services_supported(EFI_RT_SUPPORTED_GET_VARIABLE))
|
||||
return false;
|
||||
|
||||
/* Get db, MokListRT, and dbx. They might not exist, so it isn't
|
||||
* an error if we can't get them.
|
||||
/* Get db and dbx. They might not exist, so it isn't an error
|
||||
* if we can't get them.
|
||||
*/
|
||||
if (!uefi_check_ignore_db()) {
|
||||
db = get_cert_list(L"db", &secure_var, &dbsize, &status);
|
||||
@@ -102,20 +160,6 @@ static int __init load_uefi_certs(void)
|
||||
}
|
||||
}
|
||||
|
||||
mok = get_cert_list(L"MokListRT", &mok_var, &moksize, &status);
|
||||
if (!mok) {
|
||||
if (status == EFI_NOT_FOUND)
|
||||
pr_debug("MokListRT variable wasn't found\n");
|
||||
else
|
||||
pr_info("Couldn't get UEFI MokListRT\n");
|
||||
} else {
|
||||
rc = parse_efi_signature_list("UEFI:MokListRT",
|
||||
mok, moksize, get_handler_for_db);
|
||||
if (rc)
|
||||
pr_err("Couldn't parse MokListRT signatures: %d\n", rc);
|
||||
kfree(mok);
|
||||
}
|
||||
|
||||
dbx = get_cert_list(L"dbx", &secure_var, &dbxsize, &status);
|
||||
if (!dbx) {
|
||||
if (status == EFI_NOT_FOUND)
|
||||
@@ -131,6 +175,9 @@ static int __init load_uefi_certs(void)
|
||||
kfree(dbx);
|
||||
}
|
||||
|
||||
/* Load the MokListRT certs */
|
||||
rc = load_moklist_certs();
|
||||
|
||||
return rc;
|
||||
}
|
||||
late_initcall(load_uefi_certs);
|
||||
|
Reference in New Issue
Block a user