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