xref: /rk3399_ARM-atf/plat/hisilicon/poplar/bl1_plat_setup.c (revision e35d0edbbf5f55f2da5fa54ab5518149c18de622)
1*e35d0edbSJorge Ramirez-Ortiz /*
2*e35d0edbSJorge Ramirez-Ortiz  * Copyright (c) 2017, ARM Limited and Contributors. All rights reserved.
3*e35d0edbSJorge Ramirez-Ortiz  *
4*e35d0edbSJorge Ramirez-Ortiz  * SPDX-License-Identifier: BSD-3-Clause
5*e35d0edbSJorge Ramirez-Ortiz  */
6*e35d0edbSJorge Ramirez-Ortiz 
7*e35d0edbSJorge Ramirez-Ortiz #include <arch_helpers.h>
8*e35d0edbSJorge Ramirez-Ortiz #include <assert.h>
9*e35d0edbSJorge Ramirez-Ortiz #include <bl_common.h>
10*e35d0edbSJorge Ramirez-Ortiz #include <console.h>
11*e35d0edbSJorge Ramirez-Ortiz #include <debug.h>
12*e35d0edbSJorge Ramirez-Ortiz #include <errno.h>
13*e35d0edbSJorge Ramirez-Ortiz #include <generic_delay_timer.h>
14*e35d0edbSJorge Ramirez-Ortiz #include <mmio.h>
15*e35d0edbSJorge Ramirez-Ortiz #include <pl061_gpio.h>
16*e35d0edbSJorge Ramirez-Ortiz #include <platform.h>
17*e35d0edbSJorge Ramirez-Ortiz #include <platform_def.h>
18*e35d0edbSJorge Ramirez-Ortiz #include <string.h>
19*e35d0edbSJorge Ramirez-Ortiz #include <tbbr_img_def.h>
20*e35d0edbSJorge Ramirez-Ortiz #include "../../bl1/bl1_private.h"
21*e35d0edbSJorge Ramirez-Ortiz #include "hi3798cv200.h"
22*e35d0edbSJorge Ramirez-Ortiz #include "plat_private.h"
23*e35d0edbSJorge Ramirez-Ortiz 
24*e35d0edbSJorge Ramirez-Ortiz /* Symbols from link script for conherent section */
25*e35d0edbSJorge Ramirez-Ortiz extern unsigned long __COHERENT_RAM_START__;
26*e35d0edbSJorge Ramirez-Ortiz extern unsigned long __COHERENT_RAM_END__;
27*e35d0edbSJorge Ramirez-Ortiz 
28*e35d0edbSJorge Ramirez-Ortiz #define BL1_COHERENT_RAM_BASE	(unsigned long)(&__COHERENT_RAM_START__)
29*e35d0edbSJorge Ramirez-Ortiz #define BL1_COHERENT_RAM_LIMIT	(unsigned long)(&__COHERENT_RAM_END__)
30*e35d0edbSJorge Ramirez-Ortiz 
31*e35d0edbSJorge Ramirez-Ortiz /* Data structure which holds the extents of the trusted RAM for BL1 */
32*e35d0edbSJorge Ramirez-Ortiz static meminfo_t bl1_tzram_layout;
33*e35d0edbSJorge Ramirez-Ortiz 
34*e35d0edbSJorge Ramirez-Ortiz meminfo_t *bl1_plat_sec_mem_layout(void)
35*e35d0edbSJorge Ramirez-Ortiz {
36*e35d0edbSJorge Ramirez-Ortiz 	return &bl1_tzram_layout;
37*e35d0edbSJorge Ramirez-Ortiz }
38*e35d0edbSJorge Ramirez-Ortiz 
39*e35d0edbSJorge Ramirez-Ortiz void bl1_early_platform_setup(void)
40*e35d0edbSJorge Ramirez-Ortiz {
41*e35d0edbSJorge Ramirez-Ortiz 	/* Initialize the console to provide early debug support */
42*e35d0edbSJorge Ramirez-Ortiz 	console_init(PL011_UART0_BASE, PL011_UART0_CLK_IN_HZ, PL011_BAUDRATE);
43*e35d0edbSJorge Ramirez-Ortiz 
44*e35d0edbSJorge Ramirez-Ortiz 	/* Allow BL1 to see the whole Trusted RAM */
45*e35d0edbSJorge Ramirez-Ortiz 	bl1_tzram_layout.total_base = BL_MEM_BASE;
46*e35d0edbSJorge Ramirez-Ortiz 	bl1_tzram_layout.total_size = BL_MEM_SIZE;
47*e35d0edbSJorge Ramirez-Ortiz 
48*e35d0edbSJorge Ramirez-Ortiz 	/* Calculate how much RAM BL1 is using and how much remains free */
49*e35d0edbSJorge Ramirez-Ortiz 	bl1_tzram_layout.free_base = BL_MEM_BASE;
50*e35d0edbSJorge Ramirez-Ortiz 	bl1_tzram_layout.free_size = BL_MEM_SIZE;
51*e35d0edbSJorge Ramirez-Ortiz 
52*e35d0edbSJorge Ramirez-Ortiz 	reserve_mem(&bl1_tzram_layout.free_base,
53*e35d0edbSJorge Ramirez-Ortiz 		    &bl1_tzram_layout.free_size,
54*e35d0edbSJorge Ramirez-Ortiz 		    BL1_RAM_BASE,
55*e35d0edbSJorge Ramirez-Ortiz 		    BL1_RAM_LIMIT - BL1_RAM_BASE);
56*e35d0edbSJorge Ramirez-Ortiz 
57*e35d0edbSJorge Ramirez-Ortiz 	INFO("BL1: 0x%lx - 0x%lx [size = %zu]\n", BL1_RAM_BASE, BL1_RAM_LIMIT,
58*e35d0edbSJorge Ramirez-Ortiz 	     BL1_RAM_LIMIT - BL1_RAM_BASE);
59*e35d0edbSJorge Ramirez-Ortiz }
60*e35d0edbSJorge Ramirez-Ortiz 
61*e35d0edbSJorge Ramirez-Ortiz void bl1_plat_arch_setup(void)
62*e35d0edbSJorge Ramirez-Ortiz {
63*e35d0edbSJorge Ramirez-Ortiz 	plat_configure_mmu_el3(bl1_tzram_layout.total_base,
64*e35d0edbSJorge Ramirez-Ortiz 			       bl1_tzram_layout.total_size,
65*e35d0edbSJorge Ramirez-Ortiz 			       BL_MEM_BASE, /* l-loader and BL1 ROM */
66*e35d0edbSJorge Ramirez-Ortiz 			       BL1_RO_LIMIT,
67*e35d0edbSJorge Ramirez-Ortiz 			       BL1_COHERENT_RAM_BASE,
68*e35d0edbSJorge Ramirez-Ortiz 			       BL1_COHERENT_RAM_LIMIT);
69*e35d0edbSJorge Ramirez-Ortiz }
70*e35d0edbSJorge Ramirez-Ortiz 
71*e35d0edbSJorge Ramirez-Ortiz void bl1_platform_setup(void)
72*e35d0edbSJorge Ramirez-Ortiz {
73*e35d0edbSJorge Ramirez-Ortiz 	int i;
74*e35d0edbSJorge Ramirez-Ortiz 
75*e35d0edbSJorge Ramirez-Ortiz 	generic_delay_timer_init();
76*e35d0edbSJorge Ramirez-Ortiz 
77*e35d0edbSJorge Ramirez-Ortiz 	pl061_gpio_init();
78*e35d0edbSJorge Ramirez-Ortiz 	for (i = 0; i < GPIO_MAX; i++)
79*e35d0edbSJorge Ramirez-Ortiz 		pl061_gpio_register(GPIO_BASE(i), i);
80*e35d0edbSJorge Ramirez-Ortiz 
81*e35d0edbSJorge Ramirez-Ortiz 	plat_io_setup();
82*e35d0edbSJorge Ramirez-Ortiz }
83*e35d0edbSJorge Ramirez-Ortiz 
84*e35d0edbSJorge Ramirez-Ortiz unsigned int bl1_plat_get_next_image_id(void)
85*e35d0edbSJorge Ramirez-Ortiz {
86*e35d0edbSJorge Ramirez-Ortiz 	return BL2_IMAGE_ID;
87*e35d0edbSJorge Ramirez-Ortiz }
88