Add Broadcom's code for bcm63xx support
[project/bcm63xx/atf.git] / include / common / bl_common.h
1 /*
2 * Copyright (c) 2013-2019, ARM Limited and Contributors. All rights reserved.
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
7 #ifndef BL_COMMON_H
8 #define BL_COMMON_H
9
10 #include <common/ep_info.h>
11 #include <common/param_header.h>
12 #include <lib/utils_def.h>
13
14 #ifndef __ASSEMBLER__
15 #include <stddef.h>
16 #include <stdint.h>
17 #include <lib/cassert.h>
18 #endif /* __ASSEMBLER__ */
19
20 #include <export/common/bl_common_exp.h>
21
22 #define UP U(1)
23 #define DOWN U(0)
24
25 /*******************************************************************************
26 * Constants to identify the location of a memory region in a given memory
27 * layout.
28 ******************************************************************************/
29 /* BRCM_PATCH: Avoid symbol conflict with Broadcom */
30 #define ATF_TOP U(0x1)
31 #define ATF_BOTTOM U(0x0)
32
33 /*******************************************************************************
34 * Constants to indicate type of exception to the common exception handler.
35 ******************************************************************************/
36 #define SYNC_EXCEPTION_SP_EL0 U(0x0)
37 #define IRQ_SP_EL0 U(0x1)
38 #define FIQ_SP_EL0 U(0x2)
39 #define SERROR_SP_EL0 U(0x3)
40 #define SYNC_EXCEPTION_SP_ELX U(0x4)
41 #define IRQ_SP_ELX U(0x5)
42 #define FIQ_SP_ELX U(0x6)
43 #define SERROR_SP_ELX U(0x7)
44 #define SYNC_EXCEPTION_AARCH64 U(0x8)
45 #define IRQ_AARCH64 U(0x9)
46 #define FIQ_AARCH64 U(0xa)
47 #define SERROR_AARCH64 U(0xb)
48 #define SYNC_EXCEPTION_AARCH32 U(0xc)
49 #define IRQ_AARCH32 U(0xd)
50 #define FIQ_AARCH32 U(0xe)
51 #define SERROR_AARCH32 U(0xf)
52
53 /*
54 * Mapping to connect linker symbols from .ld.S with their counterparts
55 * from .scat for the BL31 image
56 */
57 #if defined(USE_ARM_LINK)
58 #define __BL31_END__ Load$$LR$$LR_END$$Base
59 #define __BSS_START__ Load$$LR$$LR_BSS$$Base
60 #define __BSS_END__ Load$$LR$$LR_BSS$$Limit
61 #define __BSS_SIZE__ Load$$LR$$LR_BSS$$Length
62 #define __COHERENT_RAM_START__ Load$$LR$$LR_COHERENT_RAM$$Base
63 #define __COHERENT_RAM_END_UNALIGNED__ Load$$__COHERENT_RAM_EPILOGUE_UNALIGNED__$$Base
64 #define __COHERENT_RAM_END__ Load$$LR$$LR_COHERENT_RAM$$Limit
65 #define __COHERENT_RAM_UNALIGNED_SIZE__ Load$$__COHERENT_RAM__$$Length
66 #define __CPU_OPS_START__ Load$$__CPU_OPS__$$Base
67 #define __CPU_OPS_END__ Load$$__CPU_OPS__$$Limit
68 #define __DATA_START__ Load$$__DATA__$$Base
69 #define __DATA_END__ Load$$__DATA__$$Limit
70 #define __GOT_START__ Load$$__GOT__$$Base
71 #define __GOT_END__ Load$$__GOT__$$Limit
72 #define __PERCPU_BAKERY_LOCK_START__ Load$$__BAKERY_LOCKS__$$Base
73 #define __PERCPU_BAKERY_LOCK_END__ Load$$__BAKERY_LOCKS_EPILOGUE__$$Base
74 #define __PMF_SVC_DESCS_START__ Load$$__PMF_SVC_DESCS__$$Base
75 #define __PMF_SVC_DESCS_END__ Load$$__PMF_SVC_DESCS__$$Limit
76 #define __PMF_TIMESTAMP_START__ Load$$__PMF_TIMESTAMP__$$Base
77 #define __PMF_TIMESTAMP_END__ Load$$__PER_CPU_TIMESTAMPS__$$Limit
78 #define __PMF_PERCPU_TIMESTAMP_END__ Load$$__PMF_TIMESTAMP_EPILOGUE__$$Base
79 #define __RELA_END__ Load$$__RELA__$$Limit
80 #define __RELA_START__ Load$$__RELA__$$Base
81 #define __RODATA_START__ Load$$__RODATA__$$Base
82 #define __RODATA_END__ Load$$__RODATA_EPILOGUE__$$Base
83 #define __RT_SVC_DESCS_START__ Load$$__RT_SVC_DESCS__$$Base
84 #define __RT_SVC_DESCS_END__ Load$$__RT_SVC_DESCS__$$Limit
85 #define __RW_START__ Load$$LR$$LR_RW_DATA$$Base
86 #define __RW_END__ Load$$LR$$LR_END$$Base
87 #define __SPM_SHIM_EXCEPTIONS_START__ Load$$__SPM_SHIM_EXCEPTIONS__$$Base
88 #define __SPM_SHIM_EXCEPTIONS_END__ Load$$__SPM_SHIM_EXCEPTIONS_EPILOGUE__$$Base
89 #define __STACKS_START__ Load$$__STACKS__$$Base
90 #define __STACKS_END__ Load$$__STACKS__$$Limit
91 #define __TEXT_START__ Load$$__TEXT__$$Base
92 #define __TEXT_END__ Load$$__TEXT_EPILOGUE__$$Base
93 #endif /* USE_ARM_LINK */
94
95 #ifndef __ASSEMBLER__
96
97 /*
98 * Declarations of linker defined symbols to help determine memory layout of
99 * BL images
100 */
101 #if SEPARATE_CODE_AND_RODATA
102 IMPORT_SYM(uintptr_t, __TEXT_START__, BL_CODE_BASE);
103 IMPORT_SYM(uintptr_t, __TEXT_END__, BL_CODE_END);
104 IMPORT_SYM(uintptr_t, __RODATA_START__, BL_RO_DATA_BASE);
105 IMPORT_SYM(uintptr_t, __RODATA_END__, BL_RO_DATA_END);
106 #else
107 IMPORT_SYM(uintptr_t, __RO_START__, BL_CODE_BASE);
108 IMPORT_SYM(uintptr_t, __RO_END__, BL_CODE_END);
109 #endif
110
111 #if defined(IMAGE_BL1)
112 IMPORT_SYM(uintptr_t, __BL1_ROM_END__, BL1_ROM_END);
113
114 IMPORT_SYM(uintptr_t, __BL1_RAM_START__, BL1_RAM_BASE);
115 IMPORT_SYM(uintptr_t, __BL1_RAM_END__, BL1_RAM_LIMIT);
116 #elif defined(IMAGE_BL2)
117 IMPORT_SYM(uintptr_t, __BL2_END__, BL2_END);
118 #elif defined(IMAGE_BL2U)
119 IMPORT_SYM(uintptr_t, __BL2U_END__, BL2U_END);
120 #elif defined(IMAGE_BL31)
121 IMPORT_SYM(uintptr_t, __BL31_START__, BL31_START);
122 IMPORT_SYM(uintptr_t, __BL31_END__, BL31_END);
123 #elif defined(IMAGE_BL32)
124 IMPORT_SYM(uintptr_t, __BL32_END__, BL32_END);
125 #endif /* IMAGE_BLX */
126
127 /* The following symbols are only exported from the BL2 at EL3 linker script. */
128 #if BL2_IN_XIP_MEM && defined(IMAGE_BL2)
129 IMPORT_SYM(uintptr_t, __BL2_ROM_END__, BL2_ROM_END);
130
131 IMPORT_SYM(uintptr_t, __BL2_RAM_START__, BL2_RAM_BASE);
132 IMPORT_SYM(uintptr_t, __BL2_RAM_END__, BL2_RAM_END);
133 #endif /* BL2_IN_XIP_MEM */
134
135 /*
136 * The next 2 constants identify the extents of the coherent memory region.
137 * These addresses are used by the MMU setup code and therefore they must be
138 * page-aligned. It is the responsibility of the linker script to ensure that
139 * __COHERENT_RAM_START__ and __COHERENT_RAM_END__ linker symbols refer to
140 * page-aligned addresses.
141 */
142 #if USE_COHERENT_MEM
143 IMPORT_SYM(uintptr_t, __COHERENT_RAM_START__, BL_COHERENT_RAM_BASE);
144 IMPORT_SYM(uintptr_t, __COHERENT_RAM_END__, BL_COHERENT_RAM_END);
145 #endif
146
147 /*******************************************************************************
148 * Structure used for telling the next BL how much of a particular type of
149 * memory is available for its use and how much is already used.
150 ******************************************************************************/
151 typedef struct meminfo {
152 uintptr_t total_base;
153 size_t total_size;
154 } meminfo_t;
155
156 /*******************************************************************************
157 * Function & variable prototypes
158 ******************************************************************************/
159 int load_auth_image(unsigned int image_id, image_info_t *image_data);
160
161 #if TRUSTED_BOARD_BOOT && defined(DYN_DISABLE_AUTH)
162 /*
163 * API to dynamically disable authentication. Only meant for development
164 * systems.
165 */
166 void dyn_disable_auth(void);
167 #endif
168
169 extern const char build_message[];
170 extern const char version_string[];
171
172 void print_entry_point_info(const entry_point_info_t *ep_info);
173 uintptr_t page_align(uintptr_t value, unsigned dir);
174
175 struct mmap_region;
176
177 void setup_page_tables(const struct mmap_region *bl_regions,
178 const struct mmap_region *plat_regions);
179
180 void bl_handle_pauth(void);
181
182 #endif /*__ASSEMBLER__*/
183
184 #endif /* BL_COMMON_H */