symbols.h: Add macro to define memlayout region symbols
When <symbols.h> was first introduced, it only declared a handful of regions and we didn't expect that too many architectures and platforms would need to add their own later. However, our amount of platforms has greatly expanded since, and with them the need for more special memory regions. The amount of code duplication is starting to get unsightly, and platforms keep defining their own <soc/symbols.h> files that need this as well. This patch adds another macro to cut down the definition boilerplate. Unfortunately, macros cannot define other macros when they're called, so referring to region sizes as _name_size doesn't work anymore. This patch replaces the scheme with REGION_SIZE(name). Not touching the regions in the x86-specific <arch/symbols.h> yet since they don't follow the standard _region/_eregion naming scheme. They can be converted later if desired. Change-Id: I44727d77d1de75882c72a94f29bd7e2c27741dd8 Signed-off-by: Julius Werner <jwerner@chromium.org> Reviewed-on: https://review.coreboot.org/c/31539 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
parent
314b5c370b
commit
7e0dea6317
|
@ -28,14 +28,14 @@ void bootmem_arch_add_ranges(void)
|
||||||
{
|
{
|
||||||
DECLARE_OPTIONAL_REGION(ttb_subtables);
|
DECLARE_OPTIONAL_REGION(ttb_subtables);
|
||||||
|
|
||||||
bootmem_add_range((uintptr_t)_ttb, _ttb_size, BM_MEM_RAMSTAGE);
|
bootmem_add_range((uintptr_t)_ttb, REGION_SIZE(ttb), BM_MEM_RAMSTAGE);
|
||||||
bootmem_add_range((uintptr_t)_ttb_subtables, _ttb_subtables_size,
|
bootmem_add_range((uintptr_t)_ttb_subtables, REGION_SIZE(ttb_subtables),
|
||||||
BM_MEM_RAMSTAGE);
|
BM_MEM_RAMSTAGE);
|
||||||
|
|
||||||
if (!IS_ENABLED(CONFIG_COMMON_CBFS_SPI_WRAPPER))
|
if (!IS_ENABLED(CONFIG_COMMON_CBFS_SPI_WRAPPER))
|
||||||
return;
|
return;
|
||||||
bootmem_add_range((uintptr_t)_postram_cbfs_cache,
|
bootmem_add_range((uintptr_t)_postram_cbfs_cache,
|
||||||
_postram_cbfs_cache_size, BM_MEM_RAMSTAGE);
|
REGION_SIZE(postram_cbfs_cache), BM_MEM_RAMSTAGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void lb_arch_add_records(struct lb_header *header)
|
void lb_arch_add_records(struct lb_header *header)
|
||||||
|
|
|
@ -28,15 +28,17 @@ void arch_write_tables(uintptr_t coreboot_table)
|
||||||
|
|
||||||
void bootmem_arch_add_ranges(void)
|
void bootmem_arch_add_ranges(void)
|
||||||
{
|
{
|
||||||
bootmem_add_range((uintptr_t)_ttb, _ttb_size, BM_MEM_RAMSTAGE);
|
bootmem_add_range((uintptr_t)_ttb, REGION_SIZE(ttb), BM_MEM_RAMSTAGE);
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_ARM64_USE_ARM_TRUSTED_FIRMWARE) && _bl31_size > 0)
|
if (IS_ENABLED(CONFIG_ARM64_USE_ARM_TRUSTED_FIRMWARE) &&
|
||||||
bootmem_add_range((uintptr_t)_bl31, _bl31_size, BM_MEM_BL31);
|
REGION_SIZE(bl31) > 0)
|
||||||
|
bootmem_add_range((uintptr_t)_bl31, REGION_SIZE(bl31),
|
||||||
|
BM_MEM_BL31);
|
||||||
|
|
||||||
if (!IS_ENABLED(CONFIG_COMMON_CBFS_SPI_WRAPPER))
|
if (!IS_ENABLED(CONFIG_COMMON_CBFS_SPI_WRAPPER))
|
||||||
return;
|
return;
|
||||||
bootmem_add_range((uintptr_t)_postram_cbfs_cache,
|
bootmem_add_range((uintptr_t)_postram_cbfs_cache,
|
||||||
_postram_cbfs_cache_size, BM_MEM_RAMSTAGE);
|
REGION_SIZE(postram_cbfs_cache), BM_MEM_RAMSTAGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void lb_arch_add_records(struct lb_header *header)
|
void lb_arch_add_records(struct lb_header *header)
|
||||||
|
|
|
@ -111,5 +111,6 @@ void arch_segment_loaded(uintptr_t start, size_t size, int flags)
|
||||||
{
|
{
|
||||||
cache_invalidate_all(start, size);
|
cache_invalidate_all(start, size);
|
||||||
if (flags & SEG_FINAL)
|
if (flags & SEG_FINAL)
|
||||||
cache_invalidate_all((uintptr_t)_cbfs_cache, _cbfs_cache_size);
|
cache_invalidate_all((uintptr_t)_cbfs_cache,
|
||||||
|
REGION_SIZE(cbfs_cache));
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,7 +172,8 @@ void acpi_prepare_resume_backup(void)
|
||||||
if (IS_ENABLED(CONFIG_RELOCATABLE_RAMSTAGE))
|
if (IS_ENABLED(CONFIG_RELOCATABLE_RAMSTAGE))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
backup_create_or_update(NULL, (uintptr_t)_program, _program_size);
|
backup_create_or_update(NULL, (uintptr_t)_program,
|
||||||
|
REGION_SIZE(program));
|
||||||
}
|
}
|
||||||
|
|
||||||
#define WAKEUP_BASE 0x600
|
#define WAKEUP_BASE 0x600
|
||||||
|
|
|
@ -239,12 +239,12 @@ int paging_enable_for_car(const char *pdpt_name, const char *pt_name)
|
||||||
if (!ENV_CACHE_AS_RAM)
|
if (!ENV_CACHE_AS_RAM)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (read_from_cbfs(pdpt_name, _pdpt, _pdpt_size)) {
|
if (read_from_cbfs(pdpt_name, _pdpt, REGION_SIZE(pdpt))) {
|
||||||
printk(BIOS_ERR, "Couldn't load pdpt\n");
|
printk(BIOS_ERR, "Couldn't load pdpt\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (read_from_cbfs(pt_name, _pagetables, _pagetables_size)) {
|
if (read_from_cbfs(pt_name, _pagetables, REGION_SIZE(pagetables))) {
|
||||||
printk(BIOS_ERR, "Couldn't load page tables\n");
|
printk(BIOS_ERR, "Couldn't load page tables\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -398,7 +398,7 @@ void fsp_memory_init(bool s3wake)
|
||||||
memranges_init_empty(&memmap, &freeranges[0], ARRAY_SIZE(freeranges));
|
memranges_init_empty(&memmap, &freeranges[0], ARRAY_SIZE(freeranges));
|
||||||
memranges_insert(&memmap, (uintptr_t)_car_region_start,
|
memranges_insert(&memmap, (uintptr_t)_car_region_start,
|
||||||
_car_relocatable_data_end - _car_region_start, 0);
|
_car_relocatable_data_end - _car_region_start, 0);
|
||||||
memranges_insert(&memmap, (uintptr_t)_program, _program_size, 0);
|
memranges_insert(&memmap, (uintptr_t)_program, REGION_SIZE(program), 0);
|
||||||
|
|
||||||
if (!IS_ENABLED(CONFIG_FSP_M_XIP))
|
if (!IS_ENABLED(CONFIG_FSP_M_XIP))
|
||||||
status = load_fspm_mem(&hdr, &file_data, &memmap);
|
status = load_fspm_mem(&hdr, &file_data, &memmap);
|
||||||
|
|
|
@ -105,7 +105,7 @@ static void switch_to_postram_cache(int unused)
|
||||||
boot_device_init();
|
boot_device_init();
|
||||||
if (_preram_cbfs_cache != _postram_cbfs_cache)
|
if (_preram_cbfs_cache != _postram_cbfs_cache)
|
||||||
mmap_helper_device_init(&mdev, _postram_cbfs_cache,
|
mmap_helper_device_init(&mdev, _postram_cbfs_cache,
|
||||||
_postram_cbfs_cache_size);
|
REGION_SIZE(postram_cbfs_cache));
|
||||||
}
|
}
|
||||||
ROMSTAGE_CBMEM_INIT_HOOK(switch_to_postram_cache);
|
ROMSTAGE_CBMEM_INIT_HOOK(switch_to_postram_cache);
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ void boot_device_init(void)
|
||||||
|
|
||||||
spi_flash_init_done = true;
|
spi_flash_init_done = true;
|
||||||
|
|
||||||
mmap_helper_device_init(&mdev, _cbfs_cache, _cbfs_cache_size);
|
mmap_helper_device_init(&mdev, _cbfs_cache, REGION_SIZE(cbfs_cache));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return the CBFS boot device. */
|
/* Return the CBFS boot device. */
|
||||||
|
|
|
@ -18,111 +18,53 @@
|
||||||
|
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
||||||
extern u8 _sram[];
|
|
||||||
extern u8 _esram[];
|
|
||||||
#define _sram_size (_esram - _sram)
|
|
||||||
|
|
||||||
extern u8 _dram[];
|
extern u8 _dram[];
|
||||||
|
|
||||||
extern u8 _timestamp[];
|
#define REGION_SIZE(name) (_e##name - _##name)
|
||||||
extern u8 _etimestamp[];
|
|
||||||
#define _timestamp_size (_etimestamp - _timestamp)
|
|
||||||
|
|
||||||
extern u8 _preram_cbmem_console[];
|
#define DECLARE_REGION(name) \
|
||||||
extern u8 _epreram_cbmem_console[];
|
extern u8 _##name[]; \
|
||||||
#define _preram_cbmem_console_size \
|
extern u8 _e##name[];
|
||||||
(_epreram_cbmem_console - _preram_cbmem_console)
|
|
||||||
|
|
||||||
extern u8 _cbmem_init_hooks[];
|
DECLARE_REGION(sram)
|
||||||
extern u8 _ecbmem_init_hooks[];
|
DECLARE_REGION(timestamp)
|
||||||
#define _cbmem_init_hooks_size (_ecbmem_init_hooks - _cbmem_init_hooks)
|
DECLARE_REGION(preram_cbmem_console)
|
||||||
|
DECLARE_REGION(cbmem_init_hooks)
|
||||||
extern u8 _stack[];
|
DECLARE_REGION(stack)
|
||||||
extern u8 _estack[];
|
DECLARE_REGION(preram_cbfs_cache)
|
||||||
#define _stack_size (_estack - _stack)
|
DECLARE_REGION(postram_cbfs_cache)
|
||||||
|
DECLARE_REGION(cbfs_cache)
|
||||||
extern u8 _pagetables[];
|
DECLARE_REGION(payload)
|
||||||
extern u8 _epagetables[];
|
|
||||||
#define _pagetables_size (_epagetables - _pagetables)
|
|
||||||
|
|
||||||
extern u8 _preram_cbfs_cache[];
|
|
||||||
extern u8 _epreram_cbfs_cache[];
|
|
||||||
#define _preram_cbfs_cache_size (_epreram_cbfs_cache - _preram_cbfs_cache)
|
|
||||||
|
|
||||||
extern u8 _postram_cbfs_cache[];
|
|
||||||
extern u8 _epostram_cbfs_cache[];
|
|
||||||
#define _postram_cbfs_cache_size (_epostram_cbfs_cache - _postram_cbfs_cache)
|
|
||||||
|
|
||||||
extern u8 _cbfs_cache[];
|
|
||||||
extern u8 _ecbfs_cache[];
|
|
||||||
#define _cbfs_cache_size (_ecbfs_cache - _cbfs_cache)
|
|
||||||
|
|
||||||
extern u8 _payload[];
|
|
||||||
extern u8 _epayload[];
|
|
||||||
#define _payload_size (_epayload - _payload)
|
|
||||||
|
|
||||||
/* "program" always refers to the current execution unit. */
|
/* "program" always refers to the current execution unit. */
|
||||||
extern u8 _program[];
|
DECLARE_REGION(program)
|
||||||
extern u8 _eprogram[];
|
|
||||||
#define _program_size (_eprogram - _program)
|
|
||||||
|
|
||||||
/* _<stage>_size is always the maximum amount allocated in memlayout, whereas
|
/* _<stage>_size is always the maximum amount allocated in memlayout, whereas
|
||||||
* _program_size gives the actual memory footprint *used* by current stage. */
|
_program_size gives the actual memory footprint *used* by current stage. */
|
||||||
extern u8 _decompressor[];
|
DECLARE_REGION(decompressor)
|
||||||
extern u8 _edecompressor[];
|
DECLARE_REGION(bootblock)
|
||||||
#define _decompressor_size (_edecompressor - _decompressor)
|
DECLARE_REGION(verstage)
|
||||||
|
DECLARE_REGION(romstage)
|
||||||
extern u8 _bootblock[];
|
DECLARE_REGION(postcar)
|
||||||
extern u8 _ebootblock[];
|
DECLARE_REGION(ramstage)
|
||||||
#define _bootblock_size (_ebootblock - _bootblock)
|
|
||||||
|
|
||||||
extern u8 _romstage[];
|
|
||||||
extern u8 _eromstage[];
|
|
||||||
#define _romstage_size (_eromstage - _romstage)
|
|
||||||
|
|
||||||
extern u8 _ramstage[];
|
|
||||||
extern u8 _eramstage[];
|
|
||||||
#define _ramstage_size (_eramstage - _ramstage)
|
|
||||||
|
|
||||||
extern u8 _verstage[];
|
|
||||||
extern u8 _everstage[];
|
|
||||||
#define _verstage_size (_everstage - _verstage)
|
|
||||||
|
|
||||||
/* Arch-specific, move to <arch/symbols.h> if they become too many. */
|
/* Arch-specific, move to <arch/symbols.h> if they become too many. */
|
||||||
|
|
||||||
extern u8 _ttb[];
|
DECLARE_REGION(pagetables)
|
||||||
extern u8 _ettb[];
|
DECLARE_REGION(ttb)
|
||||||
#define _ttb_size (_ettb - _ttb)
|
DECLARE_REGION(ttb_subtables)
|
||||||
|
DECLARE_REGION(dma_coherent)
|
||||||
|
DECLARE_REGION(soc_registers)
|
||||||
|
DECLARE_REGION(framebuffer)
|
||||||
|
DECLARE_REGION(pdpt)
|
||||||
|
DECLARE_REGION(bl31)
|
||||||
|
|
||||||
extern u8 _ttb_subtables[];
|
/*
|
||||||
extern u8 _ettb_subtables[];
|
* Put this into a .c file accessing a linker script region to mark that region
|
||||||
#define _ttb_subtables_size (_ettb_subtables - _ttb_subtables)
|
|
||||||
|
|
||||||
extern u8 _dma_coherent[];
|
|
||||||
extern u8 _edma_coherent[];
|
|
||||||
#define _dma_coherent_size (_edma_coherent - _dma_coherent)
|
|
||||||
|
|
||||||
extern u8 _soc_registers[];
|
|
||||||
extern u8 _esoc_registers[];
|
|
||||||
#define _soc_registers_size (_esoc_registers - _soc_registers)
|
|
||||||
|
|
||||||
extern u8 _framebuffer[];
|
|
||||||
extern u8 _eframebuffer[];
|
|
||||||
#define _framebuffer_size (_eframebuffer - _framebuffer)
|
|
||||||
|
|
||||||
extern u8 _pdpt[];
|
|
||||||
extern u8 _epdpt[];
|
|
||||||
#define _pdpt_size (_epdpt - _pdpt)
|
|
||||||
|
|
||||||
extern u8 _bl31[];
|
|
||||||
extern u8 _ebl31[];
|
|
||||||
#define _bl31_size (_ebl31 - _bl31)
|
|
||||||
|
|
||||||
/* Put this into a .c file accessing a linker script region to mark that region
|
|
||||||
* as "optional". If it is defined in memlayout.ld (or anywhere else), the
|
* as "optional". If it is defined in memlayout.ld (or anywhere else), the
|
||||||
* values from that definition will be used. If not, start, end and size will
|
* values from that definition will be used. If not, start, end and size will
|
||||||
* all evaluate to 0. (We can't explicitly assign the symbols to 0 in the
|
* all evaluate to 0. (We can't explicitly assign the symbols to 0 in the
|
||||||
* assembly due to https://sourceware.org/bugzilla/show_bug.cgi?id=1038.) */
|
* assembly due to https://sourceware.org/bugzilla/show_bug.cgi?id=1038.)
|
||||||
|
*/
|
||||||
#define DECLARE_OPTIONAL_REGION(name) asm (".weak _" #name ", _e" #name)
|
#define DECLARE_OPTIONAL_REGION(name) asm (".weak _" #name ", _e" #name)
|
||||||
|
|
||||||
#endif /* __SYMBOLS_H */
|
#endif /* __SYMBOLS_H */
|
||||||
|
|
|
@ -33,7 +33,8 @@ asmlinkage void bootblock_main_with_timestamp(uint64_t base_timestamp,
|
||||||
struct timestamp_entry *timestamps, size_t num_timestamps)
|
struct timestamp_entry *timestamps, size_t num_timestamps)
|
||||||
{
|
{
|
||||||
/* Initialize timestamps if we have TIMESTAMP region in memlayout.ld. */
|
/* Initialize timestamps if we have TIMESTAMP region in memlayout.ld. */
|
||||||
if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS) && _timestamp_size > 0) {
|
if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS) &&
|
||||||
|
REGION_SIZE(timestamp) > 0) {
|
||||||
int i;
|
int i;
|
||||||
timestamp_init(base_timestamp);
|
timestamp_init(base_timestamp);
|
||||||
for (i = 0; i < num_timestamps; i++)
|
for (i = 0; i < num_timestamps; i++)
|
||||||
|
|
|
@ -89,8 +89,10 @@ static void bootmem_init(void)
|
||||||
/* Add memory used by CBMEM. */
|
/* Add memory used by CBMEM. */
|
||||||
cbmem_add_bootmem();
|
cbmem_add_bootmem();
|
||||||
|
|
||||||
bootmem_add_range((uintptr_t)_stack, _stack_size, BM_MEM_RAMSTAGE);
|
bootmem_add_range((uintptr_t)_stack, REGION_SIZE(stack),
|
||||||
bootmem_add_range((uintptr_t)_program, _program_size, BM_MEM_RAMSTAGE);
|
BM_MEM_RAMSTAGE);
|
||||||
|
bootmem_add_range((uintptr_t)_program, REGION_SIZE(program),
|
||||||
|
BM_MEM_RAMSTAGE);
|
||||||
|
|
||||||
bootmem_arch_add_ranges();
|
bootmem_arch_add_ranges();
|
||||||
bootmem_platform_add_ranges();
|
bootmem_platform_add_ranges();
|
||||||
|
|
|
@ -24,7 +24,7 @@ void cbmem_run_init_hooks(int is_recovery)
|
||||||
cbmem_init_hook_t *einit_hook_ptr =
|
cbmem_init_hook_t *einit_hook_ptr =
|
||||||
(cbmem_init_hook_t *)&_ecbmem_init_hooks;
|
(cbmem_init_hook_t *)&_ecbmem_init_hooks;
|
||||||
|
|
||||||
if (_cbmem_init_hooks_size == 0)
|
if (REGION_SIZE(cbmem_init_hooks) == 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
while (init_hook_ptr != einit_hook_ptr) {
|
while (init_hook_ptr != einit_hook_ptr) {
|
||||||
|
|
|
@ -111,7 +111,8 @@ void cbmemc_init(void)
|
||||||
{
|
{
|
||||||
#ifdef __PRE_RAM__
|
#ifdef __PRE_RAM__
|
||||||
/* Pre-RAM environments use special buffer placed by linker script. */
|
/* Pre-RAM environments use special buffer placed by linker script. */
|
||||||
init_console_ptr(_preram_cbmem_console, _preram_cbmem_console_size);
|
init_console_ptr(_preram_cbmem_console,
|
||||||
|
REGION_SIZE(preram_cbmem_console));
|
||||||
#else
|
#else
|
||||||
/* Post-RAM uses static (BSS) buffer before CBMEM is reinitialized. */
|
/* Post-RAM uses static (BSS) buffer before CBMEM is reinitialized. */
|
||||||
init_console_ptr(static_console, sizeof(static_console));
|
init_console_ptr(static_console, sizeof(static_console));
|
||||||
|
|
|
@ -30,7 +30,8 @@ it with the version available from LANL.
|
||||||
int checkstack(void *top_of_stack, int core)
|
int checkstack(void *top_of_stack, int core)
|
||||||
{
|
{
|
||||||
/* Not all archs use CONFIG_STACK_SIZE, those who don't set it to 0. */
|
/* Not all archs use CONFIG_STACK_SIZE, those who don't set it to 0. */
|
||||||
size_t stack_size = CONFIG_STACK_SIZE ? CONFIG_STACK_SIZE : _stack_size;
|
size_t stack_size = CONFIG_STACK_SIZE ?
|
||||||
|
CONFIG_STACK_SIZE : REGION_SIZE(stack);
|
||||||
int i;
|
int i;
|
||||||
u32 *stack = (u32 *) (top_of_stack - stack_size);
|
u32 *stack = (u32 *) (top_of_stack - stack_size);
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ struct __packed timestamp_cache {
|
||||||
DECLARE_OPTIONAL_REGION(timestamp);
|
DECLARE_OPTIONAL_REGION(timestamp);
|
||||||
|
|
||||||
#if defined(__PRE_RAM__)
|
#if defined(__PRE_RAM__)
|
||||||
#define USE_TIMESTAMP_REGION (_timestamp_size > 0)
|
#define USE_TIMESTAMP_REGION (REGION_SIZE(timestamp) > 0)
|
||||||
#else
|
#else
|
||||||
#define USE_TIMESTAMP_REGION 0
|
#define USE_TIMESTAMP_REGION 0
|
||||||
#endif
|
#endif
|
||||||
|
@ -70,7 +70,7 @@ static void timestamp_cache_init(struct timestamp_cache *ts_cache,
|
||||||
ts_cache->cache_state = TIMESTAMP_CACHE_INITIALIZED;
|
ts_cache->cache_state = TIMESTAMP_CACHE_INITIALIZED;
|
||||||
|
|
||||||
if (USE_TIMESTAMP_REGION)
|
if (USE_TIMESTAMP_REGION)
|
||||||
ts_cache->table.max_entries = (_timestamp_size -
|
ts_cache->table.max_entries = (REGION_SIZE(timestamp) -
|
||||||
offsetof(struct timestamp_cache, entries))
|
offsetof(struct timestamp_cache, entries))
|
||||||
/ sizeof(struct timestamp_entry);
|
/ sizeof(struct timestamp_entry);
|
||||||
}
|
}
|
||||||
|
@ -82,7 +82,7 @@ static struct timestamp_cache *timestamp_cache_get(void)
|
||||||
if (TIMESTAMP_CACHE_IN_BSS) {
|
if (TIMESTAMP_CACHE_IN_BSS) {
|
||||||
ts_cache = ×tamp_cache;
|
ts_cache = ×tamp_cache;
|
||||||
} else if (USE_TIMESTAMP_REGION) {
|
} else if (USE_TIMESTAMP_REGION) {
|
||||||
if (_timestamp_size < sizeof(*ts_cache))
|
if (REGION_SIZE(timestamp) < sizeof(*ts_cache))
|
||||||
BUG();
|
BUG();
|
||||||
ts_cache = car_get_var_ptr((void *)_timestamp);
|
ts_cache = car_get_var_ptr((void *)_timestamp);
|
||||||
}
|
}
|
||||||
|
|
|
@ -326,7 +326,7 @@ static void mainboard_enable(struct device *dev)
|
||||||
mmu_config_range(0, DRAM_START, DCACHE_OFF);
|
mmu_config_range(0, DRAM_START, DCACHE_OFF);
|
||||||
mmu_config_range(DRAM_START, DRAM_SIZE, DCACHE_WRITEBACK);
|
mmu_config_range(DRAM_START, DRAM_SIZE, DCACHE_WRITEBACK);
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
mmu_config_range(DRAM_END, 4096 - DRAM_END, DCACHE_OFF);
|
mmu_config_range(DRAM_END, 4096 - DRAM_END, DCACHE_OFF);
|
||||||
dcache_mmu_enable();
|
dcache_mmu_enable();
|
||||||
|
|
||||||
|
@ -353,5 +353,5 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
|
|
||||||
if (IS_ENABLED(CONFIG_CHROMEOS)) {
|
if (IS_ENABLED(CONFIG_CHROMEOS)) {
|
||||||
/* Retrieve the switch interface MAC addresses. */
|
/* Retrieve the switch interface MAC addresses. */
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
|
|
||||||
/* DMA memory for drivers */
|
/* DMA memory for drivers */
|
||||||
#define DMA_START ((uintptr_t)_dma_coherent / MiB)
|
#define DMA_START ((uintptr_t)_dma_coherent / MiB)
|
||||||
#define DMA_SIZE (_dma_coherent_size / MiB)
|
#define DMA_SIZE (REGION_SIZE(dma_coherent) / MiB)
|
||||||
|
|
||||||
void setup_dram_mappings(enum dram_state dram)
|
void setup_dram_mappings(enum dram_state dram)
|
||||||
{
|
{
|
||||||
|
|
|
@ -74,5 +74,6 @@ void platform_romstage_main(void)
|
||||||
|
|
||||||
mmu_config_range((void *)0, (uintptr_t)sdram_size_mb() * MiB,
|
mmu_config_range((void *)0, (uintptr_t)sdram_size_mb() * MiB,
|
||||||
CACHED_MEM);
|
CACHED_MEM);
|
||||||
mmu_config_range(_dma_coherent, _dma_coherent_size, UNCACHED_MEM);
|
mmu_config_range(_dma_coherent, REGION_SIZE(dma_coherent),
|
||||||
|
UNCACHED_MEM);
|
||||||
}
|
}
|
||||||
|
|
|
@ -262,5 +262,5 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,13 +55,14 @@ static void __attribute__((noinline)) romstage(void)
|
||||||
/* Device memory below DRAM is uncached. */
|
/* Device memory below DRAM is uncached. */
|
||||||
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
||||||
/* SRAM is cached. MMU code will round size up to page size. */
|
/* SRAM is cached. MMU code will round size up to page size. */
|
||||||
mmu_config_range((uintptr_t)_sram/MiB, DIV_ROUND_UP(_sram_size, MiB),
|
mmu_config_range((uintptr_t)_sram/MiB,
|
||||||
|
DIV_ROUND_UP(REGION_SIZE(sram), MiB),
|
||||||
DCACHE_WRITEBACK);
|
DCACHE_WRITEBACK);
|
||||||
/* DRAM is cached. */
|
/* DRAM is cached. */
|
||||||
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
||||||
/* A window for DMA is uncached. */
|
/* A window for DMA is uncached. */
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
/* The space above DRAM is uncached. */
|
/* The space above DRAM is uncached. */
|
||||||
if (dram_end_mb < 4096)
|
if (dram_end_mb < 4096)
|
||||||
mmu_config_range(dram_end_mb, 4096 - dram_end_mb, DCACHE_OFF);
|
mmu_config_range(dram_end_mb, 4096 - dram_end_mb, DCACHE_OFF);
|
||||||
|
|
|
@ -260,5 +260,5 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,13 +55,14 @@ static void __attribute__((noinline)) romstage(void)
|
||||||
/* Device memory below DRAM is uncached. */
|
/* Device memory below DRAM is uncached. */
|
||||||
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
||||||
/* SRAM is cached. MMU code will round size up to page size. */
|
/* SRAM is cached. MMU code will round size up to page size. */
|
||||||
mmu_config_range((uintptr_t)_sram/MiB, DIV_ROUND_UP(_sram_size, MiB),
|
mmu_config_range((uintptr_t)_sram/MiB,
|
||||||
|
DIV_ROUND_UP(REGION_SIZE(sram), MiB),
|
||||||
DCACHE_WRITEBACK);
|
DCACHE_WRITEBACK);
|
||||||
/* DRAM is cached. */
|
/* DRAM is cached. */
|
||||||
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
||||||
/* A window for DMA is uncached. */
|
/* A window for DMA is uncached. */
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
/* The space above DRAM is uncached. */
|
/* The space above DRAM is uncached. */
|
||||||
if (dram_end_mb < 4096)
|
if (dram_end_mb < 4096)
|
||||||
mmu_config_range(dram_end_mb, 4096 - dram_end_mb, DCACHE_OFF);
|
mmu_config_range(dram_end_mb, 4096 - dram_end_mb, DCACHE_OFF);
|
||||||
|
|
|
@ -260,5 +260,5 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,7 +57,8 @@ static void __attribute__((noinline)) romstage(void)
|
||||||
/* Device memory below DRAM is uncached. */
|
/* Device memory below DRAM is uncached. */
|
||||||
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
mmu_config_range(0, dram_start_mb, DCACHE_OFF);
|
||||||
/* SRAM is cached. MMU code will round size up to page size. */
|
/* SRAM is cached. MMU code will round size up to page size. */
|
||||||
mmu_config_range((uintptr_t)_sram/MiB, DIV_ROUND_UP(_sram_size, MiB),
|
mmu_config_range((uintptr_t)_sram/MiB,
|
||||||
|
DIV_ROUND_UP(REGION_SIZE(sram), MiB),
|
||||||
DCACHE_WRITEBACK);
|
DCACHE_WRITEBACK);
|
||||||
/* The space above DRAM is uncached. */
|
/* The space above DRAM is uncached. */
|
||||||
if (dram_end_mb < 4096)
|
if (dram_end_mb < 4096)
|
||||||
|
@ -70,7 +71,7 @@ static void __attribute__((noinline)) romstage(void)
|
||||||
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
mmu_config_range(dram_start_mb, dram_size_mb, DCACHE_WRITEBACK);
|
||||||
/* A window for DMA is uncached. */
|
/* A window for DMA is uncached. */
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* A watchdog reset only resets part of the system so it ends up in
|
* A watchdog reset only resets part of the system so it ends up in
|
||||||
|
|
|
@ -462,7 +462,7 @@ static void mainboard_enable(struct device *dev)
|
||||||
/* set up caching for the DRAM */
|
/* set up caching for the DRAM */
|
||||||
mmu_config_range(DRAM_START, DRAM_SIZE, DCACHE_WRITEBACK);
|
mmu_config_range(DRAM_START, DRAM_SIZE, DCACHE_WRITEBACK);
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
|
|
||||||
const unsigned epll_hz = 192000000;
|
const unsigned epll_hz = 192000000;
|
||||||
const unsigned sample_rate = 48000;
|
const unsigned sample_rate = 48000;
|
||||||
|
@ -487,5 +487,5 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,7 +122,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
|
|
||||||
#if IS_ENABLED(CONFIG_CHROMEOS)
|
#if IS_ENABLED(CONFIG_CHROMEOS)
|
||||||
/* Retrieve the switch interface MAC addresses. */
|
/* Retrieve the switch interface MAC addresses. */
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
|
|
||||||
/* DMA memory for drivers */
|
/* DMA memory for drivers */
|
||||||
#define DMA_START ((uintptr_t)_dma_coherent / MiB)
|
#define DMA_START ((uintptr_t)_dma_coherent / MiB)
|
||||||
#define DMA_SIZE (_dma_coherent_size / MiB)
|
#define DMA_SIZE (REGION_SIZE(dma_coherent) / MiB)
|
||||||
|
|
||||||
void setup_dram_mappings(enum dram_state dram)
|
void setup_dram_mappings(enum dram_state dram)
|
||||||
{
|
{
|
||||||
|
|
|
@ -47,7 +47,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
|
|
||||||
#if IS_ENABLED(CONFIG_CHROMEOS)
|
#if IS_ENABLED(CONFIG_CHROMEOS)
|
||||||
/* Retrieve the switch interface MAC addresses. */
|
/* Retrieve the switch interface MAC addresses. */
|
||||||
|
|
|
@ -126,7 +126,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mainboard_power_on_backlight(void)
|
void mainboard_power_on_backlight(void)
|
||||||
|
|
|
@ -102,7 +102,7 @@ void main(void)
|
||||||
mmu_config_range((uintptr_t)_dram/MiB,
|
mmu_config_range((uintptr_t)_dram/MiB,
|
||||||
sdram_size_mb(), DCACHE_WRITEBACK);
|
sdram_size_mb(), DCACHE_WRITEBACK);
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
|
|
||||||
cbmem_initialize_empty();
|
cbmem_initialize_empty();
|
||||||
|
|
||||||
|
|
|
@ -105,7 +105,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mainboard_power_on_backlight(void)
|
void mainboard_power_on_backlight(void)
|
||||||
|
|
|
@ -93,7 +93,7 @@ void main(void)
|
||||||
mmu_config_range((uintptr_t)_dram/MiB,
|
mmu_config_range((uintptr_t)_dram/MiB,
|
||||||
sdram_size_mb(), DCACHE_WRITEBACK);
|
sdram_size_mb(), DCACHE_WRITEBACK);
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
|
|
||||||
cbmem_initialize_empty();
|
cbmem_initialize_empty();
|
||||||
|
|
||||||
|
|
|
@ -111,7 +111,7 @@ void lb_board(struct lb_header *header)
|
||||||
dma->tag = LB_TAB_DMA;
|
dma->tag = LB_TAB_DMA;
|
||||||
dma->size = sizeof(*dma);
|
dma->size = sizeof(*dma);
|
||||||
dma->range_start = (uintptr_t)_dma_coherent;
|
dma->range_start = (uintptr_t)_dma_coherent;
|
||||||
dma->range_size = _dma_coherent_size;
|
dma->range_size = REGION_SIZE(dma_coherent);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mainboard_power_on_backlight(void)
|
void mainboard_power_on_backlight(void)
|
||||||
|
|
|
@ -103,7 +103,7 @@ void main(void)
|
||||||
mmu_config_range((uintptr_t)_dram/MiB,
|
mmu_config_range((uintptr_t)_dram/MiB,
|
||||||
sdram_size_mb(), DCACHE_WRITEBACK);
|
sdram_size_mb(), DCACHE_WRITEBACK);
|
||||||
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
mmu_config_range((uintptr_t)_dma_coherent/MiB,
|
||||||
_dma_coherent_size/MiB, DCACHE_OFF);
|
REGION_SIZE(dma_coherent)/MiB, DCACHE_OFF);
|
||||||
|
|
||||||
cbmem_initialize_empty();
|
cbmem_initialize_empty();
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,7 @@ static size_t vb2_working_data_size(void)
|
||||||
if (IS_ENABLED(CONFIG_VBOOT_STARTS_IN_ROMSTAGE))
|
if (IS_ENABLED(CONFIG_VBOOT_STARTS_IN_ROMSTAGE))
|
||||||
return vb_work_buf_size;
|
return vb_work_buf_size;
|
||||||
else
|
else
|
||||||
return _vboot2_work_size;
|
return REGION_SIZE(vboot2_work);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct selected_region *vb2_selected_region(void)
|
static struct selected_region *vb2_selected_region(void)
|
||||||
|
|
|
@ -16,8 +16,8 @@
|
||||||
#ifndef __VBOOT_SYMBOLS_H__
|
#ifndef __VBOOT_SYMBOLS_H__
|
||||||
#define __VBOOT_SYMBOLS_H__
|
#define __VBOOT_SYMBOLS_H__
|
||||||
|
|
||||||
extern u8 _vboot2_work[];
|
#include <symbols.h>
|
||||||
extern u8 _evboot2_work[];
|
|
||||||
#define _vboot2_work_size (_evboot2_work - _vboot2_work)
|
DECLARE_REGION(vboot2_work)
|
||||||
|
|
||||||
#endif /* __VBOOT_SYMBOLS_H__ */
|
#endif /* __VBOOT_SYMBOLS_H__ */
|
||||||
|
|
|
@ -81,7 +81,7 @@ size_t start_cpu(size_t cpu, void (*entry_64)(size_t core_id))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
/* Check stack here, instead of in cpu_secondary.S */
|
/* Check stack here, instead of in cpu_secondary.S */
|
||||||
if ((CONFIG_STACK_SIZE * cpu) > _stack_sec_size)
|
if ((CONFIG_STACK_SIZE * cpu) > REGION_SIZE(stack_sec))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
/* Write the address of the main entry point */
|
/* Write the address of the main entry point */
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#define __SOC_CAVIUM_CN81XX_CPU_H__
|
#define __SOC_CAVIUM_CN81XX_CPU_H__
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <symbols.h>
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Number of the Core on which the program is currently running.
|
* Number of the Core on which the program is currently running.
|
||||||
|
@ -70,8 +71,6 @@ void secondary_cpu_init(size_t core_id);
|
||||||
|
|
||||||
/* Symbols in memlayout.ld */
|
/* Symbols in memlayout.ld */
|
||||||
|
|
||||||
extern u8 _stack_sec[];
|
DECLARE_REGION(stack_sec)
|
||||||
extern u8 _estack_sec[];
|
|
||||||
#define _stack_sec_size (_estack_sec - _stack_sec)
|
|
||||||
|
|
||||||
#endif /* __SOC_CAVIUM_CN81XX_CPU_H__ */
|
#endif /* __SOC_CAVIUM_CN81XX_CPU_H__ */
|
||||||
|
|
|
@ -31,7 +31,7 @@ void soc_mmu_init(void)
|
||||||
* Need to use secure mem attribute, as firmware is running in ARM TZ
|
* Need to use secure mem attribute, as firmware is running in ARM TZ
|
||||||
* region.
|
* region.
|
||||||
*/
|
*/
|
||||||
mmu_config_range((void *)_ttb, _ttb_size, secure_mem);
|
mmu_config_range((void *)_ttb, REGION_SIZE(ttb), secure_mem);
|
||||||
mmu_config_range((void *)_dram, sdram_size_mb() * MiB, secure_mem);
|
mmu_config_range((void *)_dram, sdram_size_mb() * MiB, secure_mem);
|
||||||
/* IO space has the MSB set and is divided into 4 sub-regions:
|
/* IO space has the MSB set and is divided into 4 sub-regions:
|
||||||
* * NCB
|
* * NCB
|
||||||
|
|
|
@ -42,7 +42,7 @@ void bootblock_main(const uint64_t reg_x0,
|
||||||
base_timestamp = timestamp_get();
|
base_timestamp = timestamp_get();
|
||||||
|
|
||||||
/* Initialize timestamps if we have TIMESTAMP region in memlayout.ld. */
|
/* Initialize timestamps if we have TIMESTAMP region in memlayout.ld. */
|
||||||
if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS) && _timestamp_size > 0)
|
if (IS_ENABLED(CONFIG_COLLECT_TIMESTAMPS) && REGION_SIZE(timestamp) > 0)
|
||||||
timestamp_init(base_timestamp);
|
timestamp_init(base_timestamp);
|
||||||
|
|
||||||
bootblock_soc_early_init();
|
bootblock_soc_early_init();
|
||||||
|
|
|
@ -54,9 +54,9 @@ static void bootblock_mmu_init(void)
|
||||||
dram_base += null_guard_size;
|
dram_base += null_guard_size;
|
||||||
dram_size -= null_guard_size;
|
dram_size -= null_guard_size;
|
||||||
}
|
}
|
||||||
assert(!identity_map((uint32_t)_sram, _sram_size,
|
assert(!identity_map((uint32_t)_sram, REGION_SIZE(sram),
|
||||||
C0_ENTRYLO_COHERENCY_WB));
|
C0_ENTRYLO_COHERENCY_WB));
|
||||||
assert(!identity_map(dram_base, dram_size, C0_ENTRYLO_COHERENCY_WB));
|
assert(!identity_map(dram_base, dram_size, C0_ENTRYLO_COHERENCY_WB));
|
||||||
assert(!identity_map((uint32_t)_soc_registers, _soc_registers_size,
|
assert(!identity_map((uint32_t)_soc_registers,
|
||||||
C0_ENTRYLO_COHERENCY_UC));
|
REGION_SIZE(soc_registers), C0_ENTRYLO_COHERENCY_UC));
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#define __SOC_MEDIATEK_COMMON_MMU_OPERATIONS_H__
|
#define __SOC_MEDIATEK_COMMON_MMU_OPERATIONS_H__
|
||||||
|
|
||||||
#include <arch/mmu.h>
|
#include <arch/mmu.h>
|
||||||
|
#include <symbols.h>
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
DEV_MEM = MA_DEV | MA_S | MA_RW,
|
DEV_MEM = MA_DEV | MA_S | MA_RW,
|
||||||
|
@ -26,9 +27,7 @@ enum {
|
||||||
NONSECURE_UNCACHED_MEM = MA_MEM | MA_NS | MA_RW | MA_MEM_NC,
|
NONSECURE_UNCACHED_MEM = MA_MEM | MA_NS | MA_RW | MA_MEM_NC,
|
||||||
};
|
};
|
||||||
|
|
||||||
extern unsigned char _sram_l2c[];
|
DECLARE_REGION(sram_l2c)
|
||||||
extern unsigned char _esram_l2c[];
|
|
||||||
#define _sram_l2c_size (_esram_l2c - _sram_l2c)
|
|
||||||
|
|
||||||
void mtk_soc_after_dram(void);
|
void mtk_soc_after_dram(void);
|
||||||
void mtk_soc_disable_l2c_sram(void);
|
void mtk_soc_disable_l2c_sram(void);
|
||||||
|
|
|
@ -32,13 +32,13 @@ void mtk_mmu_init(void)
|
||||||
mmu_config_range((void *)0, (uintptr_t)4U * GiB, DEV_MEM);
|
mmu_config_range((void *)0, (uintptr_t)4U * GiB, DEV_MEM);
|
||||||
|
|
||||||
/* SRAM is cached */
|
/* SRAM is cached */
|
||||||
mmu_config_range(_sram, _sram_size, SECURE_CACHED_MEM);
|
mmu_config_range(_sram, REGION_SIZE(sram), SECURE_CACHED_MEM);
|
||||||
|
|
||||||
/* L2C SRAM is cached */
|
/* L2C SRAM is cached */
|
||||||
mmu_config_range(_sram_l2c, _sram_l2c_size, SECURE_CACHED_MEM);
|
mmu_config_range(_sram_l2c, REGION_SIZE(sram_l2c), SECURE_CACHED_MEM);
|
||||||
|
|
||||||
/* DMA is non-cached and is reserved for TPM & da9212 I2C DMA */
|
/* DMA is non-cached and is reserved for TPM & da9212 I2C DMA */
|
||||||
mmu_config_range(_dma_coherent, _dma_coherent_size,
|
mmu_config_range(_dma_coherent, REGION_SIZE(dma_coherent),
|
||||||
SECURE_UNCACHED_MEM);
|
SECURE_UNCACHED_MEM);
|
||||||
|
|
||||||
mmu_enable();
|
mmu_enable();
|
||||||
|
@ -56,7 +56,7 @@ void mtk_mmu_disable_l2c_sram(void)
|
||||||
{
|
{
|
||||||
/* Unmap L2C SRAM so it can be reclaimed by L2 cache */
|
/* Unmap L2C SRAM so it can be reclaimed by L2 cache */
|
||||||
/* TODO: Implement true unmapping, and also use it for the zero-page! */
|
/* TODO: Implement true unmapping, and also use it for the zero-page! */
|
||||||
mmu_config_range(_sram_l2c, _sram_l2c_size, DEV_MEM);
|
mmu_config_range(_sram_l2c, REGION_SIZE(sram_l2c), DEV_MEM);
|
||||||
|
|
||||||
/* Careful: changing cache geometry while it's active is a bad idea! */
|
/* Careful: changing cache geometry while it's active is a bad idea! */
|
||||||
mmu_disable();
|
mmu_disable();
|
||||||
|
|
|
@ -171,10 +171,10 @@ static int nor_read(const struct spi_flash *flash, u32 addr, size_t len,
|
||||||
|
|
||||||
if (ENV_BOOTBLOCK || ENV_VERSTAGE) {
|
if (ENV_BOOTBLOCK || ENV_VERSTAGE) {
|
||||||
dma_buf = (uintptr_t)_dma_coherent;
|
dma_buf = (uintptr_t)_dma_coherent;
|
||||||
dma_buf_len = _dma_coherent_size;
|
dma_buf_len = REGION_SIZE(dma_coherent);
|
||||||
} else {
|
} else {
|
||||||
dma_buf = (uintptr_t)_dram_dma;
|
dma_buf = (uintptr_t)_dram_dma;
|
||||||
dma_buf_len = _dram_dma_size;
|
dma_buf_len = REGION_SIZE(dram_dma);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (len - done >= SFLASH_DMA_ALIGN) {
|
while (len - done >= SFLASH_DMA_ALIGN) {
|
||||||
|
|
|
@ -16,8 +16,6 @@
|
||||||
#ifndef __SOC_MEDIATEK_MT8173_DRAM_DMA_H__
|
#ifndef __SOC_MEDIATEK_MT8173_DRAM_DMA_H__
|
||||||
#define __SOC_MEDIATEK_MT8173_DRAM_DMA_H__
|
#define __SOC_MEDIATEK_MT8173_DRAM_DMA_H__
|
||||||
|
|
||||||
extern unsigned char _dram_dma[];
|
DECLARE_REGION(dram_dma)
|
||||||
extern unsigned char _edram_dma[];
|
|
||||||
#define _dram_dma_size (_edram_dma - _dram_dma)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -23,7 +23,8 @@
|
||||||
|
|
||||||
void mtk_soc_after_dram(void)
|
void mtk_soc_after_dram(void)
|
||||||
{
|
{
|
||||||
mmu_config_range(_dram_dma, _dram_dma_size, NONSECURE_UNCACHED_MEM);
|
mmu_config_range(_dram_dma, REGION_SIZE(dram_dma),
|
||||||
|
NONSECURE_UNCACHED_MEM);
|
||||||
mtk_mmu_disable_l2c_sram();
|
mtk_mmu_disable_l2c_sram();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -30,7 +30,8 @@ static void enable_cache(void)
|
||||||
/* Whole space is uncached. */
|
/* Whole space is uncached. */
|
||||||
mmu_config_range(0, 4096, DCACHE_OFF);
|
mmu_config_range(0, 4096, DCACHE_OFF);
|
||||||
/* SRAM is cached. MMU code will round size up to page size. */
|
/* SRAM is cached. MMU code will round size up to page size. */
|
||||||
mmu_config_range((uintptr_t)_sram/MiB, DIV_ROUND_UP(_sram_size, MiB),
|
mmu_config_range((uintptr_t)_sram/MiB,
|
||||||
|
DIV_ROUND_UP(REGION_SIZE(sram), MiB),
|
||||||
DCACHE_WRITEBACK);
|
DCACHE_WRITEBACK);
|
||||||
mmu_disable_range(0, 1);
|
mmu_disable_range(0, 1);
|
||||||
dcache_mmu_enable();
|
dcache_mmu_enable();
|
||||||
|
|
|
@ -45,7 +45,7 @@ static void tegra210_mmu_config(void)
|
||||||
mmu_config_range((void *)(start * MiB), (end-start) * MiB, cachedmem);
|
mmu_config_range((void *)(start * MiB), (end-start) * MiB, cachedmem);
|
||||||
|
|
||||||
/* SRAM */
|
/* SRAM */
|
||||||
mmu_config_range(_sram, _sram_size, cachedmem);
|
mmu_config_range(_sram, REGION_SIZE(sram), cachedmem);
|
||||||
|
|
||||||
/* Add TZ carveout. */
|
/* Add TZ carveout. */
|
||||||
carveout_range(CARVEOUT_TZ, &tz_base_mib, &tz_size_mib);
|
carveout_range(CARVEOUT_TZ, &tz_base_mib, &tz_size_mib);
|
||||||
|
@ -89,8 +89,8 @@ void tegra210_mmu_init(void)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
carveout_range(CARVEOUT_TZ, &tz_base_mib, &tz_size_mib);
|
carveout_range(CARVEOUT_TZ, &tz_base_mib, &tz_size_mib);
|
||||||
assert((uintptr_t)_ttb + _ttb_size == (tz_base_mib + tz_size_mib) * MiB
|
assert((uintptr_t)_ttb + REGION_SIZE(ttb) == (tz_base_mib + tz_size_mib)
|
||||||
&& _ttb_size <= tz_size_mib * MiB);
|
* MiB && REGION_SIZE(ttb) <= tz_size_mib * MiB);
|
||||||
|
|
||||||
mmu_enable();
|
mmu_enable();
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,18 +16,11 @@
|
||||||
#ifndef _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
#ifndef _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
||||||
#define _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
#define _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
||||||
|
|
||||||
|
#include <symbols.h>
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
||||||
extern u8 _ssram[];
|
DECLARE_REGION(ssram)
|
||||||
extern u8 _essram[];
|
DECLARE_REGION(bsram)
|
||||||
#define _ssram_size (_essram - _ssram)
|
DECLARE_REGION(dram_reserved)
|
||||||
|
|
||||||
extern u8 _bsram[];
|
|
||||||
extern u8 _ebsram[];
|
|
||||||
#define _bsram_size (_ebsram - _bsram)
|
|
||||||
|
|
||||||
extern u8 _dram_reserved[];
|
|
||||||
extern u8 _edram_reserved[];
|
|
||||||
#define _dram_reserved_size (_edram_reserved - _dram_reserved)
|
|
||||||
|
|
||||||
#endif // _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
#endif // _SOC_QUALCOMM_SDM845_SYMBOLS_H_
|
||||||
|
|
|
@ -28,9 +28,9 @@ void sdm845_mmu_init(void)
|
||||||
mmu_init();
|
mmu_init();
|
||||||
|
|
||||||
mmu_config_range((void *)(4 * KiB), ((4UL * GiB) - (4 * KiB)), DEV_MEM);
|
mmu_config_range((void *)(4 * KiB), ((4UL * GiB) - (4 * KiB)), DEV_MEM);
|
||||||
mmu_config_range((void *)_ssram, _ssram_size, CACHED_RAM);
|
mmu_config_range((void *)_ssram, REGION_SIZE(ssram), CACHED_RAM);
|
||||||
mmu_config_range((void *)_bsram, _bsram_size, CACHED_RAM);
|
mmu_config_range((void *)_bsram, REGION_SIZE(bsram), CACHED_RAM);
|
||||||
mmu_config_range((void *)_dma_coherent, _dma_coherent_size,
|
mmu_config_range((void *)_dma_coherent, REGION_SIZE(dma_coherent),
|
||||||
UNCACHED_RAM);
|
UNCACHED_RAM);
|
||||||
|
|
||||||
mmu_enable();
|
mmu_enable();
|
||||||
|
|
|
@ -23,7 +23,7 @@ static void soc_read_resources(struct device *dev)
|
||||||
{
|
{
|
||||||
ram_resource(dev, 0, (uintptr_t)_dram / KiB, DRAMSIZE4GB / KiB);
|
ram_resource(dev, 0, (uintptr_t)_dram / KiB, DRAMSIZE4GB / KiB);
|
||||||
reserved_ram_resource(dev, 1, (uintptr_t)_dram_reserved / KiB,
|
reserved_ram_resource(dev, 1, (uintptr_t)_dram_reserved / KiB,
|
||||||
_dram_reserved_size / KiB);
|
REGION_SIZE(dram_reserved) / KiB);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void soc_init(struct device *dev)
|
static void soc_init(struct device *dev)
|
||||||
|
|
|
@ -33,7 +33,7 @@ void bootblock_soc_init(void)
|
||||||
/* SRAM is tightly wedged between registers, need to use subtables. Map
|
/* SRAM is tightly wedged between registers, need to use subtables. Map
|
||||||
* write-through as equivalent for non-cacheable without XN on A17. */
|
* write-through as equivalent for non-cacheable without XN on A17. */
|
||||||
mmu_config_range_kb((uintptr_t)_sram/KiB,
|
mmu_config_range_kb((uintptr_t)_sram/KiB,
|
||||||
_sram_size/KiB, DCACHE_WRITETHROUGH);
|
REGION_SIZE(sram)/KiB, DCACHE_WRITETHROUGH);
|
||||||
dcache_mmu_enable();
|
dcache_mmu_enable();
|
||||||
|
|
||||||
rkclk_configure_crypto(148500*KHz);
|
rkclk_configure_crypto(148500*KHz);
|
||||||
|
|
|
@ -34,7 +34,7 @@ static void soc_init(struct device *dev)
|
||||||
ram_resource(dev, 0, (uintptr_t)_dram/KiB, sdram_size_mb()*(MiB/KiB));
|
ram_resource(dev, 0, (uintptr_t)_dram/KiB, sdram_size_mb()*(MiB/KiB));
|
||||||
if (display_init_required())
|
if (display_init_required())
|
||||||
rk_display_init(dev, (uintptr_t)_framebuffer,
|
rk_display_init(dev, (uintptr_t)_framebuffer,
|
||||||
_framebuffer_size);
|
REGION_SIZE(framebuffer));
|
||||||
else
|
else
|
||||||
printk(BIOS_INFO, "Skipping display init.\n");
|
printk(BIOS_INFO, "Skipping display init.\n");
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ void decompressor_soc_init(void)
|
||||||
*/
|
*/
|
||||||
mmu_config_range((void *)0, (uintptr_t)4 * GiB, DEV_MEM);
|
mmu_config_range((void *)0, (uintptr_t)4 * GiB, DEV_MEM);
|
||||||
|
|
||||||
mmu_config_range(_sram, _sram_size, SECURE_MEM);
|
mmu_config_range(_sram, REGION_SIZE(sram), SECURE_MEM);
|
||||||
|
|
||||||
mmu_enable();
|
mmu_enable();
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,12 +16,9 @@
|
||||||
#ifndef __SOC_SYMBOLS_H__
|
#ifndef __SOC_SYMBOLS_H__
|
||||||
#define __SOC_SYMBOLS_H__
|
#define __SOC_SYMBOLS_H__
|
||||||
|
|
||||||
extern unsigned char _bl31_sram[];
|
#include <symbols.h>
|
||||||
extern unsigned char _ebl31_sram[];
|
|
||||||
#define _bl31_sram_size (_ebl31_sram - _bl31_sram)
|
|
||||||
|
|
||||||
extern unsigned char _pmu_sram[];
|
DECLARE_REGION(bl31_sram)
|
||||||
extern unsigned char _epmu_sram[];
|
DECLARE_REGION(pmu_sram)
|
||||||
#define _pmu_sram_size (_epmu_sram - _pmu_sram)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -30,8 +30,10 @@
|
||||||
|
|
||||||
void bootmem_platform_add_ranges(void)
|
void bootmem_platform_add_ranges(void)
|
||||||
{
|
{
|
||||||
bootmem_add_range((uintptr_t)_pmu_sram, _pmu_sram_size, BM_MEM_BL31);
|
bootmem_add_range((uintptr_t)_pmu_sram, REGION_SIZE(pmu_sram),
|
||||||
bootmem_add_range((uintptr_t)_bl31_sram, _bl31_sram_size, BM_MEM_BL31);
|
BM_MEM_BL31);
|
||||||
|
bootmem_add_range((uintptr_t)_bl31_sram, REGION_SIZE(bl31_sram),
|
||||||
|
BM_MEM_BL31);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void soc_read_resources(struct device *dev)
|
static void soc_read_resources(struct device *dev)
|
||||||
|
|
|
@ -88,7 +88,7 @@ static int sdmmc_cbfs_open(void)
|
||||||
* figuring out the true image size from in here. Since this is mainly a
|
* figuring out the true image size from in here. Since this is mainly a
|
||||||
* developer/debug boot mode, those shortcomings should be bearable.
|
* developer/debug boot mode, those shortcomings should be bearable.
|
||||||
*/
|
*/
|
||||||
const u32 count = _cbfs_cache_size / 512;
|
const u32 count = REGION_SIZE(cbfs_cache) / 512;
|
||||||
static int first_run = 1;
|
static int first_run = 1;
|
||||||
int (*irom_load_sdmmc)(u32 start, u32 count, void *dst) =
|
int (*irom_load_sdmmc)(u32 start, u32 count, void *dst) =
|
||||||
*irom_sdmmc_read_blocks_ptr;
|
*irom_sdmmc_read_blocks_ptr;
|
||||||
|
@ -131,7 +131,7 @@ const struct region_device *boot_device_ro(void)
|
||||||
void boot_device_init(void)
|
void boot_device_init(void)
|
||||||
{
|
{
|
||||||
mem_region_device_ro_init(&alternate_rdev, _cbfs_cache,
|
mem_region_device_ro_init(&alternate_rdev, _cbfs_cache,
|
||||||
_cbfs_cache_size);
|
REGION_SIZE(cbfs_cache));
|
||||||
|
|
||||||
if (*iram_secondary_base == SECONDARY_BASE_BOOT_USB) {
|
if (*iram_secondary_base == SECONDARY_BASE_BOOT_USB) {
|
||||||
printk(BIOS_DEBUG, "Using Exynos alternate boot mode USB A-A\n");
|
printk(BIOS_DEBUG, "Using Exynos alternate boot mode USB A-A\n");
|
||||||
|
|
|
@ -179,7 +179,7 @@ void exynos_init_spi_boot_device(void)
|
||||||
{
|
{
|
||||||
boot_slave_regs = (void *)EXYNOS5_SPI1_BASE;
|
boot_slave_regs = (void *)EXYNOS5_SPI1_BASE;
|
||||||
|
|
||||||
mmap_helper_device_init(&mdev, _cbfs_cache, _cbfs_cache_size);
|
mmap_helper_device_init(&mdev, _cbfs_cache, REGION_SIZE(cbfs_cache));
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct region_device *exynos_spi_boot_device(void)
|
const struct region_device *exynos_spi_boot_device(void)
|
||||||
|
|
|
@ -92,7 +92,7 @@ static int sdmmc_cbfs_open(void)
|
||||||
* figuring out the true image size from in here. Since this is mainly a
|
* figuring out the true image size from in here. Since this is mainly a
|
||||||
* developer/debug boot mode, those shortcomings should be bearable.
|
* developer/debug boot mode, those shortcomings should be bearable.
|
||||||
*/
|
*/
|
||||||
const u32 count = _cbfs_cache_size / 512;
|
const u32 count = REGION_SIZE(cbfs_cache) / 512;
|
||||||
static int first_run = 1;
|
static int first_run = 1;
|
||||||
int (*irom_load_sdmmc)(u32 start, u32 count, void *dst) =
|
int (*irom_load_sdmmc)(u32 start, u32 count, void *dst) =
|
||||||
*irom_sdmmc_read_blocks_ptr;
|
*irom_sdmmc_read_blocks_ptr;
|
||||||
|
@ -138,7 +138,7 @@ const struct region_device *boot_device_ro(void)
|
||||||
void boot_device_init(void)
|
void boot_device_init(void)
|
||||||
{
|
{
|
||||||
mem_region_device_ro_init(&alternate_rdev, _cbfs_cache,
|
mem_region_device_ro_init(&alternate_rdev, _cbfs_cache,
|
||||||
_cbfs_cache_size);
|
REGION_SIZE(cbfs_cache));
|
||||||
|
|
||||||
if (*iram_secondary_base == SECONDARY_BASE_BOOT_USB) {
|
if (*iram_secondary_base == SECONDARY_BASE_BOOT_USB) {
|
||||||
printk(BIOS_DEBUG, "Using Exynos alternate boot mode USB A-A\n");
|
printk(BIOS_DEBUG, "Using Exynos alternate boot mode USB A-A\n");
|
||||||
|
|
|
@ -287,7 +287,7 @@ void exynos_init_spi_boot_device(void)
|
||||||
{
|
{
|
||||||
boot_slave = &exynos_spi_slaves[1];
|
boot_slave = &exynos_spi_slaves[1];
|
||||||
|
|
||||||
mmap_helper_device_init(&mdev, _cbfs_cache, _cbfs_cache_size);
|
mmap_helper_device_init(&mdev, _cbfs_cache, REGION_SIZE(cbfs_cache));
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct region_device *exynos_spi_boot_device(void)
|
const struct region_device *exynos_spi_boot_device(void)
|
||||||
|
|
|
@ -16,8 +16,8 @@
|
||||||
#ifndef __CHROMEOS_SYMBOLS_H
|
#ifndef __CHROMEOS_SYMBOLS_H
|
||||||
#define __CHROMEOS_SYMBOLS_H
|
#define __CHROMEOS_SYMBOLS_H
|
||||||
|
|
||||||
extern u8 _watchdog_tombstone[];
|
#include <symbols.h>
|
||||||
extern u8 _ewatchdog_tombstone[];
|
|
||||||
#define _watchdog_tombstone_size (_ewatchdog_tombstone - _watchdog_tombstone)
|
DECLARE_REGION(watchdog_tombstone)
|
||||||
|
|
||||||
#endif /* __CHROMEOS_SYMBOLS_H */
|
#endif /* __CHROMEOS_SYMBOLS_H */
|
||||||
|
|
|
@ -30,7 +30,7 @@ DECLARE_OPTIONAL_REGION(watchdog_tombstone);
|
||||||
|
|
||||||
static void elog_handle_watchdog_tombstone(void *unused)
|
static void elog_handle_watchdog_tombstone(void *unused)
|
||||||
{
|
{
|
||||||
if (!_watchdog_tombstone_size)
|
if (!REGION_SIZE(watchdog_tombstone))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (read32(_watchdog_tombstone) == WATCHDOG_TOMBSTONE_MAGIC)
|
if (read32(_watchdog_tombstone) == WATCHDOG_TOMBSTONE_MAGIC)
|
||||||
|
@ -44,7 +44,7 @@ BOOT_STATE_INIT_ENTRY(BS_POST_DEVICE, BS_ON_ENTRY,
|
||||||
|
|
||||||
void mark_watchdog_tombstone(void)
|
void mark_watchdog_tombstone(void)
|
||||||
{
|
{
|
||||||
assert(_watchdog_tombstone_size);
|
assert(REGION_SIZE(watchdog_tombstone));
|
||||||
write32(_watchdog_tombstone, WATCHDOG_TOMBSTONE_MAGIC);
|
write32(_watchdog_tombstone, WATCHDOG_TOMBSTONE_MAGIC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue