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 10a63cdc74SMarcin Juszkiewiczinclude plat/qemu/common/common.mk 11a63cdc74SMarcin Juszkiewicz 12301d27d9SRadoslaw Biernacki# Use the GICv2 driver on QEMU by default 13301d27d9SRadoslaw BiernackiQEMU_USE_GIC_DRIVER := QEMU_GICV2 14301d27d9SRadoslaw Biernacki 15301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},7) 16301d27d9SRadoslaw Biernacki# ARMv7 Qemu support in trusted firmware expects the Cortex-A15 model. 17301d27d9SRadoslaw Biernacki# Qemu Cortex-A15 model does not implement the virtualization extension. 18301d27d9SRadoslaw Biernacki# For this reason, we cannot set ARM_CORTEX_A15=yes and must define all 19301d27d9SRadoslaw Biernacki# the ARMv7 build directives. 20d4089fb8SGovindraj RajaMARCH_DIRECTIVE := -mcpu=cortex-a15 21301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_LARGE_PAGE_ADDRESSING)) 22301d27d9SRadoslaw Biernacki$(eval $(call add_define,ARMV7_SUPPORTS_GENERIC_TIMER)) 23e7a54033SJerome Forissier$(eval $(call add_define,ARMV7_SUPPORTS_VFP)) 24301d27d9SRadoslaw Biernacki# Qemu expects a BL32 boot stage. 25301d27d9SRadoslaw BiernackiNEED_BL32 := yes 266b666936SChen Baozielse 276b666936SChen BaoziCTX_INCLUDE_AARCH32_REGS := 0 286b666936SChen Baoziifeq (${CTX_INCLUDE_AARCH32_REGS}, 1) 296b666936SChen Baozi$(error "This is an AArch64-only port; CTX_INCLUDE_AARCH32_REGS must be disabled") 306b666936SChen Baoziendif 316b666936SChen Baozi 326b666936SChen Baozi# Treating this as a memory-constrained port for now 336b666936SChen BaoziUSE_COHERENT_MEM := 0 346b666936SChen Baozi 356b666936SChen Baozi# This can be overridden depending on CPU(s) used in the QEMU image 366b666936SChen BaoziHW_ASSISTED_COHERENCY := 1 37301d27d9SRadoslaw Biernackiendif # ARMv7 38301d27d9SRadoslaw Biernacki 39301d27d9SRadoslaw Biernackiifeq (${SPD},opteed) 40301d27d9SRadoslaw Biernackiadd-lib-optee := yes 41301d27d9SRadoslaw Biernackiendif 42301d27d9SRadoslaw Biernackiifeq ($(AARCH32_SP),optee) 43301d27d9SRadoslaw Biernackiadd-lib-optee := yes 44301d27d9SRadoslaw Biernackiendif 45f58237ccSJens Wiklanderifeq ($(SPMC_OPTEE),1) 46f58237ccSJens Wiklander$(eval $(call add_define,SPMC_OPTEE)) 47f58237ccSJens Wiklanderadd-lib-optee := yes 48f58237ccSJens Wiklanderendif 49301d27d9SRadoslaw Biernacki 50301d27d9SRadoslaw Biernackiifeq ($(NEED_BL32),yes) 51301d27d9SRadoslaw Biernacki$(eval $(call add_define,QEMU_LOAD_BL32)) 52301d27d9SRadoslaw Biernackiendif 53301d27d9SRadoslaw Biernacki 54301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 55301d27d9SRadoslaw Biernacki 56301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 57301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 58ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 59301d27d9SRadoslaw Biernacki 60301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 61301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 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_bl1.c 66301d27d9SRadoslaw Biernacki 67301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 68301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 69301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 70ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 71ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 72301d27d9SRadoslaw Biernacki 735e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 745e690269SRuchika Gupta 75301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 76301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 77301d27d9SRadoslaw Biernacki 78301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 79301d27d9SRadoslaw Biernacki 80301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 81301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 82301d27d9SRadoslaw Biernacki 83301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 84301d27d9SRadoslaw Biernacki 85dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 86301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 87e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 88301d27d9SRadoslaw Biernacki 89301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 90301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 91e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 92e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 93301d27d9SRadoslaw Biernackiendif 94301d27d9SRadoslaw Biernacki 955e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 965e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 975e690269SRuchika Gupta# flags present in Measured Boot makefile. 985e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 995e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 1005e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 1015e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 1025e690269SRuchika Gupta 103a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 104a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 105a58cfefbSlaurenw-arm endif 106a58cfefbSlaurenw-arm 1075e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1085e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1095e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1105e690269SRuchika Gupta 1115e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1125e690269SRuchika Gupta 1135e690269SRuchika Guptaendif 1145e690269SRuchika Gupta 1155e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1165e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1175e690269SRuchika Gupta 1185e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1195e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1205e690269SRuchika Gupta 1215e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1225e690269SRuchika Gupta # 1235e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1245e690269SRuchika Guptaendif 1255e690269SRuchika Gupta 12671f5359bSMarcin JuszkiewiczBL2_SOURCES += ${FDT_WRAPPERS_SOURCES} \ 12736802e2cSJens Wiklander common/uuid.c 128301d27d9SRadoslaw Biernacki 129301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 130301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 131301d27d9SRadoslaw Biernackiendif 132301d27d9SRadoslaw Biernacki 13351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 13451857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 13551857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 13651857762SSumit Gargendif 13751857762SSumit Garg 138d799d168SLeif Lindholm# Include GICv2 driver files 139d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 140d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 141301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 142301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 143301d27d9SRadoslaw Biernacki 144a6ea06f5SAlexei Fedorov# Include GICv3 driver files 145a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 146a6ea06f5SAlexei Fedorov 147a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 148301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 149301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 150301d27d9SRadoslaw Biernacki 151301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 152301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 153301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 154301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 155301d27d9SRadoslaw Biernackielse 156301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 157301d27d9SRadoslaw Biernackiendif 158301d27d9SRadoslaw Biernacki 159*18884750SMarcin Juszkiewiczifeq (${ARCH},aarch64) 160*18884750SMarcin JuszkiewiczBL31_SOURCES += drivers/arm/pl061/pl061_gpio.c \ 161ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 162301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 163*18884750SMarcin Juszkiewicz ${PLAT_QEMU_COMMON_PATH}/topology.c 164f58237ccSJens Wiklander 165cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 166cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 167cef76a7cSDongjiu Gengendif 168cef76a7cSDongjiu Geng 169cffc956eSLeo Yan# Pointer Authentication sources 170cffc956eSLeo Yanifeq (${ENABLE_PAUTH}, 1) 171c68736daSRebecca CranPLAT_BL_COMMON_SOURCES += plat/arm/common/aarch64/arm_pauth.c \ 172c68736daSRebecca Cran lib/extensions/pauth/pauth_helpers.S 173cffc956eSLeo Yanendif 174cffc956eSLeo Yan 175f58237ccSJens Wiklanderifeq (${SPD},spmd) 17625ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 17725ae7ad1SJens Wiklander common/uuid.c \ 17825ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 17925ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 180f58237ccSJens Wiklanderendif 181301d27d9SRadoslaw Biernackiendif 182301d27d9SRadoslaw Biernacki 183301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 184301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 185301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 18651857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 18751857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 18851857762SSumit Gargelse 189301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 190301d27d9SRadoslaw Biernackiendif 19151857762SSumit Gargendif 192301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 19351857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 19451857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 19551857762SSumit Gargelse 196301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 197301d27d9SRadoslaw Biernackiendif 19851857762SSumit Gargendif 199301d27d9SRadoslaw Biernacki 20036802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 20136802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 20236802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 20336802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 20436802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 20536802e2cSJens Wiklanderendif 20636802e2cSJens Wiklander 20725ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 20825ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 20925ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 21025ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 21125ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 21225ae7ad1SJens Wiklanderendif 21325ae7ad1SJens Wiklander 214301d27d9SRadoslaw BiernackiSEPARATE_CODE_AND_RODATA := 1 215301d27d9SRadoslaw BiernackiENABLE_STACK_PROTECTOR := 0 216301d27d9SRadoslaw Biernacki 217301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 218301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 219301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 220301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 221301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 222301d27d9SRadoslaw Biernackielse 223301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 224301d27d9SRadoslaw Biernackiendif 225301d27d9SRadoslaw Biernacki 226301d27d9SRadoslaw Biernacki# Process flags 227301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 228301d27d9SRadoslaw Biernacki 22974464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 23074464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 23174464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 23274464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 23374464d5bSAndrew Walbran 23474464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 23574464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 23674464d5bSAndrew Walbran 237ac17e52cSAndre Przywara# QEMU will use the RNDR instruction for the stack protector canary. 238ac17e52cSAndre PrzywaraENABLE_FEAT_RNG := 2 239ac17e52cSAndre Przywara 240337ff4f1SAndre Przywara# Later QEMU versions support SME and SVE. 241337ff4f1SAndre Przywaraifneq (${ARCH},aarch32) 242fc259b6cSJayanth Dodderi Chidanand ENABLE_SVE_FOR_NS := 2 243fc259b6cSJayanth Dodderi Chidanand ENABLE_SME_FOR_NS := 2 244337ff4f1SAndre Przywaraendif 24563bb9056SAndre Przywara 24663bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 24763bb9056SAndre Przywara $(ECHO) " DD $@" 24863bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 24963bb9056SAndre Przywara $(Q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 25063bb9056SAndre Przywara 25163bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 25263bb9056SAndre Przywara $(ECHO) " DD $@" 25363bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 25463bb9056SAndre Przywara $(Q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 25563bb9056SAndre Przywara 25663bb9056SAndre Przywaraifneq (${BL33},) 25763bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 25863bb9056SAndre Przywaraendif 259cef76a7cSDongjiu Geng 260cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 261cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 262cef76a7cSDongjiu Gengendif 263