1 /*
2  * Copyright (c) 2013-2021, 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 #define __RW_START__			Load$$LR$$LR_RW_DATA$$Base
85 #define __RW_END__			Load$$LR$$LR_END$$Base
86 #define __SPM_SHIM_EXCEPTIONS_START__	Load$$__SPM_SHIM_EXCEPTIONS__$$Base
87 #define __SPM_SHIM_EXCEPTIONS_END__	Load$$__SPM_SHIM_EXCEPTIONS_EPILOGUE__$$Base
88 #define __STACKS_START__		Load$$__STACKS__$$Base
89 #define __STACKS_END__			Load$$__STACKS__$$Limit
90 #define __TEXT_START__			Load$$__TEXT__$$Base
91 #define __TEXT_END__			Load$$__TEXT_EPILOGUE__$$Base
92 #endif /* USE_ARM_LINK */
93 
94 #ifndef __ASSEMBLER__
95 
96 /*
97  * Declarations of linker defined symbols to help determine memory layout of
98  * BL images
99  */
100 #if SEPARATE_CODE_AND_RODATA
101 IMPORT_SYM(uintptr_t, __TEXT_START__,		BL_CODE_BASE);
102 IMPORT_SYM(uintptr_t, __TEXT_END__,		BL_CODE_END);
103 IMPORT_SYM(uintptr_t, __RODATA_START__,		BL_RO_DATA_BASE);
104 IMPORT_SYM(uintptr_t, __RODATA_END__,		BL_RO_DATA_END);
105 #else
106 IMPORT_SYM(uintptr_t, __RO_START__,		BL_CODE_BASE);
107 IMPORT_SYM(uintptr_t, __RO_END__,		BL_CODE_END);
108 #endif
109 #if SEPARATE_NOBITS_REGION
110 IMPORT_SYM(uintptr_t, __NOBITS_START__,		BL_NOBITS_BASE);
111 IMPORT_SYM(uintptr_t, __NOBITS_END__,		BL_NOBITS_END);
112 #endif
113 IMPORT_SYM(uintptr_t, __RW_END__,		BL_END);
114 
115 #if defined(IMAGE_BL1)
116 IMPORT_SYM(uintptr_t, __BL1_ROM_END__,		BL1_ROM_END);
117 
118 IMPORT_SYM(uintptr_t, __BL1_RAM_START__,	BL1_RAM_BASE);
119 IMPORT_SYM(uintptr_t, __BL1_RAM_END__,		BL1_RAM_LIMIT);
120 #elif defined(IMAGE_BL2)
121 IMPORT_SYM(uintptr_t, __BL2_END__,		BL2_END);
122 #elif defined(IMAGE_BL2U)
123 IMPORT_SYM(uintptr_t, __BL2U_END__,		BL2U_END);
124 #elif defined(IMAGE_BL31)
125 IMPORT_SYM(uintptr_t, __BL31_START__,		BL31_START);
126 IMPORT_SYM(uintptr_t, __BL31_END__,		BL31_END);
127 #elif defined(IMAGE_BL32)
128 IMPORT_SYM(uintptr_t, __BL32_END__,		BL32_END);
129 #elif defined(IMAGE_RMM)
130 IMPORT_SYM(uintptr_t, __RMM_END__,		RMM_END);
131 #endif /* IMAGE_BLX */
132 
133 /* The following symbols are only exported from the BL2 at EL3 linker script. */
134 #if BL2_IN_XIP_MEM && defined(IMAGE_BL2)
135 IMPORT_SYM(uintptr_t, __BL2_ROM_END__,		BL2_ROM_END);
136 
137 IMPORT_SYM(uintptr_t, __BL2_RAM_START__,	BL2_RAM_BASE);
138 IMPORT_SYM(uintptr_t, __BL2_RAM_END__,		BL2_RAM_END);
139 #endif /* BL2_IN_XIP_MEM */
140 
141 /*
142  * The next 2 constants identify the extents of the coherent memory region.
143  * These addresses are used by the MMU setup code and therefore they must be
144  * page-aligned.  It is the responsibility of the linker script to ensure that
145  * __COHERENT_RAM_START__ and __COHERENT_RAM_END__ linker symbols refer to
146  * page-aligned addresses.
147  */
148 #if USE_COHERENT_MEM
149 IMPORT_SYM(uintptr_t, __COHERENT_RAM_START__,	BL_COHERENT_RAM_BASE);
150 IMPORT_SYM(uintptr_t, __COHERENT_RAM_END__,	BL_COHERENT_RAM_END);
151 #endif
152 
153 /*******************************************************************************
154  * Structure used for telling the next BL how much of a particular type of
155  * memory is available for its use and how much is already used.
156  ******************************************************************************/
157 typedef struct meminfo {
158 	uintptr_t total_base;
159 	size_t total_size;
160 } meminfo_t;
161 
162 /*******************************************************************************
163  * Function & variable prototypes
164  ******************************************************************************/
165 int load_auth_image(unsigned int image_id, image_info_t *image_data);
166 
167 #if TRUSTED_BOARD_BOOT && defined(DYN_DISABLE_AUTH)
168 /*
169  * API to dynamically disable authentication. Only meant for development
170  * systems.
171  */
172 void dyn_disable_auth(void);
173 #endif
174 
175 extern const char build_message[];
176 extern const char version_string[];
177 
178 void print_entry_point_info(const entry_point_info_t *ep_info);
179 uintptr_t page_align(uintptr_t value, unsigned dir);
180 
181 struct mmap_region;
182 
183 void setup_page_tables(const struct mmap_region *bl_regions,
184 			   const struct mmap_region *plat_regions);
185 
186 void bl_handle_pauth(void);
187 
188 #endif /*__ASSEMBLER__*/
189 
190 #endif /* BL_COMMON_H */
191