arm-trusted-firmware/plat/mediatek/include/mtk_mmap_pool.h
Leon Chen 52035dee1a feat(mediatek): introduce mtk init framework
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
2022-08-30 16:47:43 +08:00

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 */