summaryrefslogtreecommitdiffstats
path: root/drivers/firmware/efi/fdtparams.c
diff options
context:
space:
mode:
authorArd Biesheuvel <ardb@kernel.org>2020-02-18 10:19:34 +0100
committerArd Biesheuvel <ardb@kernel.org>2020-02-23 21:59:42 +0100
commit3b2e4b4c634cc7dd4730ce3e1c75b8206dcc4b04 (patch)
tree30fef2c537a355acde28dbd18eab378909cf6ad9 /drivers/firmware/efi/fdtparams.c
parentac5abc700a43b3d448c86932196db22af470eca1 (diff)
downloadlinux-3b2e4b4c634cc7dd4730ce3e1c75b8206dcc4b04.tar.gz
linux-3b2e4b4c634cc7dd4730ce3e1c75b8206dcc4b04.tar.bz2
linux-3b2e4b4c634cc7dd4730ce3e1c75b8206dcc4b04.zip
efi/arm: Move FDT specific definitions into fdtparams.c
Push the FDT params specific types and definition into fdtparams.c, and instead, pass a reference to the memory map data structure and populate it directly, and return the system table address as the return value. Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Diffstat (limited to 'drivers/firmware/efi/fdtparams.c')
-rw-r--r--drivers/firmware/efi/fdtparams.c30
1 files changed, 23 insertions, 7 deletions
diff --git a/drivers/firmware/efi/fdtparams.c b/drivers/firmware/efi/fdtparams.c
index 3de343faffc6..7a384b307c56 100644
--- a/drivers/firmware/efi/fdtparams.c
+++ b/drivers/firmware/efi/fdtparams.c
@@ -18,6 +18,14 @@
sizeof_field(struct efi_fdt_params, field) \
}
+struct efi_fdt_params {
+ u64 system_table;
+ u64 mmap;
+ u32 mmap_size;
+ u32 desc_size;
+ u32 desc_ver;
+};
+
struct params {
const char name[32];
const char propname[32];
@@ -121,22 +129,30 @@ static int __init fdt_find_uefi_params(unsigned long node, const char *uname,
return 0;
}
-int __init efi_get_fdt_params(struct efi_fdt_params *params)
+u64 __init efi_get_fdt_params(struct efi_memory_map_data *memmap)
{
+ struct efi_fdt_params params;
struct param_info info;
int ret;
pr_info("Getting EFI parameters from FDT:\n");
info.found = 0;
- info.params = params;
+ info.params = &params;
ret = of_scan_flat_dt(fdt_find_uefi_params, &info);
- if (!info.found)
+ if (!info.found) {
pr_info("UEFI not found.\n");
- else if (!ret)
- pr_err("Can't find '%s' in device tree!\n",
- info.missing);
+ return 0;
+ } else if (!ret) {
+ pr_err("Can't find '%s' in device tree!\n", info.missing);
+ return 0;
+ }
+
+ memmap->desc_version = params.desc_ver;
+ memmap->desc_size = params.desc_size;
+ memmap->size = params.mmap_size;
+ memmap->phys_map = params.mmap;
- return ret;
+ return params.system_table;
}