1301d27d9SRadoslaw Biernacki# 2*142ee34eSLauren Wehrmeister# Copyright (c) 2013-2025, 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 104a2e7547SMarcin JuszkiewiczSEPARATE_CODE_AND_RODATA := 1 114a2e7547SMarcin JuszkiewiczENABLE_STACK_PROTECTOR := 0 124a2e7547SMarcin Juszkiewicz 13a63cdc74SMarcin Juszkiewiczinclude plat/qemu/common/common.mk 14a63cdc74SMarcin Juszkiewicz 15301d27d9SRadoslaw Biernacki# Use the GICv2 driver on QEMU by default 16301d27d9SRadoslaw BiernackiQEMU_USE_GIC_DRIVER := QEMU_GICV2 17301d27d9SRadoslaw Biernacki 18301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},7) 19301d27d9SRadoslaw Biernacki# ARMv7 Qemu support in trusted firmware expects the Cortex-A15 model. 20301d27d9SRadoslaw Biernacki# Qemu Cortex-A15 model does not implement the virtualization extension. 21301d27d9SRadoslaw Biernacki# For this reason, we cannot set ARM_CORTEX_A15=yes and must define all 22301d27d9SRadoslaw Biernacki# the ARMv7 build directives. 23d4089fb8SGovindraj RajaMARCH_DIRECTIVE := -mcpu=cortex-a15 24301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_LARGE_PAGE_ADDRESSING)) 25301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_GENERIC_TIMER)) 26e7a54033SJerome Forissier$(eval $(call add_define,ARMV7_SUPPORTS_VFP)) 27301d27d9SRadoslaw Biernacki# Qemu expects a BL32 boot stage. 28301d27d9SRadoslaw BiernackiNEED_BL32 := yes 29301d27d9SRadoslaw Biernackiendif # ARMv7 30301d27d9SRadoslaw Biernacki 31301d27d9SRadoslaw Biernackiifeq (${SPD},opteed) 32301d27d9SRadoslaw Biernackiadd-lib-optee := yes 33301d27d9SRadoslaw Biernackiendif 34301d27d9SRadoslaw Biernackiifeq ($(AARCH32_SP),optee) 35301d27d9SRadoslaw Biernackiadd-lib-optee := yes 36301d27d9SRadoslaw Biernackiendif 37f58237ccSJens Wiklanderifeq ($(SPMC_OPTEE),1) 38f58237ccSJens Wiklander$(eval $(call add_define,SPMC_OPTEE)) 39f58237ccSJens Wiklanderadd-lib-optee := yes 40f58237ccSJens Wiklanderendif 41301d27d9SRadoslaw Biernacki 42301d27d9SRadoslaw Biernackiifeq ($(NEED_BL32),yes) 43301d27d9SRadoslaw Biernacki$(eval $(call add_define,QEMU_LOAD_BL32)) 44301d27d9SRadoslaw Biernackiendif 45301d27d9SRadoslaw Biernacki 46301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 47301d27d9SRadoslaw Biernacki 48*142ee34eSLauren Wehrmeister AUTH_MK := drivers/auth/auth.mk 49*142ee34eSLauren Wehrmeister $(info Including ${AUTH_MK}) 50*142ee34eSLauren Wehrmeister include ${AUTH_MK} 51*142ee34eSLauren Wehrmeister 52*142ee34eSLauren Wehrmeister AUTH_SOURCES += drivers/auth/tbbr/tbbr_cot_common.c 53301d27d9SRadoslaw Biernacki 54301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 55301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 56301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 57301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 58ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 59ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 60301d27d9SRadoslaw Biernacki 61301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 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_bl2.c 66301d27d9SRadoslaw Biernacki 675e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 685e690269SRuchika Gupta 69301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 70301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 71301d27d9SRadoslaw Biernacki 72301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 73301d27d9SRadoslaw Biernacki 74301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 75301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 76301d27d9SRadoslaw Biernacki 77301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 78301d27d9SRadoslaw Biernacki 797a95759fSChris Kay $(ROT_KEY): | $$(@D)/ 807c4e1eeaSChris Kay $(s)echo " OPENSSL $@" 817c4e1eeaSChris Kay $(q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 82301d27d9SRadoslaw Biernacki 837a95759fSChris Kay $(ROTPK_HASH): $(ROT_KEY) | $$(@D)/ 847c4e1eeaSChris Kay $(s)echo " OPENSSL $@" 857c4e1eeaSChris Kay $(q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 86e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 87301d27d9SRadoslaw Biernackiendif 88301d27d9SRadoslaw Biernacki 895e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 905e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 915e690269SRuchika Gupta# flags present in Measured Boot makefile. 925e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 935e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 945e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 955e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 965e690269SRuchika Gupta 975e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 985e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 995e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1005e690269SRuchika Gupta 1015e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1025e690269SRuchika Gupta 1035e690269SRuchika Guptaendif 1045e690269SRuchika Gupta 105*142ee34eSLauren Wehrmeisterifeq (${MEASURED_BOOT},1) 106*142ee34eSLauren Wehrmeisterifeq (${TRUSTED_BOARD_BOOT},0) 1075e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1085e690269SRuchika Gupta 1095e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1105e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 111*142ee34eSLauren Wehrmeisterendif 112*142ee34eSLauren Wehrmeisterendif 1135e690269SRuchika Gupta 114*142ee34eSLauren Wehrmeisterifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1155e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1165e690269SRuchika Gupta # 1175e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1185e690269SRuchika Guptaendif 1195e690269SRuchika Gupta 12033ac6f99SMathieu PoirierBL2_SOURCES += common/uuid.c 121301d27d9SRadoslaw Biernacki 122301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 123301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 124301d27d9SRadoslaw Biernackiendif 125301d27d9SRadoslaw Biernacki 12651857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 12751857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 12851857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 12951857762SSumit Gargendif 13051857762SSumit Garg 131d799d168SLeif Lindholm# Include GICv2 driver files 132d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 133d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 134301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 135301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 136301d27d9SRadoslaw Biernacki 137a6ea06f5SAlexei Fedorov# Include GICv3 driver files 138a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 139a6ea06f5SAlexei Fedorov 140a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 141301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 142301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 143301d27d9SRadoslaw Biernacki 144301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 145301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 146301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 147301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 148301d27d9SRadoslaw Biernackielse 149301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 150301d27d9SRadoslaw Biernackiendif 151301d27d9SRadoslaw Biernacki 15218884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 15318884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 154ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 155301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 15618884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 157f58237ccSJens Wiklander 158cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 159cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 160cef76a7cSDongjiu Gengendif 161cef76a7cSDongjiu Geng 162f58237ccSJens Wiklanderifeq (${SPD},spmd) 16325ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 16425ae7ad1SJens Wiklander common/uuid.c \ 16525ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 16625ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 167f58237ccSJens Wiklanderendif 168301d27d9SRadoslaw Biernackiendif 169301d27d9SRadoslaw Biernacki 170301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 171301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 172301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 17351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17451857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 17551857762SSumit Gargelse 176301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 177301d27d9SRadoslaw Biernackiendif 17851857762SSumit Gargendif 179301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 18051857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18151857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 18251857762SSumit Gargelse 183301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 184301d27d9SRadoslaw Biernackiendif 18551857762SSumit Gargendif 186301d27d9SRadoslaw Biernacki 18736802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 18836802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 18936802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 19036802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 19136802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 19236802e2cSJens Wiklanderendif 19336802e2cSJens Wiklander 19425ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 19525ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 19625ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 19725ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 19825ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 19925ae7ad1SJens Wiklanderendif 20025ae7ad1SJens Wiklander 201301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 202301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 203301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 204cd75693fSJean-Philippe Brucker ifeq (${ENABLE_RME},1) 205cd75693fSJean-Philippe Brucker # Avoid overlap between BL2 and BL32 to ease GPT partition 206cd75693fSJean-Philippe Brucker $(error "With RME, BL32 must use secure DRAM") 207cd75693fSJean-Philippe Brucker endif 208301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 209301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 210301d27d9SRadoslaw Biernackielse 211301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 212301d27d9SRadoslaw Biernackiendif 213301d27d9SRadoslaw Biernacki 214301d27d9SRadoslaw Biernacki# Process flags 215301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 216301d27d9SRadoslaw Biernacki 21774464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 21874464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 21974464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 22074464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 22174464d5bSAndrew Walbran 22274464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 22374464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 22474464d5bSAndrew Walbran 22563bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 2267c4e1eeaSChris Kay $(s)echo " DD $@" 2277c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 2287c4e1eeaSChris Kay $(q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 22963bb9056SAndre Przywara 23063bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 2317c4e1eeaSChris Kay $(s)echo " DD $@" 2327c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 2337c4e1eeaSChris Kay $(q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 23463bb9056SAndre Przywara 23563bb9056SAndre Przywaraifneq (${BL33},) 23663bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 23763bb9056SAndre Przywaraendif 238cef76a7cSDongjiu Geng 239cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 240cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 241cef76a7cSDongjiu Gengendif 242