1301d27d9SRadoslaw Biernacki# 2142ee34eSLauren 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 48142ee34eSLauren Wehrmeister AUTH_MK := drivers/auth/auth.mk 49142ee34eSLauren Wehrmeister $(info Including ${AUTH_MK}) 50142ee34eSLauren Wehrmeister include ${AUTH_MK} 51142ee34eSLauren Wehrmeister 52142ee34eSLauren 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 \ 98*03032a95SChris Kay plat/qemu/qemu/qemu_helpers.c 99*03032a95SChris Kay 100*03032a95SChris Kay BL2_LIBS += $(LIBEVLOG_LIBS) 101*03032a95SChris Kay BL2_INCLUDE_DIRS += $(LIBEVLOG_INCLUDE_DIRS) 1025e690269SRuchika Gupta 1035e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1045e690269SRuchika Gupta 1055e690269SRuchika Guptaendif 1065e690269SRuchika Gupta 107142ee34eSLauren Wehrmeisterifeq (${MEASURED_BOOT},1) 108142ee34eSLauren Wehrmeisterifeq (${TRUSTED_BOARD_BOOT},0) 1095e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1105e690269SRuchika Gupta 1115e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1125e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 113142ee34eSLauren Wehrmeisterendif 114142ee34eSLauren Wehrmeisterendif 1155e690269SRuchika Gupta 116142ee34eSLauren Wehrmeisterifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1175e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1185e690269SRuchika Gupta # 1195e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1205e690269SRuchika Guptaendif 1215e690269SRuchika Gupta 12233ac6f99SMathieu PoirierBL2_SOURCES += common/uuid.c 123301d27d9SRadoslaw Biernacki 124301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 125301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 126301d27d9SRadoslaw Biernackiendif 127301d27d9SRadoslaw Biernacki 12851857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 12951857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 13051857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 13151857762SSumit Gargendif 13251857762SSumit Garg 133d799d168SLeif Lindholm# Include GICv2 driver files 134d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 135d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 136301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 137301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 138301d27d9SRadoslaw Biernacki 139a6ea06f5SAlexei Fedorov# Include GICv3 driver files 140a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 141a6ea06f5SAlexei Fedorov 142a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 143301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 144301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 145301d27d9SRadoslaw Biernacki 146301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 147301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 148301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 149301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 150301d27d9SRadoslaw Biernackielse 151301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 152301d27d9SRadoslaw Biernackiendif 153301d27d9SRadoslaw Biernacki 15418884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 15518884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 156ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 157301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 15818884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 159f58237ccSJens Wiklander 160cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 161cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 162cef76a7cSDongjiu Gengendif 163cef76a7cSDongjiu Geng 164f58237ccSJens Wiklanderifeq (${SPD},spmd) 16525ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 16625ae7ad1SJens Wiklander common/uuid.c \ 16725ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 16825ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 169f58237ccSJens Wiklanderendif 170301d27d9SRadoslaw Biernackiendif 171301d27d9SRadoslaw Biernacki 172301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 173301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 174301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 17551857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17651857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 17751857762SSumit Gargelse 178301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 179301d27d9SRadoslaw Biernackiendif 18051857762SSumit Gargendif 181301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 18251857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18351857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 18451857762SSumit Gargelse 185301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 186301d27d9SRadoslaw Biernackiendif 18751857762SSumit Gargendif 188301d27d9SRadoslaw Biernacki 18936802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 19036802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 19136802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 19236802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 19336802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 19436802e2cSJens Wiklanderendif 19536802e2cSJens Wiklander 19625ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 19725ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 19825ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 19925ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 20025ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 20125ae7ad1SJens Wiklanderendif 20225ae7ad1SJens Wiklander 203301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 204301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 205301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 206cd75693fSJean-Philippe Brucker ifeq (${ENABLE_RME},1) 207cd75693fSJean-Philippe Brucker # Avoid overlap between BL2 and BL32 to ease GPT partition 208cd75693fSJean-Philippe Brucker $(error "With RME, BL32 must use secure DRAM") 209cd75693fSJean-Philippe Brucker endif 210301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 211301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 212301d27d9SRadoslaw Biernackielse 213301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 214301d27d9SRadoslaw Biernackiendif 215301d27d9SRadoslaw Biernacki 216301d27d9SRadoslaw Biernacki# Process flags 217301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 218301d27d9SRadoslaw Biernacki 21974464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 22074464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 22174464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 22274464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 22374464d5bSAndrew Walbran 22474464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 22574464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 22674464d5bSAndrew Walbran 22763bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 2287c4e1eeaSChris Kay $(s)echo " DD $@" 2297c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 2307c4e1eeaSChris Kay $(q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 23163bb9056SAndre Przywara 23263bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 2337c4e1eeaSChris Kay $(s)echo " DD $@" 2347c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 2357c4e1eeaSChris Kay $(q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 23663bb9056SAndre Przywara 23763bb9056SAndre Przywaraifneq (${BL33},) 23863bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 23963bb9056SAndre Przywaraendif 240cef76a7cSDongjiu Geng 241cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 242cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 243cef76a7cSDongjiu Gengendif 244