mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-16 17:44:19 +00:00

Provide six initcall levels for drivers/modules initialize HW controllers or runtime arguments during cold boot. The initcall level cold boot execution order: -MTK_EARLY_PLAT_INIT Call before MMU enabled. -MTK_ARCH_INIT MMU Enabled, arch related init(GiC init, interrupt type registration). -MTK_PLAT_SETUP_0_INIT MTK driver init level 0. -MTK_PLAT_SETUP_1_INIT MTK driver init level 1. -MTK_PLAT_RUNTIME_INIT MTK driver init. After this initcall, TF-A handovers to MTK 2nd bootloader. -MTK_PLAT_BL33_DEFER_INIT MTK 2nd bootloader traps to TF-A before handover to rich OS. This initcall executed in the trap handler(boot_to_kernel). Signed-off-by: Leon Chen <leon.chen@mediatek.com> Change-Id: Icd7fe95372441db73c975ccb6ce77a6c529df1cc
58 lines
1.3 KiB
C
58 lines
1.3 KiB
C
/*
|
|
* Copyright (c) 2022, MediaTek Inc. All rights reserved.
|
|
*
|
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
*/
|
|
|
|
#ifndef MTK_MMAP_POOL_H
|
|
#define MTK_MMAP_POOL_H
|
|
|
|
#include <cdefs.h>
|
|
#include <lib/xlat_tables/xlat_tables_compat.h>
|
|
|
|
struct mtk_mmap_descriptor {
|
|
const char *mmap_name;
|
|
const mmap_region_t *mmap_ptr;
|
|
const uint32_t mmap_size;
|
|
};
|
|
|
|
#define MTK_MMAP_SECTION \
|
|
__used \
|
|
__aligned(sizeof(void *)) \
|
|
__section(".mtk_mmap_lists")
|
|
|
|
#define DECLARE_MTK_MMAP_REGIONS(_mmap_array) \
|
|
static const struct mtk_mmap_descriptor _mtk_mmap_descriptor_##_mmap_array \
|
|
__used \
|
|
__aligned(sizeof(void *)) \
|
|
__section(".mtk_mmap_pool") \
|
|
= { \
|
|
.mmap_name = #_mmap_array, \
|
|
.mmap_ptr = _mmap_array, \
|
|
.mmap_size = ARRAY_SIZE(_mmap_array) \
|
|
}
|
|
|
|
#define MAP_BL_RW MAP_REGION_FLAT( \
|
|
DATA_START, \
|
|
BL_END - DATA_START, \
|
|
MT_MEMORY | MT_RW | MT_SECURE)
|
|
|
|
#if SEPARATE_CODE_AND_RODATA
|
|
#define MAP_BL_RO \
|
|
MAP_REGION_FLAT( \
|
|
BL_CODE_BASE, \
|
|
BL_CODE_END - BL_CODE_BASE, \
|
|
MT_CODE | MT_SECURE), \
|
|
MAP_REGION_FLAT( \
|
|
BL_RO_DATA_BASE, \
|
|
BL_RO_DATA_END - BL_RO_DATA_BASE, \
|
|
MT_RO_DATA | MT_SECURE)
|
|
#else
|
|
#define MAP_BL_RO MAP_REGION_FLAT(BL_CODE_BASE, \
|
|
BL_CODE_END - BL_CODE_BASE, \
|
|
MT_CODE | MT_SECURE)
|
|
#endif
|
|
|
|
void mtk_xlat_init(const mmap_region_t *bl_regions);
|
|
|
|
#endif /* MTK_MMAP_POOL_H */
|