xref: /rk3399_rockchip-uboot/arch/arm/lib/bootm-fdt.c (revision 6cb8d50f5d5e662c6d224d0a5a77e3cecf41361d)
16caa1956SSimon Glass /*
26caa1956SSimon Glass  * Copyright (c) 2013, Google Inc.
36caa1956SSimon Glass  *
46caa1956SSimon Glass  * Copyright (C) 2011
56caa1956SSimon Glass  * Corscience GmbH & Co. KG - Simon Schwarz <schwarz@corscience.de>
66caa1956SSimon Glass  *  - Added prep subcommand support
76caa1956SSimon Glass  *  - Reorganized source - modeled after powerpc version
86caa1956SSimon Glass  *
96caa1956SSimon Glass  * (C) Copyright 2002
106caa1956SSimon Glass  * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
116caa1956SSimon Glass  * Marius Groeger <mgroeger@sysgo.de>
126caa1956SSimon Glass  *
136caa1956SSimon Glass  * Copyright (C) 2001  Erik Mouw (J.A.K.Mouw@its.tudelft.nl)
146caa1956SSimon Glass  *
151a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
166caa1956SSimon Glass  */
176caa1956SSimon Glass 
186caa1956SSimon Glass #include <common.h>
196caa1956SSimon Glass #include <fdt_support.h>
204588d61aSTom Rini #ifdef CONFIG_ARMV7_NONSEC
21d6b72da0SJan Kiszka #include <asm/armv7.h>
224588d61aSTom Rini #endif
23dd09f7e7STom Rini #include <asm/psci.h>
246b6024eaSMasahiro Yamada #include <asm/spin_table.h>
256caa1956SSimon Glass 
266caa1956SSimon Glass DECLARE_GLOBAL_DATA_PTR;
276caa1956SSimon Glass 
28ce176305SPrabhakar Kushwaha #ifdef CONFIG_FMAN_ENET
29ce176305SPrabhakar Kushwaha __weak int fdt_update_ethernet_dt(void *blob)
30ce176305SPrabhakar Kushwaha {
31ce176305SPrabhakar Kushwaha 	return 0;
32ce176305SPrabhakar Kushwaha }
33ce176305SPrabhakar Kushwaha #endif
34ce176305SPrabhakar Kushwaha 
35e09b1e4aSJoseph Chen __weak int board_fdt_fixup(void *blob)
36e09b1e4aSJoseph Chen {
37e09b1e4aSJoseph Chen 	return 0;
38e09b1e4aSJoseph Chen }
39e09b1e4aSJoseph Chen 
40e29607edSMa Haijun int arch_fixup_fdt(void *blob)
416caa1956SSimon Glass {
42984a3c87SB, Ravi 	int ret = 0;
43984a3c87SB, Ravi #if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_OF_LIBFDT)
446caa1956SSimon Glass 	bd_t *bd = gd->bd;
45984a3c87SB, Ravi 	int bank;
466caa1956SSimon Glass 	u64 start[CONFIG_NR_DRAM_BANKS];
476caa1956SSimon Glass 	u64 size[CONFIG_NR_DRAM_BANKS];
486caa1956SSimon Glass 
496caa1956SSimon Glass 	for (bank = 0; bank < CONFIG_NR_DRAM_BANKS; bank++) {
506caa1956SSimon Glass 		start[bank] = bd->bi_dram[bank].start;
516caa1956SSimon Glass 		size[bank] = bd->bi_dram[bank].size;
520291804aSJoseph Chen 		if (size[bank] == 0)
530291804aSJoseph Chen 			continue;
54*6cb8d50fSJoseph Chen 		printf("Adding bank: 0x%08llx - 0x%08llx (size: 0x%08llx)\n",
55*6cb8d50fSJoseph Chen 		       start[bank], start[bank] + size[bank], size[bank]);
5655fe151cSJoseph Chen 
57d6b72da0SJan Kiszka #ifdef CONFIG_ARMV7_NONSEC
58d6b72da0SJan Kiszka 		ret = armv7_apply_memory_carveout(&start[bank], &size[bank]);
59d6b72da0SJan Kiszka 		if (ret)
60d6b72da0SJan Kiszka 			return ret;
61d6b72da0SJan Kiszka #endif
626caa1956SSimon Glass 	}
636caa1956SSimon Glass 
64984a3c87SB, Ravi #ifdef CONFIG_OF_LIBFDT
65e771a3d5SMarc Zyngier 	ret = fdt_fixup_memory_banks(blob, start, size, CONFIG_NR_DRAM_BANKS);
66e771a3d5SMarc Zyngier 	if (ret)
67e771a3d5SMarc Zyngier 		return ret;
68984a3c87SB, Ravi #endif
69e771a3d5SMarc Zyngier 
706b6024eaSMasahiro Yamada #ifdef CONFIG_ARMV8_SPIN_TABLE
716b6024eaSMasahiro Yamada 	ret = spin_table_update_dt(blob);
726b6024eaSMasahiro Yamada 	if (ret)
736b6024eaSMasahiro Yamada 		return ret;
746b6024eaSMasahiro Yamada #endif
756b6024eaSMasahiro Yamada 
769a561753Smacro.wave.z@gmail.com #if defined(CONFIG_ARMV7_NONSEC) || defined(CONFIG_ARMV8_PSCI) || \
77daa92644SHou Zhiqiang 	defined(CONFIG_SEC_FIRMWARE_ARMV8_PSCI)
78dd09f7e7STom Rini 	ret = psci_update_dt(blob);
796441e3deSMasahiro Yamada 	if (ret)
80e771a3d5SMarc Zyngier 		return ret;
816441e3deSMasahiro Yamada #endif
82984a3c87SB, Ravi #endif
83e09b1e4aSJoseph Chen 	ret = board_fdt_fixup(blob);
84e09b1e4aSJoseph Chen 	if (ret)
85e09b1e4aSJoseph Chen 		return ret;
86e09b1e4aSJoseph Chen 
87ce176305SPrabhakar Kushwaha #ifdef CONFIG_FMAN_ENET
88ce176305SPrabhakar Kushwaha 	ret = fdt_update_ethernet_dt(blob);
89ce176305SPrabhakar Kushwaha 	if (ret)
90ce176305SPrabhakar Kushwaha 		return ret;
91ce176305SPrabhakar Kushwaha #endif
926441e3deSMasahiro Yamada 	return 0;
936caa1956SSimon Glass }
94