1301d27d9SRadoslaw Biernacki# 2fc259b6cSJayanth Dodderi Chidanand# Copyright (c) 2013-2023, Arm Limited and Contributors. All rights reserved. 3301d27d9SRadoslaw Biernacki# 4301d27d9SRadoslaw Biernacki# SPDX-License-Identifier: BSD-3-Clause 5301d27d9SRadoslaw Biernacki# 6301d27d9SRadoslaw Biernacki 7886688d1SMarcin JuszkiewiczPLAT_QEMU_PATH := plat/qemu/qemu 8886688d1SMarcin JuszkiewiczPLAT_QEMU_COMMON_PATH := plat/qemu/common 9886688d1SMarcin Juszkiewicz 10a63cdc74SMarcin Juszkiewiczinclude plat/qemu/common/common.mk 11a63cdc74SMarcin Juszkiewicz 12301d27d9SRadoslaw Biernacki# Use the GICv2 driver on QEMU by default 13301d27d9SRadoslaw BiernackiQEMU_USE_GIC_DRIVER := QEMU_GICV2 14301d27d9SRadoslaw Biernacki 15301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},7) 16301d27d9SRadoslaw Biernacki# ARMv7 Qemu support in trusted firmware expects the Cortex-A15 model. 17301d27d9SRadoslaw Biernacki# Qemu Cortex-A15 model does not implement the virtualization extension. 18301d27d9SRadoslaw Biernacki# For this reason, we cannot set ARM_CORTEX_A15=yes and must define all 19301d27d9SRadoslaw Biernacki# the ARMv7 build directives. 20d4089fb8SGovindraj RajaMARCH_DIRECTIVE := -mcpu=cortex-a15 21301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_LARGE_PAGE_ADDRESSING)) 22301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_GENERIC_TIMER)) 23e7a54033SJerome Forissier$(eval $(call add_define,ARMV7_SUPPORTS_VFP)) 24301d27d9SRadoslaw Biernacki# Qemu expects a BL32 boot stage. 25301d27d9SRadoslaw BiernackiNEED_BL32 := yes 266b666936SChen Baozielse 276b666936SChen BaoziCTX_INCLUDE_AARCH32_REGS := 0 286b666936SChen Baoziifeq (${CTX_INCLUDE_AARCH32_REGS}, 1) 296b666936SChen Baozi$(error "This is an AArch64-only port; CTX_INCLUDE_AARCH32_REGS must be disabled") 306b666936SChen Baoziendif 316b666936SChen Baozi 326b666936SChen Baozi# Treating this as a memory-constrained port for now 336b666936SChen BaoziUSE_COHERENT_MEM := 0 346b666936SChen Baozi 356b666936SChen Baozi# This can be overridden depending on CPU(s) used in the QEMU image 366b666936SChen BaoziHW_ASSISTED_COHERENCY := 1 37301d27d9SRadoslaw Biernackiendif # ARMv7 38301d27d9SRadoslaw Biernacki 39301d27d9SRadoslaw Biernackiifeq (${SPD},opteed) 40301d27d9SRadoslaw Biernackiadd-lib-optee := yes 41301d27d9SRadoslaw Biernackiendif 42301d27d9SRadoslaw Biernackiifeq ($(AARCH32_SP),optee) 43301d27d9SRadoslaw Biernackiadd-lib-optee := yes 44301d27d9SRadoslaw Biernackiendif 45f58237ccSJens Wiklanderifeq ($(SPMC_OPTEE),1) 46f58237ccSJens Wiklander$(eval $(call add_define,SPMC_OPTEE)) 47f58237ccSJens Wiklanderadd-lib-optee := yes 48f58237ccSJens Wiklanderendif 49301d27d9SRadoslaw Biernacki 50301d27d9SRadoslaw Biernackiifeq ($(NEED_BL32),yes) 51301d27d9SRadoslaw Biernacki$(eval $(call add_define,QEMU_LOAD_BL32)) 52301d27d9SRadoslaw Biernackiendif 53301d27d9SRadoslaw Biernacki 54301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 55301d27d9SRadoslaw Biernacki 56301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 57301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 58ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 59301d27d9SRadoslaw Biernacki 60301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 61301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 62301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 63301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 64ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 65ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 66301d27d9SRadoslaw Biernacki 67301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 68301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 69301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 70ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 71ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 72301d27d9SRadoslaw Biernacki 735e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 745e690269SRuchika Gupta 75301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 76301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 77301d27d9SRadoslaw Biernacki 78301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 79301d27d9SRadoslaw Biernacki 80301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 81301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 82301d27d9SRadoslaw Biernacki 83301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 84301d27d9SRadoslaw Biernacki 85dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 86301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 87e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 88301d27d9SRadoslaw Biernacki 89301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 90301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 91e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 92e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 93301d27d9SRadoslaw Biernackiendif 94301d27d9SRadoslaw Biernacki 955e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 965e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 975e690269SRuchika Gupta# flags present in Measured Boot makefile. 985e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 995e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 1005e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 1015e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 1025e690269SRuchika Gupta 103a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 104a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 105a58cfefbSlaurenw-arm endif 106a58cfefbSlaurenw-arm 1075e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1085e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1095e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1105e690269SRuchika Gupta 1115e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1125e690269SRuchika Gupta 1135e690269SRuchika Guptaendif 1145e690269SRuchika Gupta 1155e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1165e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1175e690269SRuchika Gupta 1185e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1195e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1205e690269SRuchika Gupta 1215e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1225e690269SRuchika Gupta # 1235e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1245e690269SRuchika Guptaendif 1255e690269SRuchika Gupta 126*71f5359bSMarcin JuszkiewiczBL2_SOURCES += ${FDT_WRAPPERS_SOURCES} \ 12736802e2cSJens Wiklander common/uuid.c 128301d27d9SRadoslaw Biernacki 129301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 130301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 131301d27d9SRadoslaw Biernackiendif 132301d27d9SRadoslaw Biernacki 13351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 13451857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 13551857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 13651857762SSumit Gargendif 13751857762SSumit Garg 138d799d168SLeif Lindholm# Include GICv2 driver files 139d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 140d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 141301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 142301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 143301d27d9SRadoslaw Biernacki 144a6ea06f5SAlexei Fedorov# Include GICv3 driver files 145a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 146a6ea06f5SAlexei Fedorov 147a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 148301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 149301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 150301d27d9SRadoslaw Biernacki 151301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 152301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 153301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 154301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 155301d27d9SRadoslaw Biernackielse 156301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 157301d27d9SRadoslaw Biernackiendif 158301d27d9SRadoslaw Biernacki 159301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},8) 1606b666936SChen BaoziBL31_SOURCES += ${QEMU_CPU_LIBS} \ 16161cbd41dSAndrew Walbran lib/semihosting/semihosting.c \ 16261cbd41dSAndrew Walbran lib/semihosting/${ARCH}/semihosting_call.S \ 163301d27d9SRadoslaw Biernacki plat/common/plat_psci_common.c \ 164ffb07b04SMaxim Uvarov drivers/arm/pl061/pl061_gpio.c \ 165ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 166301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 167301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/topology.c \ 168301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/aarch64/plat_helpers.S \ 169301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl31_setup.c \ 170301d27d9SRadoslaw Biernacki ${QEMU_GIC_SOURCES} 171f58237ccSJens Wiklander 172cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 173cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 174cef76a7cSDongjiu Gengendif 175cef76a7cSDongjiu Geng 176cffc956eSLeo Yan# Pointer Authentication sources 177cffc956eSLeo Yanifeq (${ENABLE_PAUTH}, 1) 178c68736daSRebecca CranPLAT_BL_COMMON_SOURCES += plat/arm/common/aarch64/arm_pauth.c \ 179c68736daSRebecca Cran lib/extensions/pauth/pauth_helpers.S 180cffc956eSLeo Yanendif 181cffc956eSLeo Yan 182f58237ccSJens Wiklanderifeq (${SPD},spmd) 18325ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 18425ae7ad1SJens Wiklander common/uuid.c \ 18525ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 18625ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 187f58237ccSJens Wiklanderendif 188301d27d9SRadoslaw Biernackiendif 189301d27d9SRadoslaw Biernacki 190301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 191301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 192301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 19351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 19451857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 19551857762SSumit Gargelse 196301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 197301d27d9SRadoslaw Biernackiendif 19851857762SSumit Gargendif 199301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 20051857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 20151857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 20251857762SSumit Gargelse 203301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 204301d27d9SRadoslaw Biernackiendif 20551857762SSumit Gargendif 206301d27d9SRadoslaw Biernacki 20736802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 20836802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 20936802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 21036802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 21136802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 21236802e2cSJens Wiklanderendif 21336802e2cSJens Wiklander 21425ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 21525ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 21625ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 21725ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 21825ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 21925ae7ad1SJens Wiklanderendif 22025ae7ad1SJens Wiklander 221301d27d9SRadoslaw BiernackiSEPARATE_CODE_AND_RODATA := 1 222301d27d9SRadoslaw BiernackiENABLE_STACK_PROTECTOR := 0 223301d27d9SRadoslaw Biernacki 224301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 225301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 226301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 227301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 228301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 229301d27d9SRadoslaw Biernackielse 230301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 231301d27d9SRadoslaw Biernackiendif 232301d27d9SRadoslaw Biernacki 233301d27d9SRadoslaw Biernacki# Process flags 234301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 235301d27d9SRadoslaw Biernacki 23674464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 23774464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 23874464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 23974464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 24074464d5bSAndrew Walbran 24174464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 24274464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 24374464d5bSAndrew Walbran 244ac17e52cSAndre Przywara# QEMU will use the RNDR instruction for the stack protector canary. 245ac17e52cSAndre PrzywaraENABLE_FEAT_RNG := 2 246ac17e52cSAndre Przywara 247337ff4f1SAndre Przywara# Later QEMU versions support SME and SVE. 248337ff4f1SAndre Przywaraifneq (${ARCH},aarch32) 249fc259b6cSJayanth Dodderi Chidanand ENABLE_SVE_FOR_NS := 2 250fc259b6cSJayanth Dodderi Chidanand ENABLE_SME_FOR_NS := 2 251337ff4f1SAndre Przywaraendif 25263bb9056SAndre Przywara 25363bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 25463bb9056SAndre Przywara $(ECHO) " DD $@" 25563bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 25663bb9056SAndre Przywara $(Q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 25763bb9056SAndre Przywara 25863bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 25963bb9056SAndre Przywara $(ECHO) " DD $@" 26063bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 26163bb9056SAndre Przywara $(Q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 26263bb9056SAndre Przywara 26363bb9056SAndre Przywaraifneq (${BL33},) 26463bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 26563bb9056SAndre Przywaraendif 266cef76a7cSDongjiu Geng 267cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 268cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 269cef76a7cSDongjiu Gengendif 270