1301d27d9SRadoslaw Biernacki# 27c4e1eeaSChris Kay# Copyright (c) 2013-2024, 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 42322af234SRaymond Maoifeq (${TRANSFER_LIST},1) 43322af234SRaymond Maoinclude lib/transfer_list/transfer_list.mk 44322af234SRaymond Maoendif 45322af234SRaymond Mao 46301d27d9SRadoslaw Biernackiifeq ($(NEED_BL32),yes) 47301d27d9SRadoslaw Biernacki$(eval $(call add_define,QEMU_LOAD_BL32)) 48301d27d9SRadoslaw Biernackiendif 49301d27d9SRadoslaw Biernacki 50301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 51301d27d9SRadoslaw Biernacki 52301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 53301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 54ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 55301d27d9SRadoslaw Biernacki 56301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 57301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 58301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 59301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 60ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 61ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 62301d27d9SRadoslaw Biernacki 63301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 64301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 65301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 66ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 67ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 68301d27d9SRadoslaw Biernacki 695e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 705e690269SRuchika Gupta 71301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 72301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 73301d27d9SRadoslaw Biernacki 74301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 75301d27d9SRadoslaw Biernacki 76301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 77301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 78301d27d9SRadoslaw Biernacki 79301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 80301d27d9SRadoslaw Biernacki 817a95759fSChris Kay $(ROT_KEY): | $$(@D)/ 827c4e1eeaSChris Kay $(s)echo " OPENSSL $@" 837c4e1eeaSChris Kay $(q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 84301d27d9SRadoslaw Biernacki 857a95759fSChris Kay $(ROTPK_HASH): $(ROT_KEY) | $$(@D)/ 867c4e1eeaSChris Kay $(s)echo " OPENSSL $@" 877c4e1eeaSChris Kay $(q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 88e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 89301d27d9SRadoslaw Biernackiendif 90301d27d9SRadoslaw Biernacki 915e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 925e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 935e690269SRuchika Gupta# flags present in Measured Boot makefile. 945e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 955e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 965e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 975e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 985e690269SRuchika Gupta 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 118*33ac6f99SMathieu PoirierBL2_SOURCES += common/uuid.c 119301d27d9SRadoslaw Biernacki 120301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 121301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 122301d27d9SRadoslaw Biernackiendif 123301d27d9SRadoslaw Biernacki 12451857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 12551857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 12651857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 12751857762SSumit Gargendif 12851857762SSumit Garg 129d799d168SLeif Lindholm# Include GICv2 driver files 130d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 131d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 132301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 133301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 134301d27d9SRadoslaw Biernacki 135a6ea06f5SAlexei Fedorov# Include GICv3 driver files 136a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 137a6ea06f5SAlexei Fedorov 138a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 139301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 140301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 141301d27d9SRadoslaw Biernacki 142301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 143301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 144301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 145301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 146301d27d9SRadoslaw Biernackielse 147301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 148301d27d9SRadoslaw Biernackiendif 149301d27d9SRadoslaw Biernacki 15018884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 15118884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 152ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 153301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 15418884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 155f58237ccSJens Wiklander 156cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 157cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 158cef76a7cSDongjiu Gengendif 159cef76a7cSDongjiu Geng 160f58237ccSJens Wiklanderifeq (${SPD},spmd) 16125ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 16225ae7ad1SJens Wiklander common/uuid.c \ 16325ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 16425ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 165f58237ccSJens Wiklanderendif 166301d27d9SRadoslaw Biernackiendif 167301d27d9SRadoslaw Biernacki 168301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 169301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 170301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 17151857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17251857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 17351857762SSumit Gargelse 174301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 175301d27d9SRadoslaw Biernackiendif 17651857762SSumit Gargendif 177301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 17851857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17951857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 18051857762SSumit Gargelse 181301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 182301d27d9SRadoslaw Biernackiendif 18351857762SSumit Gargendif 184301d27d9SRadoslaw Biernacki 18536802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 18636802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 18736802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 18836802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 18936802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 19036802e2cSJens Wiklanderendif 19136802e2cSJens Wiklander 19225ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 19325ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 19425ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 19525ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 19625ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 19725ae7ad1SJens Wiklanderendif 19825ae7ad1SJens Wiklander 199301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 200301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 201301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 202cd75693fSJean-Philippe Brucker ifeq (${ENABLE_RME},1) 203cd75693fSJean-Philippe Brucker # Avoid overlap between BL2 and BL32 to ease GPT partition 204cd75693fSJean-Philippe Brucker $(error "With RME, BL32 must use secure DRAM") 205cd75693fSJean-Philippe Brucker endif 206301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 207301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 208301d27d9SRadoslaw Biernackielse 209301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 210301d27d9SRadoslaw Biernackiendif 211301d27d9SRadoslaw Biernacki 212301d27d9SRadoslaw Biernacki# Process flags 213301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 214301d27d9SRadoslaw Biernacki 21574464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 21674464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 21774464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 21874464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 21974464d5bSAndrew Walbran 22074464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 22174464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 22274464d5bSAndrew Walbran 22363bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 2247c4e1eeaSChris Kay $(s)echo " DD $@" 2257c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 2267c4e1eeaSChris Kay $(q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 22763bb9056SAndre Przywara 22863bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 2297c4e1eeaSChris Kay $(s)echo " DD $@" 2307c4e1eeaSChris Kay $(q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 2317c4e1eeaSChris Kay $(q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 23263bb9056SAndre Przywara 23363bb9056SAndre Przywaraifneq (${BL33},) 23463bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 23563bb9056SAndre Przywaraendif 236cef76a7cSDongjiu Geng 237cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 238cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 239cef76a7cSDongjiu Gengendif 240