X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=arch%2Farm%2Flib%2Fbootm-fdt.c;h=eaa817b9ac8ef08877cc1652a5fc1ee1e4aefecf;hb=b07d044d5bfa8c440b172eb3f8a9d537f82e21b6;hp=8394e15b7e3822d3d3132deb5b13df0a61c407bd;hpb=e29607ed972056723e4bf0ac90767421cf0f0b78;p=u-boot diff --git a/arch/arm/lib/bootm-fdt.c b/arch/arm/lib/bootm-fdt.c index 8394e15b7e..eaa817b9ac 100644 --- a/arch/arm/lib/bootm-fdt.c +++ b/arch/arm/lib/bootm-fdt.c @@ -17,11 +17,18 @@ #include #include +#ifdef CONFIG_ARMV7_NONSEC +#include +#endif +#include +#include DECLARE_GLOBAL_DATA_PTR; int arch_fixup_fdt(void *blob) { + int ret = 0; +#if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_OF_LIBFDT) bd_t *bd = gd->bd; int bank; u64 start[CONFIG_NR_DRAM_BANKS]; @@ -30,7 +37,32 @@ int arch_fixup_fdt(void *blob) for (bank = 0; bank < CONFIG_NR_DRAM_BANKS; bank++) { start[bank] = bd->bi_dram[bank].start; size[bank] = bd->bi_dram[bank].size; +#ifdef CONFIG_ARMV7_NONSEC + ret = armv7_apply_memory_carveout(&start[bank], &size[bank]); + if (ret) + return ret; +#endif } - return fdt_fixup_memory_banks(blob, start, size, CONFIG_NR_DRAM_BANKS); +#ifdef CONFIG_OF_LIBFDT + ret = fdt_fixup_memory_banks(blob, start, size, CONFIG_NR_DRAM_BANKS); + if (ret) + return ret; +#endif + +#ifdef CONFIG_ARMV8_SPIN_TABLE + ret = spin_table_update_dt(blob); + if (ret) + return ret; +#endif + +#if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_ARMV8_PSCI) || \ + defined(CONFIG_SEC_FIRMWARE_ARMV8_PSCI) + ret = psci_update_dt(blob); + if (ret) + return ret; +#endif +#endif + + return 0; }