Commit 980771f6 authored by Ard Biesheuvel's avatar Ard Biesheuvel

efi/libstub: Drop __pure getters for EFI stub options

The practice of using __pure getter functions to access global
variables in the EFI stub dates back to the time when we had to
carefully prevent GOT entries from being emitted, because we
could not rely on the toolchain to do this for us.

Today, we use the hidden visibility pragma for all EFI stub source
files, which now all live in the same subdirectory, and we apply a
sanity check on the objects, so we can get rid of these getter
functions and simply refer to global data objects directly.

So switch over the remaining boolean variables carrying options set
on the kernel command line.
Signed-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
parent ccc27ae7
...@@ -55,7 +55,7 @@ efi_status_t handle_kernel_image(unsigned long *image_addr, ...@@ -55,7 +55,7 @@ efi_status_t handle_kernel_image(unsigned long *image_addr,
u32 phys_seed = 0; u32 phys_seed = 0;
if (IS_ENABLED(CONFIG_RANDOMIZE_BASE)) { if (IS_ENABLED(CONFIG_RANDOMIZE_BASE)) {
if (!nokaslr()) { if (!efi_nokaslr) {
status = efi_get_random_bytes(sizeof(phys_seed), status = efi_get_random_bytes(sizeof(phys_seed),
(u8 *)&phys_seed); (u8 *)&phys_seed);
if (status == EFI_NOT_FOUND) { if (status == EFI_NOT_FOUND) {
......
...@@ -12,34 +12,15 @@ ...@@ -12,34 +12,15 @@
#include "efistub.h" #include "efistub.h"
static bool efi_nochunk; bool efi_nochunk;
static bool efi_nokaslr; bool efi_nokaslr;
static bool efi_noinitrd; bool efi_noinitrd;
static bool efi_quiet; bool efi_quiet;
static bool efi_novamap; bool efi_novamap;
static bool efi_nosoftreserve; static bool efi_nosoftreserve;
static bool efi_disable_pci_dma = IS_ENABLED(CONFIG_EFI_DISABLE_PCI_DMA); static bool efi_disable_pci_dma = IS_ENABLED(CONFIG_EFI_DISABLE_PCI_DMA);
bool __pure nochunk(void)
{
return efi_nochunk;
}
bool __pure nokaslr(void)
{
return efi_nokaslr;
}
bool __pure noinitrd(void)
{
return efi_noinitrd;
}
bool __pure is_quiet(void)
{
return efi_quiet;
}
bool __pure novamap(void)
{
return efi_novamap;
}
bool __pure __efi_soft_reserve_enabled(void) bool __pure __efi_soft_reserve_enabled(void)
{ {
return !efi_nosoftreserve; return !efi_nosoftreserve;
......
...@@ -263,7 +263,7 @@ efi_status_t efi_entry(efi_handle_t handle, efi_system_table_t *sys_table_arg) ...@@ -263,7 +263,7 @@ efi_status_t efi_entry(efi_handle_t handle, efi_system_table_t *sys_table_arg)
if (!fdt_addr) if (!fdt_addr)
pr_efi("Generating empty DTB\n"); pr_efi("Generating empty DTB\n");
if (!noinitrd()) { if (!efi_noinitrd) {
max_addr = efi_get_max_initrd_addr(dram_base, image_addr); max_addr = efi_get_max_initrd_addr(dram_base, image_addr);
status = efi_load_initrd_dev_path(&initrd_addr, &initrd_size, status = efi_load_initrd_dev_path(&initrd_addr, &initrd_size,
max_addr); max_addr);
...@@ -294,7 +294,7 @@ efi_status_t efi_entry(efi_handle_t handle, efi_system_table_t *sys_table_arg) ...@@ -294,7 +294,7 @@ efi_status_t efi_entry(efi_handle_t handle, efi_system_table_t *sys_table_arg)
EFI_PROPERTIES_RUNTIME_MEMORY_PROTECTION_NON_EXECUTABLE_PE_DATA); EFI_PROPERTIES_RUNTIME_MEMORY_PROTECTION_NON_EXECUTABLE_PE_DATA);
/* hibernation expects the runtime regions to stay in the same place */ /* hibernation expects the runtime regions to stay in the same place */
if (!IS_ENABLED(CONFIG_HIBERNATION) && !nokaslr() && !flat_va_mapping) { if (!IS_ENABLED(CONFIG_HIBERNATION) && !efi_nokaslr && !flat_va_mapping) {
/* /*
* Randomize the base of the UEFI runtime services region. * Randomize the base of the UEFI runtime services region.
* Preserve the 2 MB alignment of the region by taking a * Preserve the 2 MB alignment of the region by taking a
...@@ -367,7 +367,7 @@ void efi_get_virtmap(efi_memory_desc_t *memory_map, unsigned long map_size, ...@@ -367,7 +367,7 @@ void efi_get_virtmap(efi_memory_desc_t *memory_map, unsigned long map_size,
size = in->num_pages * EFI_PAGE_SIZE; size = in->num_pages * EFI_PAGE_SIZE;
in->virt_addr = in->phys_addr; in->virt_addr = in->phys_addr;
if (novamap()) { if (efi_novamap) {
continue; continue;
} }
......
...@@ -25,11 +25,11 @@ ...@@ -25,11 +25,11 @@
#define EFI_ALLOC_ALIGN EFI_PAGE_SIZE #define EFI_ALLOC_ALIGN EFI_PAGE_SIZE
#endif #endif
extern bool __pure nochunk(void); extern bool efi_nochunk;
extern bool __pure nokaslr(void); extern bool efi_nokaslr;
extern bool __pure noinitrd(void); extern bool efi_noinitrd;
extern bool __pure is_quiet(void); extern bool efi_quiet;
extern bool __pure novamap(void); extern bool efi_novamap;
extern const efi_system_table_t *efi_system_table; extern const efi_system_table_t *efi_system_table;
...@@ -50,7 +50,7 @@ extern const efi_system_table_t *efi_system_table; ...@@ -50,7 +50,7 @@ extern const efi_system_table_t *efi_system_table;
#endif #endif
#define pr_efi(msg) do { \ #define pr_efi(msg) do { \
if (!is_quiet()) efi_printk("EFI stub: "msg); \ if (!efi_quiet) efi_printk("EFI stub: "msg); \
} while (0) } while (0)
#define pr_efi_err(msg) efi_printk("EFI stub: ERROR: "msg) #define pr_efi_err(msg) efi_printk("EFI stub: ERROR: "msg)
......
...@@ -310,7 +310,7 @@ efi_status_t allocate_new_fdt_and_exit_boot(void *handle, ...@@ -310,7 +310,7 @@ efi_status_t allocate_new_fdt_and_exit_boot(void *handle,
if (status == EFI_SUCCESS) { if (status == EFI_SUCCESS) {
efi_set_virtual_address_map_t *svam; efi_set_virtual_address_map_t *svam;
if (novamap()) if (efi_novamap)
return EFI_SUCCESS; return EFI_SUCCESS;
/* Install the new virtual address map */ /* Install the new virtual address map */
......
...@@ -142,7 +142,7 @@ efi_status_t handle_cmdline_files(efi_loaded_image_t *image, ...@@ -142,7 +142,7 @@ efi_status_t handle_cmdline_files(efi_loaded_image_t *image,
if (!load_addr || !load_size) if (!load_addr || !load_size)
return EFI_INVALID_PARAMETER; return EFI_INVALID_PARAMETER;
if (IS_ENABLED(CONFIG_X86) && !nochunk()) if (IS_ENABLED(CONFIG_X86) && !efi_nochunk)
efi_chunk_size = EFI_READ_CHUNK_SIZE; efi_chunk_size = EFI_READ_CHUNK_SIZE;
alloc_addr = alloc_size = 0; alloc_addr = alloc_size = 0;
......
...@@ -427,7 +427,7 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle, ...@@ -427,7 +427,7 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle,
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
goto fail2; goto fail2;
if (!noinitrd()) { if (!efi_noinitrd) {
status = efi_load_initrd(image, &ramdisk_addr, status = efi_load_initrd(image, &ramdisk_addr,
&ramdisk_size, &ramdisk_size,
hdr->initrd_addr_max, hdr->initrd_addr_max,
...@@ -787,7 +787,7 @@ unsigned long efi_main(efi_handle_t handle, ...@@ -787,7 +787,7 @@ unsigned long efi_main(efi_handle_t handle,
* permit an initrd loaded from the LINUX_EFI_INITRD_MEDIA_GUID device * permit an initrd loaded from the LINUX_EFI_INITRD_MEDIA_GUID device
* path to supersede it. * path to supersede it.
*/ */
if (!noinitrd()) { if (!efi_noinitrd) {
unsigned long addr, size; unsigned long addr, size;
status = efi_load_initrd_dev_path(&addr, &size, ULONG_MAX); status = efi_load_initrd_dev_path(&addr, &size, ULONG_MAX);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment