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