soc/intel/alderlake: Add ADL-P 4+4 with 28W TDP
[coreboot.git] / src / include / symbols.h
bloba03af08463fd925c50b74c40feddec83f861f3d8
1 /* SPDX-License-Identifier: GPL-2.0-only */
3 #ifndef __SYMBOLS_H
4 #define __SYMBOLS_H
6 #include <types.h>
8 extern u8 _dram[];
10 #define REGION_SIZE(name) ((size_t)_##name##_size)
12 #define DECLARE_REGION(name) \
13 extern u8 _##name[]; \
14 extern u8 _e##name[]; \
15 extern u8 _##name##_size[];
18 * Regions can be declared optional if not all configurations provide them in
19 * memlayout and you want code to be able to check for their existence at
20 * runtime. Not every region that is architecture or platform-specific should
21 * use this -- only declare regions optional if the code *accessing* them runs
22 * both on configurations that have the region and those that don't. That code
23 * should then check (REGION_SIZE(name) != 0) before accessing it.
25 #define DECLARE_OPTIONAL_REGION(name) \
26 __weak extern u8 _##name[]; \
27 __weak extern u8 _e##name[]; \
28 __weak extern u8 _##name##_size[];
30 DECLARE_REGION(sram)
31 DECLARE_OPTIONAL_REGION(timestamp)
32 DECLARE_REGION(preram_cbmem_console)
33 DECLARE_REGION(cbmem_init_hooks)
34 DECLARE_REGION(stack)
35 DECLARE_OPTIONAL_REGION(preram_cbfs_cache)
36 DECLARE_OPTIONAL_REGION(postram_cbfs_cache)
37 DECLARE_OPTIONAL_REGION(cbfs_cache)
38 DECLARE_REGION(cbfs_mcache)
39 DECLARE_REGION(fmap_cache)
40 DECLARE_REGION(tpm_log)
42 #if ENV_ROMSTAGE && CONFIG(ASAN_IN_ROMSTAGE)
43 DECLARE_REGION(bss)
44 DECLARE_REGION(asan_shadow)
45 #endif
47 #if ENV_RAMSTAGE && CONFIG(ASAN_IN_RAMSTAGE)
48 DECLARE_REGION(data)
49 DECLARE_REGION(heap)
50 DECLARE_REGION(asan_shadow)
51 #endif
53 /* Regions for execution units. */
55 DECLARE_REGION(payload)
56 /* "program" always refers to the current execution unit. */
57 DECLARE_REGION(program)
58 /* _<stage>_size is always the maximum amount allocated in memlayout, whereas
59 _program_size gives the actual memory footprint *used* by current stage. */
60 DECLARE_REGION(decompressor)
61 DECLARE_REGION(bootblock)
62 DECLARE_REGION(verstage)
63 DECLARE_REGION(romstage)
64 DECLARE_REGION(postcar)
65 DECLARE_REGION(ramstage)
67 /* Arch-specific, move to <arch/symbols.h> if they become too many. */
69 DECLARE_REGION(pagetables)
70 DECLARE_REGION(ttb)
71 DECLARE_OPTIONAL_REGION(ttb_subtables)
72 DECLARE_REGION(dma_coherent)
73 DECLARE_REGION(soc_registers)
74 DECLARE_REGION(framebuffer)
75 DECLARE_REGION(pdpt)
76 DECLARE_OPTIONAL_REGION(opensbi)
77 DECLARE_OPTIONAL_REGION(bl31)
78 DECLARE_REGION(transfer_buffer)
79 DECLARE_OPTIONAL_REGION(watchdog_tombstone)
81 /* Returns true when pre-RAM symbols are known to the linker.
82 * (Does not necessarily mean that the memory is accessible.) */
83 static inline int preram_symbols_available(void)
85 return !ENV_X86 || ENV_ROMSTAGE_OR_BEFORE;
88 #endif /* __SYMBOLS_H */