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 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 42*322af234SRaymond Maoifeq (${TRANSFER_LIST},1) 43*322af234SRaymond Maoinclude lib/transfer_list/transfer_list.mk 44*322af234SRaymond Maoendif 45*322af234SRaymond 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 81dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 82301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 83e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 84301d27d9SRadoslaw Biernacki 85301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 86301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 87e95abc4cSSalome Thirot $(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 99a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 100a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 101a58cfefbSlaurenw-arm endif 102a58cfefbSlaurenw-arm 1035e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1045e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1055e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1065e690269SRuchika Gupta 1075e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1085e690269SRuchika Gupta 1095e690269SRuchika Guptaendif 1105e690269SRuchika Gupta 1115e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1125e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1135e690269SRuchika Gupta 1145e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1155e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1165e690269SRuchika Gupta 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 12271f5359bSMarcin JuszkiewiczBL2_SOURCES += ${FDT_WRAPPERS_SOURCES} \ 12336802e2cSJens Wiklander common/uuid.c 124301d27d9SRadoslaw Biernacki 125301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 126301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 127301d27d9SRadoslaw Biernackiendif 128301d27d9SRadoslaw Biernacki 12951857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 13051857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 13151857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 13251857762SSumit Gargendif 13351857762SSumit Garg 134d799d168SLeif Lindholm# Include GICv2 driver files 135d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 136d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 137301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 138301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 139301d27d9SRadoslaw Biernacki 140a6ea06f5SAlexei Fedorov# Include GICv3 driver files 141a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 142a6ea06f5SAlexei Fedorov 143a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 144301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 145301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 146301d27d9SRadoslaw Biernacki 147301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 148301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 149301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 150301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 151301d27d9SRadoslaw Biernackielse 152301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 153301d27d9SRadoslaw Biernackiendif 154301d27d9SRadoslaw Biernacki 15518884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 15618884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 157ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 158301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 15918884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 160f58237ccSJens Wiklander 161cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 162cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 163cef76a7cSDongjiu Gengendif 164cef76a7cSDongjiu Geng 165f58237ccSJens Wiklanderifeq (${SPD},spmd) 16625ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 16725ae7ad1SJens Wiklander common/uuid.c \ 16825ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 16925ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 170f58237ccSJens Wiklanderendif 171301d27d9SRadoslaw Biernackiendif 172301d27d9SRadoslaw Biernacki 173301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 174301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 175301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 17651857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 17751857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 17851857762SSumit Gargelse 179301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 180301d27d9SRadoslaw Biernackiendif 18151857762SSumit Gargendif 182301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 18351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18451857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 18551857762SSumit Gargelse 186301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 187301d27d9SRadoslaw Biernackiendif 18851857762SSumit Gargendif 189301d27d9SRadoslaw Biernacki 19036802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 19136802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 19236802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 19336802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 19436802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 19536802e2cSJens Wiklanderendif 19636802e2cSJens Wiklander 19725ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 19825ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 19925ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 20025ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 20125ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 20225ae7ad1SJens Wiklanderendif 20325ae7ad1SJens Wiklander 204301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 205301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 206301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 207301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 208301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 209301d27d9SRadoslaw Biernackielse 210301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 211301d27d9SRadoslaw Biernackiendif 212301d27d9SRadoslaw Biernacki 213301d27d9SRadoslaw Biernacki# Process flags 214301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 215301d27d9SRadoslaw Biernacki 21674464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 21774464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 21874464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 21974464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 22074464d5bSAndrew Walbran 22174464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 22274464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 22374464d5bSAndrew Walbran 22463bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 22563bb9056SAndre Przywara $(ECHO) " DD $@" 22663bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 22763bb9056SAndre Przywara $(Q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 22863bb9056SAndre Przywara 22963bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 23063bb9056SAndre Przywara $(ECHO) " DD $@" 23163bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 23263bb9056SAndre Przywara $(Q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 23363bb9056SAndre Przywara 23463bb9056SAndre Przywaraifneq (${BL33},) 23563bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 23663bb9056SAndre Przywaraendif 237cef76a7cSDongjiu Geng 238cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 239cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 240cef76a7cSDongjiu Gengendif 241