mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
baaabecfc8
On non-EFI systems, it wasn't possible to test the platform firmware
loader because it will have never set "checked_fw" during __init.
Instead, allow the test code to override this check. Additionally split
the declarations into a private symbol namespace so there is greater
enforcement of the symbol visibility.
Fixes: 548193cba2
("test_firmware: add support for firmware_request_platform")
Cc: stable@vger.kernel.org
Signed-off-by: Kees Cook <keescook@chromium.org>
Acked-by: Ard Biesheuvel <ardb@kernel.org>
Link: https://lore.kernel.org/r/20200909225354.3118328-1-keescook@chromium.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
42 lines
1.0 KiB
C
42 lines
1.0 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _LINUX_EFI_EMBEDDED_FW_H
|
|
#define _LINUX_EFI_EMBEDDED_FW_H
|
|
|
|
#include <linux/list.h>
|
|
#include <linux/mod_devicetable.h>
|
|
|
|
#define EFI_EMBEDDED_FW_PREFIX_LEN 8
|
|
|
|
/*
|
|
* This struct is private to the efi-embedded fw implementation.
|
|
* They are in this header for use by lib/test_firmware.c only!
|
|
*/
|
|
struct efi_embedded_fw {
|
|
struct list_head list;
|
|
const char *name;
|
|
const u8 *data;
|
|
size_t length;
|
|
};
|
|
|
|
/**
|
|
* struct efi_embedded_fw_desc - This struct is used by the EFI embedded-fw
|
|
* code to search for embedded firmwares.
|
|
*
|
|
* @name: Name to register the firmware with if found
|
|
* @prefix: First 8 bytes of the firmware
|
|
* @length: Length of the firmware in bytes including prefix
|
|
* @sha256: SHA256 of the firmware
|
|
*/
|
|
struct efi_embedded_fw_desc {
|
|
const char *name;
|
|
u8 prefix[EFI_EMBEDDED_FW_PREFIX_LEN];
|
|
u32 length;
|
|
u8 sha256[32];
|
|
};
|
|
|
|
extern const struct dmi_system_id touchscreen_dmi_table[];
|
|
|
|
int efi_get_embedded_fw(const char *name, const u8 **dat, size_t *sz);
|
|
|
|
#endif
|