Commit 987053a3 authored by Arvind Sankar's avatar Arvind Sankar Committed by Ard Biesheuvel

efi/x86: Move command-line initrd loading to efi_main

Consolidate the initrd loading in efi_main.

The command line options now need to be parsed only once.
Signed-off-by: default avatarArvind Sankar <nivedita@alum.mit.edu>
Link: https://lore.kernel.org/r/20200430182843.2510180-9-nivedita@alum.mit.eduSigned-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
parent 3839ab85
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
const efi_system_table_t *efi_system_table; const efi_system_table_t *efi_system_table;
extern u32 image_offset; extern u32 image_offset;
static efi_loaded_image_t *image = NULL;
static efi_status_t static efi_status_t
preserve_pci_rom_image(efi_pci_io_protocol_t *pci, struct pci_setup_rom **__rom) preserve_pci_rom_image(efi_pci_io_protocol_t *pci, struct pci_setup_rom **__rom)
...@@ -355,7 +356,6 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle, ...@@ -355,7 +356,6 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle,
{ {
struct boot_params *boot_params; struct boot_params *boot_params;
struct setup_header *hdr; struct setup_header *hdr;
efi_loaded_image_t *image;
void *image_base; void *image_base;
efi_guid_t proto = LOADED_IMAGE_PROTOCOL_GUID; efi_guid_t proto = LOADED_IMAGE_PROTOCOL_GUID;
int options_size = 0; int options_size = 0;
...@@ -414,30 +414,9 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle, ...@@ -414,30 +414,9 @@ efi_status_t __efiapi efi_pe_entry(efi_handle_t handle,
hdr->ramdisk_image = 0; hdr->ramdisk_image = 0;
hdr->ramdisk_size = 0; hdr->ramdisk_size = 0;
if (efi_is_native()) {
status = efi_parse_options(cmdline_ptr);
if (status != EFI_SUCCESS)
goto fail2;
if (!efi_noinitrd) {
status = efi_load_initrd(image, &ramdisk_addr,
&ramdisk_size,
hdr->initrd_addr_max,
ULONG_MAX);
if (status != EFI_SUCCESS)
goto fail2;
efi_set_u64_split(ramdisk_addr, &hdr->ramdisk_image,
&boot_params->ext_ramdisk_image);
efi_set_u64_split(ramdisk_size, &hdr->ramdisk_size,
&boot_params->ext_ramdisk_size);
}
}
efi_stub_entry(handle, sys_table_arg, boot_params); efi_stub_entry(handle, sys_table_arg, boot_params);
/* not reached */ /* not reached */
fail2:
efi_free(options_size, (unsigned long)cmdline_ptr);
fail: fail:
efi_free(sizeof(struct boot_params), (unsigned long)boot_params); efi_free(sizeof(struct boot_params), (unsigned long)boot_params);
...@@ -760,35 +739,42 @@ unsigned long efi_main(efi_handle_t handle, ...@@ -760,35 +739,42 @@ unsigned long efi_main(efi_handle_t handle,
image_offset = 0; image_offset = 0;
} }
/*
* efi_pe_entry() may have been called before efi_main(), in which
* case this is the second time we parse the cmdline. This is ok,
* parsing the cmdline multiple times does not have side-effects.
*/
cmdline_paddr = ((u64)hdr->cmd_line_ptr | cmdline_paddr = ((u64)hdr->cmd_line_ptr |
((u64)boot_params->ext_cmd_line_ptr << 32)); ((u64)boot_params->ext_cmd_line_ptr << 32));
efi_parse_options((char *)cmdline_paddr); efi_parse_options((char *)cmdline_paddr);
/* /*
* At this point, an initrd may already have been loaded, either by * At this point, an initrd may already have been loaded by the
* the bootloader and passed via bootparams, or loaded from a initrd= * bootloader and passed via bootparams. We permit an initrd loaded
* command line option by efi_pe_entry() above. In either case, we * from the LINUX_EFI_INITRD_MEDIA_GUID device path to supersede it.
* permit an initrd loaded from the LINUX_EFI_INITRD_MEDIA_GUID device *
* path to supersede it. * If the device path is not present, any command-line initrd=
* arguments will be processed only if image is not NULL, which will be
* the case only if we were loaded via the PE entry point.
*/ */
if (!efi_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);
if (status == EFI_SUCCESS) { if (status == EFI_NOT_FOUND) {
if (efi_is_native() && image != NULL) {
status = efi_load_initrd(image, &addr, &size,
hdr->initrd_addr_max,
ULONG_MAX);
} else {
addr = size = 0;
status = EFI_SUCCESS;
}
}
if (status != EFI_SUCCESS) {
efi_err("Failed to load initrd!\n");
goto fail;
}
efi_set_u64_split(addr, &hdr->ramdisk_image, efi_set_u64_split(addr, &hdr->ramdisk_image,
&boot_params->ext_ramdisk_image); &boot_params->ext_ramdisk_image);
efi_set_u64_split(size, &hdr->ramdisk_size, efi_set_u64_split(size, &hdr->ramdisk_size,
&boot_params->ext_ramdisk_size); &boot_params->ext_ramdisk_size);
} else if (status != EFI_NOT_FOUND) {
efi_err("efi_load_initrd_dev_path() failed!\n");
goto fail;
}
} }
/* /*
......
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