提交 876dc36a 编写于 作者: R Roy Franz 提交者: Matt Fleming

efi: Add system table pointer argument to shared functions.

Add system table pointer argument to shared EFI stub related functions
so they no longer use a global system table pointer as they did when part
of eboot.c.  For the ARM EFI stub this allows us to avoid global
variables completely and thereby not have to deal with GOT fixups.
Not having the EFI stub fixup its GOT, which is shared with the
decompressor, simplifies the relocating of the zImage to a
bootable address.
Signed-off-by: NRoy Franz <roy.franz@linaro.org>
Signed-off-by: NMatt Fleming <matt.fleming@intel.com>
上级 7721da4c
...@@ -453,13 +453,13 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table) ...@@ -453,13 +453,13 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table)
status = efi_call_phys3(sys_table->boottime->handle_protocol, status = efi_call_phys3(sys_table->boottime->handle_protocol,
handle, &proto, (void *)&image); handle, &proto, (void *)&image);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to get handle for LOADED_IMAGE_PROTOCOL\n"); efi_printk(sys_table, "Failed to get handle for LOADED_IMAGE_PROTOCOL\n");
return NULL; return NULL;
} }
status = low_alloc(0x4000, 1, (unsigned long *)&boot_params); status = low_alloc(sys_table, 0x4000, 1, (unsigned long *)&boot_params);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc lowmem for boot params\n"); efi_printk(sys_table, "Failed to alloc lowmem for boot params\n");
return NULL; return NULL;
} }
...@@ -503,9 +503,10 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table) ...@@ -503,9 +503,10 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table)
options_size++; /* NUL termination */ options_size++; /* NUL termination */
status = low_alloc(options_size, 1, &cmdline); status = low_alloc(sys_table, options_size, 1,
&cmdline);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for cmdline\n"); efi_printk(sys_table, "Failed to alloc mem for cmdline\n");
goto fail; goto fail;
} }
...@@ -529,16 +530,16 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table) ...@@ -529,16 +530,16 @@ struct boot_params *make_boot_params(void *handle, efi_system_table_t *_table)
memset(sdt, 0, sizeof(*sdt)); memset(sdt, 0, sizeof(*sdt));
status = handle_ramdisks(image, hdr); status = handle_ramdisks(sys_table, image, hdr);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
goto fail2; goto fail2;
return boot_params; return boot_params;
fail2: fail2:
if (options_size) if (options_size)
low_free(options_size, hdr->cmd_line_ptr); low_free(sys_table, options_size, hdr->cmd_line_ptr);
fail: fail:
low_free(0x4000, (unsigned long)boot_params); low_free(sys_table, 0x4000, (unsigned long)boot_params);
return NULL; return NULL;
} }
...@@ -561,7 +562,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params, ...@@ -561,7 +562,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params,
again: again:
size += sizeof(*mem_map) * 2; size += sizeof(*mem_map) * 2;
_size = size; _size = size;
status = low_alloc(size, 1, (unsigned long *)&mem_map); status = low_alloc(sys_table, size, 1, (unsigned long *)&mem_map);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
return status; return status;
...@@ -569,7 +570,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params, ...@@ -569,7 +570,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params,
status = efi_call_phys5(sys_table->boottime->get_memory_map, &size, status = efi_call_phys5(sys_table->boottime->get_memory_map, &size,
mem_map, &key, &desc_size, &desc_version); mem_map, &key, &desc_size, &desc_version);
if (status == EFI_BUFFER_TOO_SMALL) { if (status == EFI_BUFFER_TOO_SMALL) {
low_free(_size, (unsigned long)mem_map); low_free(sys_table, _size, (unsigned long)mem_map);
goto again; goto again;
} }
...@@ -671,7 +672,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params, ...@@ -671,7 +672,7 @@ static efi_status_t exit_boot(struct boot_params *boot_params,
return EFI_SUCCESS; return EFI_SUCCESS;
free_mem_map: free_mem_map:
low_free(_size, (unsigned long)mem_map); low_free(sys_table, _size, (unsigned long)mem_map);
return status; return status;
} }
...@@ -694,10 +695,10 @@ static efi_status_t relocate_kernel(struct setup_header *hdr) ...@@ -694,10 +695,10 @@ static efi_status_t relocate_kernel(struct setup_header *hdr)
EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA, EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA,
nr_pages, &start); nr_pages, &start);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
status = low_alloc(hdr->init_size, hdr->kernel_alignment, status = low_alloc(sys_table, hdr->init_size,
&start); hdr->kernel_alignment, &start);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
efi_printk("Failed to alloc mem for kernel\n"); efi_printk(sys_table, "Failed to alloc mem for kernel\n");
} }
if (status == EFI_SUCCESS) if (status == EFI_SUCCESS)
...@@ -737,14 +738,15 @@ struct boot_params *efi_main(void *handle, efi_system_table_t *_table, ...@@ -737,14 +738,15 @@ struct boot_params *efi_main(void *handle, efi_system_table_t *_table,
EFI_LOADER_DATA, sizeof(*gdt), EFI_LOADER_DATA, sizeof(*gdt),
(void **)&gdt); (void **)&gdt);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for gdt structure\n"); efi_printk(sys_table, "Failed to alloc mem for gdt structure\n");
goto fail; goto fail;
} }
gdt->size = 0x800; gdt->size = 0x800;
status = low_alloc(gdt->size, 8, (unsigned long *)&gdt->address); status = low_alloc(sys_table, gdt->size, 8,
(unsigned long *)&gdt->address);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for gdt\n"); efi_printk(sys_table, "Failed to alloc mem for gdt\n");
goto fail; goto fail;
} }
...@@ -752,7 +754,7 @@ struct boot_params *efi_main(void *handle, efi_system_table_t *_table, ...@@ -752,7 +754,7 @@ struct boot_params *efi_main(void *handle, efi_system_table_t *_table,
EFI_LOADER_DATA, sizeof(*idt), EFI_LOADER_DATA, sizeof(*idt),
(void **)&idt); (void **)&idt);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for idt structure\n"); efi_printk(sys_table, "Failed to alloc mem for idt structure\n");
goto fail; goto fail;
} }
......
...@@ -19,15 +19,16 @@ struct initrd { ...@@ -19,15 +19,16 @@ struct initrd {
static void efi_char16_printk(efi_char16_t *str) static void efi_char16_printk(efi_system_table_t *sys_table_arg,
efi_char16_t *str)
{ {
struct efi_simple_text_output_protocol *out; struct efi_simple_text_output_protocol *out;
out = (struct efi_simple_text_output_protocol *)sys_table->con_out; out = (struct efi_simple_text_output_protocol *)sys_table_arg->con_out;
efi_call_phys2(out->output_string, out, str); efi_call_phys2(out->output_string, out, str);
} }
static void efi_printk(char *str) static void efi_printk(efi_system_table_t *sys_table_arg, char *str)
{ {
char *s8; char *s8;
...@@ -37,15 +38,17 @@ static void efi_printk(char *str) ...@@ -37,15 +38,17 @@ static void efi_printk(char *str)
ch[0] = *s8; ch[0] = *s8;
if (*s8 == '\n') { if (*s8 == '\n') {
efi_char16_t nl[2] = { '\r', 0 }; efi_char16_t nl[2] = { '\r', 0 };
efi_char16_printk(nl); efi_char16_printk(sys_table_arg, nl);
} }
efi_char16_printk(ch); efi_char16_printk(sys_table_arg, ch);
} }
} }
static efi_status_t __get_map(efi_memory_desc_t **map, unsigned long *map_size, static efi_status_t __get_map(efi_system_table_t *sys_table_arg,
efi_memory_desc_t **map,
unsigned long *map_size,
unsigned long *desc_size) unsigned long *desc_size)
{ {
efi_memory_desc_t *m = NULL; efi_memory_desc_t *m = NULL;
...@@ -60,20 +63,20 @@ static efi_status_t __get_map(efi_memory_desc_t **map, unsigned long *map_size, ...@@ -60,20 +63,20 @@ static efi_status_t __get_map(efi_memory_desc_t **map, unsigned long *map_size,
* allocation which may be in a new descriptor region. * allocation which may be in a new descriptor region.
*/ */
*map_size += sizeof(*m); *map_size += sizeof(*m);
status = efi_call_phys3(sys_table->boottime->allocate_pool, status = efi_call_phys3(sys_table_arg->boottime->allocate_pool,
EFI_LOADER_DATA, *map_size, (void **)&m); EFI_LOADER_DATA, *map_size, (void **)&m);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
goto fail; goto fail;
status = efi_call_phys5(sys_table->boottime->get_memory_map, map_size, status = efi_call_phys5(sys_table_arg->boottime->get_memory_map,
m, &key, desc_size, &desc_version); map_size, m, &key, desc_size, &desc_version);
if (status == EFI_BUFFER_TOO_SMALL) { if (status == EFI_BUFFER_TOO_SMALL) {
efi_call_phys1(sys_table->boottime->free_pool, m); efi_call_phys1(sys_table_arg->boottime->free_pool, m);
goto again; goto again;
} }
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
efi_call_phys1(sys_table->boottime->free_pool, m); efi_call_phys1(sys_table_arg->boottime->free_pool, m);
fail: fail:
*map = m; *map = m;
...@@ -83,8 +86,9 @@ static efi_status_t __get_map(efi_memory_desc_t **map, unsigned long *map_size, ...@@ -83,8 +86,9 @@ static efi_status_t __get_map(efi_memory_desc_t **map, unsigned long *map_size,
/* /*
* Allocate at the highest possible address that is not above 'max'. * Allocate at the highest possible address that is not above 'max'.
*/ */
static efi_status_t high_alloc(unsigned long size, unsigned long align, static efi_status_t high_alloc(efi_system_table_t *sys_table_arg,
unsigned long *addr, unsigned long max) unsigned long size, unsigned long align,
unsigned long *addr, unsigned long max)
{ {
unsigned long map_size, desc_size; unsigned long map_size, desc_size;
efi_memory_desc_t *map; efi_memory_desc_t *map;
...@@ -93,7 +97,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align, ...@@ -93,7 +97,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align,
u64 max_addr = 0; u64 max_addr = 0;
int i; int i;
status = __get_map(&map, &map_size, &desc_size); status = __get_map(sys_table_arg, &map, &map_size, &desc_size);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
goto fail; goto fail;
...@@ -139,7 +143,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align, ...@@ -139,7 +143,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align,
if (!max_addr) if (!max_addr)
status = EFI_NOT_FOUND; status = EFI_NOT_FOUND;
else { else {
status = efi_call_phys4(sys_table->boottime->allocate_pages, status = efi_call_phys4(sys_table_arg->boottime->allocate_pages,
EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA, EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA,
nr_pages, &max_addr); nr_pages, &max_addr);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
...@@ -152,7 +156,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align, ...@@ -152,7 +156,7 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align,
} }
free_pool: free_pool:
efi_call_phys1(sys_table->boottime->free_pool, map); efi_call_phys1(sys_table_arg->boottime->free_pool, map);
fail: fail:
return status; return status;
...@@ -161,7 +165,8 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align, ...@@ -161,7 +165,8 @@ static efi_status_t high_alloc(unsigned long size, unsigned long align,
/* /*
* Allocate at the lowest possible address. * Allocate at the lowest possible address.
*/ */
static efi_status_t low_alloc(unsigned long size, unsigned long align, static efi_status_t low_alloc(efi_system_table_t *sys_table_arg,
unsigned long size, unsigned long align,
unsigned long *addr) unsigned long *addr)
{ {
unsigned long map_size, desc_size; unsigned long map_size, desc_size;
...@@ -170,7 +175,7 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align, ...@@ -170,7 +175,7 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align,
unsigned long nr_pages; unsigned long nr_pages;
int i; int i;
status = __get_map(&map, &map_size, &desc_size); status = __get_map(sys_table_arg, &map, &map_size, &desc_size);
if (status != EFI_SUCCESS) if (status != EFI_SUCCESS)
goto fail; goto fail;
...@@ -203,7 +208,7 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align, ...@@ -203,7 +208,7 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align,
if ((start + size) > end) if ((start + size) > end)
continue; continue;
status = efi_call_phys4(sys_table->boottime->allocate_pages, status = efi_call_phys4(sys_table_arg->boottime->allocate_pages,
EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA, EFI_ALLOCATE_ADDRESS, EFI_LOADER_DATA,
nr_pages, &start); nr_pages, &start);
if (status == EFI_SUCCESS) { if (status == EFI_SUCCESS) {
...@@ -216,17 +221,18 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align, ...@@ -216,17 +221,18 @@ static efi_status_t low_alloc(unsigned long size, unsigned long align,
status = EFI_NOT_FOUND; status = EFI_NOT_FOUND;
free_pool: free_pool:
efi_call_phys1(sys_table->boottime->free_pool, map); efi_call_phys1(sys_table_arg->boottime->free_pool, map);
fail: fail:
return status; return status;
} }
static void low_free(unsigned long size, unsigned long addr) static void low_free(efi_system_table_t *sys_table_arg, unsigned long size,
unsigned long addr)
{ {
unsigned long nr_pages; unsigned long nr_pages;
nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE; nr_pages = round_up(size, EFI_PAGE_SIZE) / EFI_PAGE_SIZE;
efi_call_phys2(sys_table->boottime->free_pages, addr, nr_pages); efi_call_phys2(sys_table_arg->boottime->free_pages, addr, nr_pages);
} }
...@@ -236,7 +242,8 @@ static void low_free(unsigned long size, unsigned long addr) ...@@ -236,7 +242,8 @@ static void low_free(unsigned long size, unsigned long addr)
* We only support loading an initrd from the same filesystem as the * We only support loading an initrd from the same filesystem as the
* kernel image. * kernel image.
*/ */
static efi_status_t handle_ramdisks(efi_loaded_image_t *image, static efi_status_t handle_ramdisks(efi_system_table_t *sys_table_arg,
efi_loaded_image_t *image,
struct setup_header *hdr) struct setup_header *hdr)
{ {
struct initrd *initrds; struct initrd *initrds;
...@@ -278,12 +285,12 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -278,12 +285,12 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
if (!nr_initrds) if (!nr_initrds)
return EFI_SUCCESS; return EFI_SUCCESS;
status = efi_call_phys3(sys_table->boottime->allocate_pool, status = efi_call_phys3(sys_table_arg->boottime->allocate_pool,
EFI_LOADER_DATA, EFI_LOADER_DATA,
nr_initrds * sizeof(*initrds), nr_initrds * sizeof(*initrds),
&initrds); &initrds);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for initrds\n"); efi_printk(sys_table_arg, "Failed to alloc mem for initrds\n");
goto fail; goto fail;
} }
...@@ -329,18 +336,18 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -329,18 +336,18 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
if (!i) { if (!i) {
efi_boot_services_t *boottime; efi_boot_services_t *boottime;
boottime = sys_table->boottime; boottime = sys_table_arg->boottime;
status = efi_call_phys3(boottime->handle_protocol, status = efi_call_phys3(boottime->handle_protocol,
image->device_handle, &fs_proto, &io); image->device_handle, &fs_proto, &io);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to handle fs_proto\n"); efi_printk(sys_table_arg, "Failed to handle fs_proto\n");
goto free_initrds; goto free_initrds;
} }
status = efi_call_phys2(io->open_volume, io, &fh); status = efi_call_phys2(io->open_volume, io, &fh);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to open volume\n"); efi_printk(sys_table_arg, "Failed to open volume\n");
goto free_initrds; goto free_initrds;
} }
} }
...@@ -348,9 +355,9 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -348,9 +355,9 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
status = efi_call_phys5(fh->open, fh, &h, filename_16, status = efi_call_phys5(fh->open, fh, &h, filename_16,
EFI_FILE_MODE_READ, (u64)0); EFI_FILE_MODE_READ, (u64)0);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to open initrd file: "); efi_printk(sys_table_arg, "Failed to open initrd file: ");
efi_char16_printk(filename_16); efi_char16_printk(sys_table_arg, filename_16);
efi_printk("\n"); efi_printk(sys_table_arg, "\n");
goto close_handles; goto close_handles;
} }
...@@ -360,30 +367,31 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -360,30 +367,31 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
status = efi_call_phys4(h->get_info, h, &info_guid, status = efi_call_phys4(h->get_info, h, &info_guid,
&info_sz, NULL); &info_sz, NULL);
if (status != EFI_BUFFER_TOO_SMALL) { if (status != EFI_BUFFER_TOO_SMALL) {
efi_printk("Failed to get initrd info size\n"); efi_printk(sys_table_arg, "Failed to get initrd info size\n");
goto close_handles; goto close_handles;
} }
grow: grow:
status = efi_call_phys3(sys_table->boottime->allocate_pool, status = efi_call_phys3(sys_table_arg->boottime->allocate_pool,
EFI_LOADER_DATA, info_sz, &info); EFI_LOADER_DATA, info_sz, &info);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc mem for initrd info\n"); efi_printk(sys_table_arg, "Failed to alloc mem for initrd info\n");
goto close_handles; goto close_handles;
} }
status = efi_call_phys4(h->get_info, h, &info_guid, status = efi_call_phys4(h->get_info, h, &info_guid,
&info_sz, info); &info_sz, info);
if (status == EFI_BUFFER_TOO_SMALL) { if (status == EFI_BUFFER_TOO_SMALL) {
efi_call_phys1(sys_table->boottime->free_pool, info); efi_call_phys1(sys_table_arg->boottime->free_pool,
info);
goto grow; goto grow;
} }
file_sz = info->file_size; file_sz = info->file_size;
efi_call_phys1(sys_table->boottime->free_pool, info); efi_call_phys1(sys_table_arg->boottime->free_pool, info);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to get initrd info\n"); efi_printk(sys_table_arg, "Failed to get initrd info\n");
goto close_handles; goto close_handles;
} }
...@@ -399,16 +407,16 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -399,16 +407,16 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
* addresses in memory, so allocate enough memory for * addresses in memory, so allocate enough memory for
* all the initrd's. * all the initrd's.
*/ */
status = high_alloc(initrd_total, 0x1000, status = high_alloc(sys_table_arg, initrd_total, 0x1000,
&initrd_addr, hdr->initrd_addr_max); &initrd_addr, hdr->initrd_addr_max);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to alloc highmem for initrds\n"); efi_printk(sys_table_arg, "Failed to alloc highmem for initrds\n");
goto close_handles; goto close_handles;
} }
/* We've run out of free low memory. */ /* We've run out of free low memory. */
if (initrd_addr > hdr->initrd_addr_max) { if (initrd_addr > hdr->initrd_addr_max) {
efi_printk("We've run out of free low memory\n"); efi_printk(sys_table_arg, "We've run out of free low memory\n");
status = EFI_INVALID_PARAMETER; status = EFI_INVALID_PARAMETER;
goto free_initrd_total; goto free_initrd_total;
} }
...@@ -428,7 +436,7 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -428,7 +436,7 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
initrds[j].handle, initrds[j].handle,
&chunksize, addr); &chunksize, addr);
if (status != EFI_SUCCESS) { if (status != EFI_SUCCESS) {
efi_printk("Failed to read initrd\n"); efi_printk(sys_table_arg, "Failed to read initrd\n");
goto free_initrd_total; goto free_initrd_total;
} }
addr += chunksize; addr += chunksize;
...@@ -440,7 +448,7 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -440,7 +448,7 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
} }
efi_call_phys1(sys_table->boottime->free_pool, initrds); efi_call_phys1(sys_table_arg->boottime->free_pool, initrds);
hdr->ramdisk_image = initrd_addr; hdr->ramdisk_image = initrd_addr;
hdr->ramdisk_size = initrd_total; hdr->ramdisk_size = initrd_total;
...@@ -448,13 +456,13 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image, ...@@ -448,13 +456,13 @@ static efi_status_t handle_ramdisks(efi_loaded_image_t *image,
return status; return status;
free_initrd_total: free_initrd_total:
low_free(initrd_total, initrd_addr); low_free(sys_table_arg, initrd_total, initrd_addr);
close_handles: close_handles:
for (k = j; k < i; k++) for (k = j; k < i; k++)
efi_call_phys1(fh->close, initrds[k].handle); efi_call_phys1(fh->close, initrds[k].handle);
free_initrds: free_initrds:
efi_call_phys1(sys_table->boottime->free_pool, initrds); efi_call_phys1(sys_table_arg->boottime->free_pool, initrds);
fail: fail:
hdr->ramdisk_image = 0; hdr->ramdisk_image = 0;
hdr->ramdisk_size = 0; hdr->ramdisk_size = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册