xref: /openbmc/u-boot/arch/arm/lib/bootm-fdt.c (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
1*83d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
26caa1956SSimon Glass /*
36caa1956SSimon Glass  * Copyright (c) 2013, Google Inc.
46caa1956SSimon Glass  *
56caa1956SSimon Glass  * Copyright (C) 2011
66caa1956SSimon Glass  * Corscience GmbH & Co. KG - Simon Schwarz <schwarz@corscience.de>
76caa1956SSimon Glass  *  - Added prep subcommand support
86caa1956SSimon Glass  *  - Reorganized source - modeled after powerpc version
96caa1956SSimon Glass  *
106caa1956SSimon Glass  * (C) Copyright 2002
116caa1956SSimon Glass  * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
126caa1956SSimon Glass  * Marius Groeger <mgroeger@sysgo.de>
136caa1956SSimon Glass  *
146caa1956SSimon Glass  * Copyright (C) 2001  Erik Mouw (J.A.K.Mouw@its.tudelft.nl)
156caa1956SSimon Glass  */
166caa1956SSimon Glass 
176caa1956SSimon Glass #include <common.h>
186caa1956SSimon Glass #include <fdt_support.h>
194588d61aSTom Rini #ifdef CONFIG_ARMV7_NONSEC
20d6b72da0SJan Kiszka #include <asm/armv7.h>
214588d61aSTom Rini #endif
22dd09f7e7STom Rini #include <asm/psci.h>
236b6024eaSMasahiro Yamada #include <asm/spin_table.h>
246caa1956SSimon Glass 
256caa1956SSimon Glass DECLARE_GLOBAL_DATA_PTR;
266caa1956SSimon Glass 
276bedf447SPrabhakar Kushwaha #ifdef CONFIG_FMAN_ENET
fdt_update_ethernet_dt(void * blob)286bedf447SPrabhakar Kushwaha __weak int fdt_update_ethernet_dt(void *blob)
296bedf447SPrabhakar Kushwaha {
306bedf447SPrabhakar Kushwaha 	return 0;
316bedf447SPrabhakar Kushwaha }
326bedf447SPrabhakar Kushwaha #endif
336bedf447SPrabhakar Kushwaha 
arch_fixup_fdt(void * blob)34e29607edSMa Haijun int arch_fixup_fdt(void *blob)
356caa1956SSimon Glass {
36020da843SHeiko Schocher 	__maybe_unused int ret = 0;
37984a3c87SB, Ravi #if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_OF_LIBFDT)
386caa1956SSimon Glass 	bd_t *bd = gd->bd;
39984a3c87SB, Ravi 	int bank;
406caa1956SSimon Glass 	u64 start[CONFIG_NR_DRAM_BANKS];
416caa1956SSimon Glass 	u64 size[CONFIG_NR_DRAM_BANKS];
426caa1956SSimon Glass 
436caa1956SSimon Glass 	for (bank = 0; bank < CONFIG_NR_DRAM_BANKS; bank++) {
446caa1956SSimon Glass 		start[bank] = bd->bi_dram[bank].start;
456caa1956SSimon Glass 		size[bank] = bd->bi_dram[bank].size;
46d6b72da0SJan Kiszka #ifdef CONFIG_ARMV7_NONSEC
47d6b72da0SJan Kiszka 		ret = armv7_apply_memory_carveout(&start[bank], &size[bank]);
48d6b72da0SJan Kiszka 		if (ret)
49d6b72da0SJan Kiszka 			return ret;
50d6b72da0SJan Kiszka #endif
516caa1956SSimon Glass 	}
526caa1956SSimon Glass 
53984a3c87SB, Ravi #ifdef CONFIG_OF_LIBFDT
54e771a3d5SMarc Zyngier 	ret = fdt_fixup_memory_banks(blob, start, size, CONFIG_NR_DRAM_BANKS);
55e771a3d5SMarc Zyngier 	if (ret)
56e771a3d5SMarc Zyngier 		return ret;
57984a3c87SB, Ravi #endif
58e771a3d5SMarc Zyngier 
596b6024eaSMasahiro Yamada #ifdef CONFIG_ARMV8_SPIN_TABLE
606b6024eaSMasahiro Yamada 	ret = spin_table_update_dt(blob);
616b6024eaSMasahiro Yamada 	if (ret)
626b6024eaSMasahiro Yamada 		return ret;
636b6024eaSMasahiro Yamada #endif
646b6024eaSMasahiro Yamada 
659a561753Smacro.wave.z@gmail.com #if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_ARMV8_PSCI) || \
66daa92644SHou Zhiqiang 	defined(CONFIG_SEC_FIRMWARE_ARMV8_PSCI)
67dd09f7e7STom Rini 	ret = psci_update_dt(blob);
686441e3deSMasahiro Yamada 	if (ret)
69e771a3d5SMarc Zyngier 		return ret;
706441e3deSMasahiro Yamada #endif
71984a3c87SB, Ravi #endif
726441e3deSMasahiro Yamada 
736bedf447SPrabhakar Kushwaha #ifdef CONFIG_FMAN_ENET
746bedf447SPrabhakar Kushwaha 	ret = fdt_update_ethernet_dt(blob);
756bedf447SPrabhakar Kushwaha 	if (ret)
766bedf447SPrabhakar Kushwaha 		return ret;
776bedf447SPrabhakar Kushwaha #endif
786441e3deSMasahiro Yamada 	return 0;
796caa1956SSimon Glass }
80