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 10*4a2e7547SMarcin JuszkiewiczSEPARATE_CODE_AND_RODATA := 1 11*4a2e7547SMarcin JuszkiewiczENABLE_STACK_PROTECTOR := 0 12*4a2e7547SMarcin 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 48301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 49301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 50ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 51301d27d9SRadoslaw Biernacki 52301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 53301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 54301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 55301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 56ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 57ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 58301d27d9SRadoslaw Biernacki 59301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 60301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 61301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 62ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 63ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 64301d27d9SRadoslaw Biernacki 655e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 665e690269SRuchika Gupta 67301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 68301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 69301d27d9SRadoslaw Biernacki 70301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 71301d27d9SRadoslaw Biernacki 72301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 73301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 74301d27d9SRadoslaw Biernacki 75301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 76301d27d9SRadoslaw Biernacki 77dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 78301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 79e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 80301d27d9SRadoslaw Biernacki 81301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 82301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 83e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 84e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 85301d27d9SRadoslaw Biernackiendif 86301d27d9SRadoslaw Biernacki 875e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 885e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 895e690269SRuchika Gupta# flags present in Measured Boot makefile. 905e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 915e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 925e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 935e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 945e690269SRuchika Gupta 95a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 96a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 97a58cfefbSlaurenw-arm endif 98a58cfefbSlaurenw-arm 995e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1005e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1015e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1025e690269SRuchika Gupta 1035e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1045e690269SRuchika Gupta 1055e690269SRuchika Guptaendif 1065e690269SRuchika Gupta 1075e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1085e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1095e690269SRuchika Gupta 1105e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1115e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1125e690269SRuchika Gupta 1135e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1145e690269SRuchika Gupta # 1155e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1165e690269SRuchika Guptaendif 1175e690269SRuchika Gupta 11871f5359bSMarcin JuszkiewiczBL2_SOURCES += ${FDT_WRAPPERS_SOURCES} \ 11936802e2cSJens Wiklander common/uuid.c 120301d27d9SRadoslaw Biernacki 121301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 122301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 123301d27d9SRadoslaw Biernackiendif 124301d27d9SRadoslaw Biernacki 12551857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 12651857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 12751857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 12851857762SSumit Gargendif 12951857762SSumit Garg 130d799d168SLeif Lindholm# Include GICv2 driver files 131d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 132d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 133301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 134301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 135301d27d9SRadoslaw Biernacki 136a6ea06f5SAlexei Fedorov# Include GICv3 driver files 137a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 138a6ea06f5SAlexei Fedorov 139a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 140301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 141301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 142301d27d9SRadoslaw Biernacki 143301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 144301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 145301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 146301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 147301d27d9SRadoslaw Biernackielse 148301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 149301d27d9SRadoslaw Biernackiendif 150301d27d9SRadoslaw Biernacki 15118884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 15218884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 153ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 154301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 15518884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 156f58237ccSJens Wiklander 157cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 158cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 159cef76a7cSDongjiu Gengendif 160cef76a7cSDongjiu Geng 161cffc956eSLeo Yan# Pointer Authentication sources 162cffc956eSLeo Yanifeq (${ENABLE_PAUTH}, 1) 163c68736daSRebecca CranPLAT_BL_COMMON_SOURCES += plat/arm/common/aarch64/arm_pauth.c \ 164c68736daSRebecca Cran lib/extensions/pauth/pauth_helpers.S 165cffc956eSLeo Yanendif 166cffc956eSLeo Yan 167f58237ccSJens Wiklanderifeq (${SPD},spmd) 16825ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 16925ae7ad1SJens Wiklander common/uuid.c \ 17025ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 17125ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 172f58237ccSJens Wiklanderendif 173301d27d9SRadoslaw Biernackiendif 174301d27d9SRadoslaw Biernacki 175301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 176301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 177301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 17851857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17951857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 18051857762SSumit Gargelse 181301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 182301d27d9SRadoslaw Biernackiendif 18351857762SSumit Gargendif 184301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 18551857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18651857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 18751857762SSumit Gargelse 188301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 189301d27d9SRadoslaw Biernackiendif 19051857762SSumit Gargendif 191301d27d9SRadoslaw Biernacki 19236802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 19336802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 19436802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 19536802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 19636802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 19736802e2cSJens Wiklanderendif 19836802e2cSJens Wiklander 19925ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 20025ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 20125ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 20225ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 20325ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 20425ae7ad1SJens Wiklanderendif 20525ae7ad1SJens Wiklander 206301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 207301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 208301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 209301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 210301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 211301d27d9SRadoslaw Biernackielse 212301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 213301d27d9SRadoslaw Biernackiendif 214301d27d9SRadoslaw Biernacki 215301d27d9SRadoslaw Biernacki# Process flags 216301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 217301d27d9SRadoslaw Biernacki 21874464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 21974464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 22074464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 22174464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 22274464d5bSAndrew Walbran 22374464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 22474464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 22574464d5bSAndrew Walbran 22663bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 22763bb9056SAndre Przywara $(ECHO) " DD $@" 22863bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 22963bb9056SAndre Przywara $(Q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 23063bb9056SAndre Przywara 23163bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 23263bb9056SAndre Przywara $(ECHO) " DD $@" 23363bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 23463bb9056SAndre Przywara $(Q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 23563bb9056SAndre Przywara 23663bb9056SAndre Przywaraifneq (${BL33},) 23763bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 23863bb9056SAndre Przywaraendif 239cef76a7cSDongjiu Geng 240cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 241cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 242cef76a7cSDongjiu Gengendif 243