1301d27d9SRadoslaw Biernacki# 25e690269SRuchika Gupta# Copyright (c) 2013-2022, ARM Limited and Contributors. All rights reserved. 3301d27d9SRadoslaw Biernacki# 4301d27d9SRadoslaw Biernacki# SPDX-License-Identifier: BSD-3-Clause 5301d27d9SRadoslaw Biernacki# 6301d27d9SRadoslaw Biernacki 7301d27d9SRadoslaw Biernacki# Use the GICv2 driver on QEMU by default 8301d27d9SRadoslaw BiernackiQEMU_USE_GIC_DRIVER := QEMU_GICV2 9301d27d9SRadoslaw Biernacki 10301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},7) 11301d27d9SRadoslaw Biernacki# ARMv7 Qemu support in trusted firmware expects the Cortex-A15 model. 12301d27d9SRadoslaw Biernacki# Qemu Cortex-A15 model does not implement the virtualization extension. 13301d27d9SRadoslaw Biernacki# For this reason, we cannot set ARM_CORTEX_A15=yes and must define all 14301d27d9SRadoslaw Biernacki# the ARMv7 build directives. 15301d27d9SRadoslaw BiernackiMARCH32_DIRECTIVE := -mcpu=cortex-a15 16301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_LARGE_PAGE_ADDRESSING)) 17301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_GENERIC_TIMER)) 18e7a54033SJerome Forissier$(eval $(call add_define,ARMV7_SUPPORTS_VFP)) 19301d27d9SRadoslaw Biernacki# Qemu expects a BL32 boot stage. 20301d27d9SRadoslaw BiernackiNEED_BL32 := yes 21*6b666936SChen Baozielse 22*6b666936SChen BaoziCTX_INCLUDE_AARCH32_REGS := 0 23*6b666936SChen Baoziifeq (${CTX_INCLUDE_AARCH32_REGS}, 1) 24*6b666936SChen Baozi$(error "This is an AArch64-only port; CTX_INCLUDE_AARCH32_REGS must be disabled") 25*6b666936SChen Baoziendif 26*6b666936SChen Baozi 27*6b666936SChen Baozi# Treating this as a memory-constrained port for now 28*6b666936SChen BaoziUSE_COHERENT_MEM := 0 29*6b666936SChen Baozi 30*6b666936SChen Baozi# This can be overridden depending on CPU(s) used in the QEMU image 31*6b666936SChen BaoziHW_ASSISTED_COHERENCY := 1 32301d27d9SRadoslaw Biernackiendif # ARMv7 33301d27d9SRadoslaw Biernacki 34301d27d9SRadoslaw Biernackiifeq (${SPD},opteed) 35301d27d9SRadoslaw Biernackiadd-lib-optee := yes 36301d27d9SRadoslaw Biernackiendif 37301d27d9SRadoslaw Biernackiifeq ($(AARCH32_SP),optee) 38301d27d9SRadoslaw Biernackiadd-lib-optee := yes 39301d27d9SRadoslaw Biernackiendif 40f58237ccSJens Wiklanderifeq ($(SPMC_OPTEE),1) 41f58237ccSJens Wiklander$(eval $(call add_define,SPMC_OPTEE)) 42f58237ccSJens Wiklanderadd-lib-optee := yes 43f58237ccSJens Wiklanderendif 44301d27d9SRadoslaw Biernacki 45301d27d9SRadoslaw Biernackiinclude lib/libfdt/libfdt.mk 46301d27d9SRadoslaw Biernacki 47301d27d9SRadoslaw Biernackiifeq ($(NEED_BL32),yes) 48301d27d9SRadoslaw Biernacki$(eval $(call add_define,QEMU_LOAD_BL32)) 49301d27d9SRadoslaw Biernackiendif 50301d27d9SRadoslaw Biernacki 51301d27d9SRadoslaw BiernackiPLAT_QEMU_PATH := plat/qemu/qemu 52301d27d9SRadoslaw BiernackiPLAT_QEMU_COMMON_PATH := plat/qemu/common 53301d27d9SRadoslaw BiernackiPLAT_INCLUDES := -Iinclude/plat/arm/common/ \ 54301d27d9SRadoslaw Biernacki -I${PLAT_QEMU_COMMON_PATH}/include \ 55301d27d9SRadoslaw Biernacki -I${PLAT_QEMU_PATH}/include \ 56301d27d9SRadoslaw Biernacki -Iinclude/common/tbbr 57301d27d9SRadoslaw Biernacki 58301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},8) 59301d27d9SRadoslaw BiernackiPLAT_INCLUDES += -Iinclude/plat/arm/common/${ARCH} 60*6b666936SChen Baozi 61*6b666936SChen BaoziQEMU_CPU_LIBS := lib/cpus/aarch64/aem_generic.S \ 62*6b666936SChen Baozi lib/cpus/aarch64/cortex_a53.S \ 63*6b666936SChen Baozi lib/cpus/aarch64/cortex_a57.S \ 64*6b666936SChen Baozi lib/cpus/aarch64/cortex_a72.S \ 65*6b666936SChen Baozi lib/cpus/aarch64/cortex_a76.S \ 66*6b666936SChen Baozi lib/cpus/aarch64/neoverse_n_common.S \ 67*6b666936SChen Baozi lib/cpus/aarch64/neoverse_n1.S \ 68*6b666936SChen Baozi lib/cpus/aarch64/qemu_max.S 69*6b666936SChen Baozielse 70*6b666936SChen BaoziQEMU_CPU_LIBS := lib/cpus/${ARCH}/cortex_a15.S 71301d27d9SRadoslaw Biernackiendif 72301d27d9SRadoslaw Biernacki 73301d27d9SRadoslaw BiernackiPLAT_BL_COMMON_SOURCES := ${PLAT_QEMU_COMMON_PATH}/qemu_common.c \ 74301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_console.c \ 75301d27d9SRadoslaw Biernacki drivers/arm/pl011/${ARCH}/pl011_console.S 76301d27d9SRadoslaw Biernacki 77301d27d9SRadoslaw Biernackiinclude lib/xlat_tables_v2/xlat_tables.mk 78301d27d9SRadoslaw BiernackiPLAT_BL_COMMON_SOURCES += ${XLAT_TABLES_LIB_SRCS} 79301d27d9SRadoslaw Biernacki 80301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 81301d27d9SRadoslaw Biernacki 82301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 83301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 84ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 85301d27d9SRadoslaw Biernacki 86301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 87301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 88301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 89301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 90ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 91ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 92301d27d9SRadoslaw Biernacki 93301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 94301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 95301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 96ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 97ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 98301d27d9SRadoslaw Biernacki 995e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 1005e690269SRuchika Gupta 101301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 102301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 103301d27d9SRadoslaw Biernacki 104301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 105301d27d9SRadoslaw Biernacki 106301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 107301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 108301d27d9SRadoslaw Biernacki 109301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 110301d27d9SRadoslaw Biernacki 111dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 112301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 113e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 114301d27d9SRadoslaw Biernacki 115301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 116301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 117e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 118e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 119301d27d9SRadoslaw Biernackiendif 120301d27d9SRadoslaw Biernacki 1215e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 1225e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 1235e690269SRuchika Gupta# flags present in Measured Boot makefile. 1245e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 1255e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 1265e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 1275e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 1285e690269SRuchika Gupta 129a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 130a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 131a58cfefbSlaurenw-arm endif 132a58cfefbSlaurenw-arm 1335e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1345e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1355e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1365e690269SRuchika Gupta 1375e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1385e690269SRuchika Gupta 1395e690269SRuchika Guptaendif 1405e690269SRuchika Gupta 1415e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1425e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1435e690269SRuchika Gupta 1445e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1455e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1465e690269SRuchika Gupta 1475e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1485e690269SRuchika Gupta # 1495e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1505e690269SRuchika Guptaendif 1515e690269SRuchika Gupta 152301d27d9SRadoslaw BiernackiBL1_SOURCES += drivers/io/io_semihosting.c \ 153301d27d9SRadoslaw Biernacki drivers/io/io_storage.c \ 154301d27d9SRadoslaw Biernacki drivers/io/io_fip.c \ 155301d27d9SRadoslaw Biernacki drivers/io/io_memmap.c \ 156301d27d9SRadoslaw Biernacki lib/semihosting/semihosting.c \ 157301d27d9SRadoslaw Biernacki lib/semihosting/${ARCH}/semihosting_call.S \ 158301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_io_storage.c \ 159301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/${ARCH}/plat_helpers.S \ 160*6b666936SChen Baozi ${PLAT_QEMU_COMMON_PATH}/qemu_bl1_setup.c \ 161*6b666936SChen Baozi ${QEMU_CPU_LIBS} 162301d27d9SRadoslaw Biernacki 163301d27d9SRadoslaw BiernackiBL2_SOURCES += drivers/io/io_semihosting.c \ 164301d27d9SRadoslaw Biernacki drivers/io/io_storage.c \ 165301d27d9SRadoslaw Biernacki drivers/io/io_fip.c \ 166301d27d9SRadoslaw Biernacki drivers/io/io_memmap.c \ 167301d27d9SRadoslaw Biernacki lib/semihosting/semihosting.c \ 168301d27d9SRadoslaw Biernacki lib/semihosting/${ARCH}/semihosting_call.S \ 169301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_io_storage.c \ 170301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/${ARCH}/plat_helpers.S \ 171301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl2_setup.c \ 172301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl2_mem_params_desc.c \ 173301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_image_load.c \ 174301d27d9SRadoslaw Biernacki common/fdt_fixup.c \ 1755e690269SRuchika Gupta common/fdt_wrappers.c \ 17636802e2cSJens Wiklander common/desc_image_load.c \ 17736802e2cSJens Wiklander common/uuid.c 178301d27d9SRadoslaw Biernacki 179301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 180301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 181301d27d9SRadoslaw Biernackiendif 182301d27d9SRadoslaw Biernacki 18351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18451857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 18551857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 18651857762SSumit Gargendif 18751857762SSumit Garg 188d799d168SLeif Lindholm# Include GICv2 driver files 189d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 190d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 191301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 192301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 193301d27d9SRadoslaw Biernacki 194a6ea06f5SAlexei Fedorov# Include GICv3 driver files 195a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 196a6ea06f5SAlexei Fedorov 197a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 198301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 199301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 200301d27d9SRadoslaw Biernacki 201301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 202301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 203301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 204301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 205301d27d9SRadoslaw Biernackielse 206301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 207301d27d9SRadoslaw Biernackiendif 208301d27d9SRadoslaw Biernacki 209301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},8) 210*6b666936SChen BaoziBL31_SOURCES += ${QEMU_CPU_LIBS} \ 21161cbd41dSAndrew Walbran lib/semihosting/semihosting.c \ 21261cbd41dSAndrew Walbran lib/semihosting/${ARCH}/semihosting_call.S \ 213301d27d9SRadoslaw Biernacki plat/common/plat_psci_common.c \ 214ffb07b04SMaxim Uvarov drivers/arm/pl061/pl061_gpio.c \ 215ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 216301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 217301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/topology.c \ 218301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/aarch64/plat_helpers.S \ 219301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl31_setup.c \ 220301d27d9SRadoslaw Biernacki ${QEMU_GIC_SOURCES} 221f58237ccSJens Wiklander 222cffc956eSLeo Yan# Pointer Authentication sources 223cffc956eSLeo Yanifeq (${ENABLE_PAUTH}, 1) 224cffc956eSLeo YanPLAT_BL_COMMON_SOURCES += plat/arm/common/aarch64/arm_pauth.c \ 225cffc956eSLeo Yan lib/extensions/pauth/pauth_helpers.S 226cffc956eSLeo Yanendif 227cffc956eSLeo Yan 228f58237ccSJens Wiklanderifeq (${SPD},spmd) 22925ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 23025ae7ad1SJens Wiklander common/uuid.c \ 23125ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 23225ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 233f58237ccSJens Wiklanderendif 234301d27d9SRadoslaw Biernackiendif 235301d27d9SRadoslaw Biernacki 236301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 237301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 238301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 23951857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 24051857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 24151857762SSumit Gargelse 242301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 243301d27d9SRadoslaw Biernackiendif 24451857762SSumit Gargendif 245301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 24651857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 24751857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 24851857762SSumit Gargelse 249301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 250301d27d9SRadoslaw Biernackiendif 25151857762SSumit Gargendif 252301d27d9SRadoslaw Biernacki 25336802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 25436802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 25536802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 25636802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 25736802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 25836802e2cSJens Wiklanderendif 25936802e2cSJens Wiklander 26025ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 26125ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 26225ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 26325ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 26425ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 26525ae7ad1SJens Wiklanderendif 26625ae7ad1SJens Wiklander 267301d27d9SRadoslaw BiernackiSEPARATE_CODE_AND_RODATA := 1 268301d27d9SRadoslaw BiernackiENABLE_STACK_PROTECTOR := 0 269301d27d9SRadoslaw Biernackiifneq ($(ENABLE_STACK_PROTECTOR), 0) 270301d27d9SRadoslaw Biernacki PLAT_BL_COMMON_SOURCES += ${PLAT_QEMU_COMMON_PATH}/qemu_stack_protector.c 271301d27d9SRadoslaw Biernackiendif 272301d27d9SRadoslaw Biernacki 273301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 274301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 275301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 276301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 277301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 278301d27d9SRadoslaw Biernackielse 279301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 280301d27d9SRadoslaw Biernackiendif 281301d27d9SRadoslaw Biernacki 282301d27d9SRadoslaw Biernacki# Process flags 283301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 284301d27d9SRadoslaw Biernacki 28574464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 28674464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 28774464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 28874464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 28974464d5bSAndrew Walbran 29074464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 29174464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 29274464d5bSAndrew Walbran 293337ff4f1SAndre Przywara# Later QEMU versions support SME and SVE. 294337ff4f1SAndre Przywaraifneq (${ARCH},aarch32) 295337ff4f1SAndre Przywara ENABLE_SVE_FOR_NS := 1 296337ff4f1SAndre Przywara ENABLE_SME_FOR_NS := 1 297337ff4f1SAndre Przywaraendif 298