123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- #ifndef COMMON_DEF_H
- #define COMMON_DEF_H
- #include <common/bl_common.h>
- #include <lib/utils_def.h>
- #include <lib/xlat_tables/xlat_tables_defs.h>
- #include <platform_def.h>
- #ifdef __aarch64__
- #define SZ_32 UL(0x00000020)
- #define SZ_64 UL(0x00000040)
- #define SZ_128 UL(0x00000080)
- #define SZ_256 UL(0x00000100)
- #define SZ_512 UL(0x00000200)
- #define SZ_1K UL(0x00000400)
- #define SZ_2K UL(0x00000800)
- #define SZ_4K UL(0x00001000)
- #define SZ_8K UL(0x00002000)
- #define SZ_16K UL(0x00004000)
- #define SZ_32K UL(0x00008000)
- #define SZ_64K UL(0x00010000)
- #define SZ_128K UL(0x00020000)
- #define SZ_256K UL(0x00040000)
- #define SZ_512K UL(0x00080000)
- #define SZ_1M UL(0x00100000)
- #define SZ_2M UL(0x00200000)
- #define SZ_4M UL(0x00400000)
- #define SZ_8M UL(0x00800000)
- #define SZ_16M UL(0x01000000)
- #define SZ_32M UL(0x02000000)
- #define SZ_64M UL(0x04000000)
- #define SZ_128M UL(0x08000000)
- #define SZ_256M UL(0x10000000)
- #define SZ_512M UL(0x20000000)
- #define SZ_1G UL(0x40000000)
- #define SZ_2G UL(0x80000000)
- #else
- #define SZ_32 U(0x00000020)
- #define SZ_64 U(0x00000040)
- #define SZ_128 U(0x00000080)
- #define SZ_256 U(0x00000100)
- #define SZ_512 U(0x00000200)
- #define SZ_1K U(0x00000400)
- #define SZ_2K U(0x00000800)
- #define SZ_4K U(0x00001000)
- #define SZ_8K U(0x00002000)
- #define SZ_16K U(0x00004000)
- #define SZ_32K U(0x00008000)
- #define SZ_64K U(0x00010000)
- #define SZ_128K U(0x00020000)
- #define SZ_256K U(0x00040000)
- #define SZ_512K U(0x00080000)
- #define SZ_1M U(0x00100000)
- #define SZ_2M U(0x00200000)
- #define SZ_4M U(0x00400000)
- #define SZ_8M U(0x00800000)
- #define SZ_16M U(0x01000000)
- #define SZ_32M U(0x02000000)
- #define SZ_64M U(0x04000000)
- #define SZ_128M U(0x08000000)
- #define SZ_256M U(0x10000000)
- #define SZ_512M U(0x20000000)
- #define SZ_1G U(0x40000000)
- #define SZ_2G U(0x80000000)
- #endif
- #ifdef __aarch64__
- #define PLATFORM_LINKER_FORMAT "elf64-littleaarch64"
- #define PLATFORM_LINKER_ARCH aarch64
- #else
- #define PLATFORM_LINKER_FORMAT "elf32-littlearm"
- #define PLATFORM_LINKER_ARCH arm
- #endif
- #define FIRMWARE_WELCOME_STR "Booting Trusted Firmware\n"
- #define BL2_IMAGE_DESC { \
- .image_id = BL2_IMAGE_ID, \
- SET_STATIC_PARAM_HEAD(image_info, PARAM_EP, \
- VERSION_2, image_info_t, 0), \
- .image_info.image_base = BL2_BASE, \
- .image_info.image_max_size = BL2_LIMIT - BL2_BASE,\
- SET_STATIC_PARAM_HEAD(ep_info, PARAM_EP, \
- VERSION_2, entry_point_info_t, SECURE | EXECUTABLE),\
- .ep_info.pc = BL2_BASE, \
- }
- #if SEPARATE_CODE_AND_RODATA
- #define BL1_CODE_END BL_CODE_END
- #define BL1_RO_DATA_BASE BL_RO_DATA_BASE
- #define BL1_RO_DATA_END round_up(BL1_ROM_END, PAGE_SIZE)
- #if BL2_IN_XIP_MEM
- #define BL2_CODE_END BL_CODE_END
- #define BL2_RO_DATA_BASE BL_RO_DATA_BASE
- #define BL2_RO_DATA_END round_up(BL2_ROM_END, PAGE_SIZE)
- #endif
- #else
- #define BL_RO_DATA_BASE UL(0)
- #define BL_RO_DATA_END UL(0)
- #define BL1_CODE_END round_up(BL1_ROM_END, PAGE_SIZE)
- #if BL2_IN_XIP_MEM
- #define BL2_RO_DATA_BASE UL(0)
- #define BL2_RO_DATA_END UL(0)
- #define BL2_CODE_END round_up(BL2_ROM_END, PAGE_SIZE)
- #endif
- #endif
- #if MEASURED_BOOT
- #define CRITICAL_DATA_ID_BASE U(0x80000000)
- #endif
- #endif
|