1PLATFORM_FLAVOR ?= ls1021atwr 2 3$(call force,CFG_SECURE_TIME_SOURCE_CNTPCT,y) 4$(call force,CFG_GIC,y) 5$(call force,CFG_16550_UART,y) 6$(call force,CFG_LS,y) 7 8$(call force,CFG_DRAM0_BASE,0x80000000) 9$(call force,CFG_TEE_OS_DRAM0_SIZE,0x4000000) 10 11ifeq ($(PLATFORM_FLAVOR),ls1021atwr) 12include core/arch/arm/cpu/cortex-a7.mk 13$(call force,CFG_TEE_CORE_NB_CORE,2) 14$(call force,CFG_DRAM0_SIZE,0x40000000) 15$(call force,CFG_CORE_CLUSTER_SHIFT,2) 16CFG_SHMEM_SIZE ?= 0x00100000 17CFG_BOOT_SYNC_CPU ?= y 18CFG_BOOT_SECONDARY_REQUEST ?= y 19endif 20 21ifeq ($(PLATFORM_FLAVOR),ls1021aqds) 22include core/arch/arm/cpu/cortex-a7.mk 23$(call force,CFG_TEE_CORE_NB_CORE,2) 24$(call force,CFG_DRAM0_SIZE,0x80000000) 25$(call force,CFG_CORE_CLUSTER_SHIFT,2) 26CFG_SHMEM_SIZE ?= 0x00100000 27CFG_BOOT_SYNC_CPU ?= y 28CFG_BOOT_SECONDARY_REQUEST ?= y 29endif 30 31ifeq ($(PLATFORM_FLAVOR),ls1012ardb) 32include core/arch/arm/cpu/cortex-armv8-0.mk 33$(call force,CFG_TEE_CORE_NB_CORE,1) 34$(call force,CFG_DRAM0_SIZE,0x40000000) 35$(call force,CFG_CORE_CLUSTER_SHIFT,2) 36CFG_NUM_THREADS ?= 2 37CFG_SHMEM_SIZE ?= 0x00200000 38endif 39 40ifeq ($(PLATFORM_FLAVOR),ls1012afrwy) 41include core/arch/arm/cpu/cortex-armv8-0.mk 42$(call force,CFG_TEE_CORE_NB_CORE,1) 43$(call force,CFG_CORE_CLUSTER_SHIFT,2) 44CFG_DRAM0_SIZE ?= 0x20000000 45CFG_SHMEM_SIZE ?= 0x00200000 46endif 47 48ifeq ($(PLATFORM_FLAVOR),ls1043ardb) 49include core/arch/arm/cpu/cortex-armv8-0.mk 50$(call force,CFG_TEE_CORE_NB_CORE,4) 51$(call force,CFG_DRAM0_SIZE,0x80000000) 52$(call force,CFG_CORE_CLUSTER_SHIFT,2) 53CFG_SHMEM_SIZE ?= 0x00200000 54endif 55 56ifeq ($(PLATFORM_FLAVOR),ls1046ardb) 57include core/arch/arm/cpu/cortex-armv8-0.mk 58$(call force,CFG_TEE_CORE_NB_CORE,4) 59$(call force,CFG_DRAM0_SIZE,0x80000000) 60$(call force,CFG_CORE_CLUSTER_SHIFT,2) 61CFG_SHMEM_SIZE ?= 0x00200000 62endif 63 64ifeq ($(PLATFORM_FLAVOR),ls1088ardb) 65include core/arch/arm/cpu/cortex-armv8-0.mk 66$(call force,CFG_TEE_CORE_NB_CORE,8) 67$(call force,CFG_DRAM0_SIZE,0x80000000) 68$(call force,CFG_CORE_CLUSTER_SHIFT,2) 69$(call force,CFG_ARM_GICV3,y) 70CFG_SHMEM_SIZE ?= 0x00200000 71endif 72 73ifeq ($(PLATFORM_FLAVOR),ls2088ardb) 74include core/arch/arm/cpu/cortex-armv8-0.mk 75$(call force,CFG_TEE_CORE_NB_CORE,8) 76$(call force,CFG_DRAM0_SIZE,0x80000000) 77$(call force,CFG_CORE_CLUSTER_SHIFT,1) 78$(call force,CFG_ARM_GICV3,y) 79CFG_SHMEM_SIZE ?= 0x00200000 80endif 81 82ifeq ($(PLATFORM_FLAVOR),lx2160aqds) 83include core/arch/arm/cpu/cortex-armv8-0.mk 84$(call force,CFG_TEE_CORE_NB_CORE,16) 85$(call force,CFG_DRAM0_SIZE,0x80000000) 86$(call force,CFG_DRAM1_BASE,0x2080000000) 87$(call force,CFG_DRAM1_SIZE,0x1F80000000) 88$(call force,CFG_CORE_CLUSTER_SHIFT,1) 89$(call force,CFG_ARM_GICV3,y) 90$(call force,CFG_PL011,y) 91$(call force,CFG_CORE_ARM64_PA_BITS,48) 92$(call force,CFG_EMBED_DTB,y) 93$(call force,CFG_EMBED_DTB_SOURCE_FILE,fsl-lx2160a-qds.dts) 94CFG_LS_I2C ?= y 95CFG_LS_GPIO ?= y 96CFG_LS_DSPI ?= y 97CFG_SHMEM_SIZE ?= 0x00200000 98endif 99 100ifeq ($(PLATFORM_FLAVOR),lx2160ardb) 101include core/arch/arm/cpu/cortex-armv8-0.mk 102$(call force,CFG_TEE_CORE_NB_CORE,16) 103$(call force,CFG_DRAM0_SIZE,0x80000000) 104$(call force,CFG_DRAM1_BASE,0x2080000000) 105$(call force,CFG_DRAM1_SIZE,0x1F80000000) 106$(call force,CFG_CORE_CLUSTER_SHIFT,1) 107$(call force,CFG_ARM_GICV3,y) 108$(call force,CFG_PL011,y) 109$(call force,CFG_CORE_ARM64_PA_BITS,48) 110$(call force,CFG_EMBED_DTB,y) 111$(call force,CFG_EMBED_DTB_SOURCE_FILE,fsl-lx2160a-rdb.dts) 112CFG_LS_I2C ?= y 113CFG_LS_GPIO ?= y 114CFG_LS_DSPI ?= y 115CFG_SHMEM_SIZE ?= 0x00200000 116endif 117 118ifeq ($(PLATFORM_FLAVOR),ls1028ardb) 119include core/arch/arm/cpu/cortex-armv8-0.mk 120$(call force,CFG_TEE_CORE_NB_CORE,2) 121$(call force,CFG_DRAM0_SIZE,0x80000000) 122$(call force,CFG_CORE_CLUSTER_SHIFT,1) 123$(call force,CFG_ARM_GICV3,y) 124CFG_SHMEM_SIZE ?= 0x00200000 125endif 126 127ifeq ($(platform-flavor-armv8),1) 128$(call force,CFG_WITH_ARM_TRUSTED_FW,y) 129CFG_TZDRAM_START ?= ((CFG_DRAM0_BASE + CFG_DRAM0_SIZE) - CFG_TEE_OS_DRAM0_SIZE) 130CFG_TZDRAM_SIZE ?= ( CFG_TEE_OS_DRAM0_SIZE - CFG_SHMEM_SIZE) 131#CFG_SHMEM_START (Non-Secure shared memory) needs to be 2MB aligned boundary for TZASC 380 configuration. 132CFG_SHMEM_START ?= ((CFG_DRAM0_BASE + CFG_DRAM0_SIZE) - CFG_SHMEM_SIZE) 133$(call force,CFG_ARM64_core,y) 134CFG_USER_TA_TARGETS ?= ta_arm64 135else 136#In ARMv7 platform CFG_SHMEM_SIZE is different to that of ARMv8 platforms. 137CFG_TZDRAM_START ?= ((CFG_DRAM0_BASE + CFG_DRAM0_SIZE) - CFG_TEE_OS_DRAM0_SIZE) 138CFG_TZDRAM_SIZE ?= ( CFG_TEE_OS_DRAM0_SIZE - (2*CFG_SHMEM_SIZE)) 139#CFG_SHMEM_START (Non-Secure shared memory) needs to be 2MB aligned boundary for TZASC 380 configuration. 140CFG_SHMEM_START ?= ((CFG_DRAM0_BASE + CFG_DRAM0_SIZE) - (2*CFG_SHMEM_SIZE)) 141endif 142 143#Keeping Number of TEE thread equal to number of cores on the SoC 144CFG_NUM_THREADS ?= CFG_TEE_CORE_NB_CORE 145 146ifneq ($(CFG_ARM64_core),y) 147$(call force,CFG_SECONDARY_INIT_CNTFRQ,y) 148endif 149 150CFG_CRYPTO_SIZE_OPTIMIZATION ?= n 151 152# NXP CAAM support is not enabled by default and can be enabled 153# on the command line 154CFG_NXP_CAAM ?= n 155 156ifeq ($(CFG_NXP_CAAM),y) 157# If NXP CAAM Driver is supported, the Crypto Driver interfacing 158# it with generic crypto API can be enabled. 159CFG_CRYPTO_DRIVER ?= y 160CFG_CRYPTO_DRIVER_DEBUG ?= 0 161else 162$(call force,CFG_CRYPTO_DRIVER,n) 163$(call force,CFG_WITH_SOFTWARE_PRNG,y) 164endif 165 166# Cryptographic configuration 167include core/arch/arm/plat-ls/crypto_conf.mk 168