summaryrefslogtreecommitdiff
path: root/cmd/bootefi.c
diff options
context:
space:
mode:
authorHeinrich Schuchardt <xypron.glpk@gmx.de>2018-11-18 17:58:53 +0100
committerAlexander Graf <agraf@suse.de>2018-12-02 21:59:37 +0100
commit0c9ac06a2894ea08488b5f8f5d1e5cbd57808900 (patch)
tree466cec720ffb90f4bf1cae936db48d7ede6035b9 /cmd/bootefi.c
parent16b615d9abd006fb69930860f23e7785a48d040a (diff)
efi_loader: create fdt reservation before copy
When copying the device we must ensure that the copy does not fall into a memory area reserved by the same. So let's change the sequence: first create memory reservations and then copy the device tree. Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de> Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'cmd/bootefi.c')
-rw-r--r--cmd/bootefi.c12
1 files changed, 3 insertions, 9 deletions
diff --git a/cmd/bootefi.c b/cmd/bootefi.c
index ad97a9c019..38679ffc56 100644
--- a/cmd/bootefi.c
+++ b/cmd/bootefi.c
@@ -280,13 +280,6 @@ static void efi_carve_out_dt_rsv(void *fdt)
/* Convert from sandbox address space. */
addr = (uintptr_t)map_sysmem(addr, 0);
- /*
- * Do not carve out the device tree. It is already marked as
- * EFI_RUNTIME_SERVICES_DATA
- */
- if (addr == (uintptr_t)fdt)
- continue;
-
pages = efi_size_in_pages(size + (addr & EFI_PAGE_MASK));
addr &= ~EFI_PAGE_MASK;
if (!efi_add_memory_map(addr, pages, EFI_RESERVED_MEMORY_TYPE,
@@ -307,6 +300,9 @@ static efi_status_t efi_install_fdt(ulong fdt_addr)
return EFI_INVALID_PARAMETER;
}
+ /* Create memory reservation as indicated by the device tree */
+ efi_carve_out_dt_rsv(fdt);
+
/* Prepare fdt for payload */
ret = copy_fdt(&fdt);
if (ret)
@@ -317,8 +313,6 @@ static efi_status_t efi_install_fdt(ulong fdt_addr)
return EFI_LOAD_ERROR;
}
- efi_carve_out_dt_rsv(fdt);
-
/* Link to it in the efi tables */
ret = efi_install_configuration_table(&efi_guid_fdt, fdt);
if (ret != EFI_SUCCESS)