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 7*886688d1SMarcin JuszkiewiczPLAT_QEMU_PATH := plat/qemu/qemu 8*886688d1SMarcin JuszkiewiczPLAT_QEMU_COMMON_PATH := plat/qemu/common 9*886688d1SMarcin 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 BiernackiPLAT_BL_COMMON_SOURCES := ${PLAT_QEMU_COMMON_PATH}/qemu_common.c \ 55301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_console.c \ 56301d27d9SRadoslaw Biernacki drivers/arm/pl011/${ARCH}/pl011_console.S 57301d27d9SRadoslaw Biernacki 58301d27d9SRadoslaw Biernackiinclude lib/xlat_tables_v2/xlat_tables.mk 59301d27d9SRadoslaw BiernackiPLAT_BL_COMMON_SOURCES += ${XLAT_TABLES_LIB_SRCS} 60301d27d9SRadoslaw Biernacki 61301d27d9SRadoslaw Biernackiifneq (${TRUSTED_BOARD_BOOT},0) 62301d27d9SRadoslaw Biernacki 63301d27d9SRadoslaw Biernacki AUTH_SOURCES := drivers/auth/auth_mod.c \ 64301d27d9SRadoslaw Biernacki drivers/auth/img_parser_mod.c \ 65ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_common.c 66301d27d9SRadoslaw Biernacki 67301d27d9SRadoslaw Biernacki BL1_SOURCES += ${AUTH_SOURCES} \ 68301d27d9SRadoslaw Biernacki bl1/tbbr/tbbr_img_desc.c \ 69301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 70301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 71ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 72ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl1.c 73301d27d9SRadoslaw Biernacki 74301d27d9SRadoslaw Biernacki BL2_SOURCES += ${AUTH_SOURCES} \ 75301d27d9SRadoslaw Biernacki plat/common/tbbr/plat_tbbr.c \ 76301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_trusted_boot.c \ 77ad43c49eSManish V Badarkhe $(PLAT_QEMU_COMMON_PATH)/qemu_rotpk.S \ 78ad43c49eSManish V Badarkhe drivers/auth/tbbr/tbbr_cot_bl2.c 79301d27d9SRadoslaw Biernacki 805e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_x509.mk 815e690269SRuchika Gupta 82301d27d9SRadoslaw Biernacki ROT_KEY = $(BUILD_PLAT)/rot_key.pem 83301d27d9SRadoslaw Biernacki ROTPK_HASH = $(BUILD_PLAT)/rotpk_sha256.bin 84301d27d9SRadoslaw Biernacki 85301d27d9SRadoslaw Biernacki $(eval $(call add_define_val,ROTPK_HASH,'"$(ROTPK_HASH)"')) 86301d27d9SRadoslaw Biernacki 87301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl1/qemu_rotpk.o: $(ROTPK_HASH) 88301d27d9SRadoslaw Biernacki $(BUILD_PLAT)/bl2/qemu_rotpk.o: $(ROTPK_HASH) 89301d27d9SRadoslaw Biernacki 90301d27d9SRadoslaw Biernacki certificates: $(ROT_KEY) 91301d27d9SRadoslaw Biernacki 92dad2934cSManish V Badarkhe $(ROT_KEY): | $(BUILD_PLAT) 93301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 94e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl genrsa 2048 > $@ 2>/dev/null 95301d27d9SRadoslaw Biernacki 96301d27d9SRadoslaw Biernacki $(ROTPK_HASH): $(ROT_KEY) 97301d27d9SRadoslaw Biernacki @echo " OPENSSL $@" 98e95abc4cSSalome Thirot $(Q)${OPENSSL_BIN_PATH}/openssl rsa -in $< -pubout -outform DER 2>/dev/null |\ 99e95abc4cSSalome Thirot ${OPENSSL_BIN_PATH}/openssl dgst -sha256 -binary > $@ 2>/dev/null 100301d27d9SRadoslaw Biernackiendif 101301d27d9SRadoslaw Biernacki 1025e690269SRuchika Gupta# Include Measured Boot makefile before any Crypto library makefile. 1035e690269SRuchika Gupta# Crypto library makefile may need default definitions of Measured Boot build 1045e690269SRuchika Gupta# flags present in Measured Boot makefile. 1055e690269SRuchika Guptaifeq (${MEASURED_BOOT},1) 1065e690269SRuchika Gupta MEASURED_BOOT_MK := drivers/measured_boot/event_log/event_log.mk 1075e690269SRuchika Gupta $(info Including ${MEASURED_BOOT_MK}) 1085e690269SRuchika Gupta include ${MEASURED_BOOT_MK} 1095e690269SRuchika Gupta 110a58cfefbSlaurenw-arm ifneq (${MBOOT_EL_HASH_ALG}, sha256) 111a58cfefbSlaurenw-arm $(eval $(call add_define,TF_MBEDTLS_MBOOT_USE_SHA512)) 112a58cfefbSlaurenw-arm endif 113a58cfefbSlaurenw-arm 1145e690269SRuchika Gupta BL2_SOURCES += plat/qemu/qemu/qemu_measured_boot.c \ 1155e690269SRuchika Gupta plat/qemu/qemu/qemu_helpers.c \ 1165e690269SRuchika Gupta ${EVENT_LOG_SOURCES} 1175e690269SRuchika Gupta 1185e690269SRuchika Gupta BL1_SOURCES += plat/qemu/qemu/qemu_bl1_measured_boot.c 1195e690269SRuchika Gupta 1205e690269SRuchika Guptaendif 1215e690269SRuchika Gupta 1225e690269SRuchika Guptaifneq ($(filter 1,${MEASURED_BOOT} ${TRUSTED_BOARD_BOOT}),) 1235e690269SRuchika Gupta CRYPTO_SOURCES := drivers/auth/crypto_mod.c 1245e690269SRuchika Gupta 1255e690269SRuchika Gupta BL1_SOURCES += ${CRYPTO_SOURCES} 1265e690269SRuchika Gupta BL2_SOURCES += ${CRYPTO_SOURCES} 1275e690269SRuchika Gupta 1285e690269SRuchika Gupta # We expect to locate the *.mk files under the directories specified below 1295e690269SRuchika Gupta # 1305e690269SRuchika Gupta include drivers/auth/mbedtls/mbedtls_crypto.mk 1315e690269SRuchika Guptaendif 1325e690269SRuchika Gupta 133301d27d9SRadoslaw BiernackiBL1_SOURCES += drivers/io/io_semihosting.c \ 134301d27d9SRadoslaw Biernacki drivers/io/io_storage.c \ 135301d27d9SRadoslaw Biernacki drivers/io/io_fip.c \ 136301d27d9SRadoslaw Biernacki drivers/io/io_memmap.c \ 137301d27d9SRadoslaw Biernacki lib/semihosting/semihosting.c \ 138301d27d9SRadoslaw Biernacki lib/semihosting/${ARCH}/semihosting_call.S \ 139301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_io_storage.c \ 140301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/${ARCH}/plat_helpers.S \ 1416b666936SChen Baozi ${PLAT_QEMU_COMMON_PATH}/qemu_bl1_setup.c \ 1426b666936SChen Baozi ${QEMU_CPU_LIBS} 143301d27d9SRadoslaw Biernacki 144301d27d9SRadoslaw BiernackiBL2_SOURCES += drivers/io/io_semihosting.c \ 145301d27d9SRadoslaw Biernacki drivers/io/io_storage.c \ 146301d27d9SRadoslaw Biernacki drivers/io/io_fip.c \ 147301d27d9SRadoslaw Biernacki drivers/io/io_memmap.c \ 148301d27d9SRadoslaw Biernacki lib/semihosting/semihosting.c \ 149301d27d9SRadoslaw Biernacki lib/semihosting/${ARCH}/semihosting_call.S \ 150301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_io_storage.c \ 151301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/${ARCH}/plat_helpers.S \ 152301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl2_setup.c \ 153301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl2_mem_params_desc.c \ 154301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_image_load.c \ 155301d27d9SRadoslaw Biernacki common/fdt_fixup.c \ 156a63cdc74SMarcin Juszkiewicz ${FDT_WRAPPERS_SOURCES} \ 15736802e2cSJens Wiklander common/desc_image_load.c \ 15836802e2cSJens Wiklander common/uuid.c 159301d27d9SRadoslaw Biernacki 160301d27d9SRadoslaw Biernackiifeq ($(add-lib-optee),yes) 161301d27d9SRadoslaw BiernackiBL2_SOURCES += lib/optee/optee_utils.c 162301d27d9SRadoslaw Biernackiendif 163301d27d9SRadoslaw Biernacki 16451857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 16551857762SSumit GargBL1_SOURCES += drivers/io/io_encrypted.c 16651857762SSumit GargBL2_SOURCES += drivers/io/io_encrypted.c 16751857762SSumit Gargendif 16851857762SSumit Garg 169d799d168SLeif Lindholm# Include GICv2 driver files 170d799d168SLeif Lindholminclude drivers/arm/gic/v2/gicv2.mk 171d799d168SLeif LindholmQEMU_GICV2_SOURCES := ${GICV2_SOURCES} \ 172301d27d9SRadoslaw Biernacki plat/common/plat_gicv2.c \ 173301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv2.c 174301d27d9SRadoslaw Biernacki 175a6ea06f5SAlexei Fedorov# Include GICv3 driver files 176a6ea06f5SAlexei Fedorovinclude drivers/arm/gic/v3/gicv3.mk 177a6ea06f5SAlexei Fedorov 178a6ea06f5SAlexei FedorovQEMU_GICV3_SOURCES := ${GICV3_SOURCES} \ 179301d27d9SRadoslaw Biernacki plat/common/plat_gicv3.c \ 180301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_gicv3.c 181301d27d9SRadoslaw Biernacki 182301d27d9SRadoslaw Biernackiifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV2) 183301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV2_SOURCES} 184301d27d9SRadoslaw Biernackielse ifeq (${QEMU_USE_GIC_DRIVER}, QEMU_GICV3) 185301d27d9SRadoslaw BiernackiQEMU_GIC_SOURCES := ${QEMU_GICV3_SOURCES} 186301d27d9SRadoslaw Biernackielse 187301d27d9SRadoslaw Biernacki$(error "Incorrect GIC driver chosen for QEMU platform") 188301d27d9SRadoslaw Biernackiendif 189301d27d9SRadoslaw Biernacki 190301d27d9SRadoslaw Biernackiifeq (${ARM_ARCH_MAJOR},8) 1916b666936SChen BaoziBL31_SOURCES += ${QEMU_CPU_LIBS} \ 19261cbd41dSAndrew Walbran lib/semihosting/semihosting.c \ 19361cbd41dSAndrew Walbran lib/semihosting/${ARCH}/semihosting_call.S \ 194301d27d9SRadoslaw Biernacki plat/common/plat_psci_common.c \ 195ffb07b04SMaxim Uvarov drivers/arm/pl061/pl061_gpio.c \ 196ffb07b04SMaxim Uvarov drivers/gpio/gpio.c \ 197301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_pm.c \ 198301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/topology.c \ 199301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/aarch64/plat_helpers.S \ 200301d27d9SRadoslaw Biernacki ${PLAT_QEMU_COMMON_PATH}/qemu_bl31_setup.c \ 201301d27d9SRadoslaw Biernacki ${QEMU_GIC_SOURCES} 202f58237ccSJens Wiklander 203cef76a7cSDongjiu Gengifeq (${SDEI_SUPPORT}, 1) 204cef76a7cSDongjiu GengBL31_SOURCES += plat/qemu/common/qemu_sdei.c 205cef76a7cSDongjiu Gengendif 206cef76a7cSDongjiu Geng 207cffc956eSLeo Yan# Pointer Authentication sources 208cffc956eSLeo Yanifeq (${ENABLE_PAUTH}, 1) 209c68736daSRebecca CranPLAT_BL_COMMON_SOURCES += plat/arm/common/aarch64/arm_pauth.c \ 210c68736daSRebecca Cran lib/extensions/pauth/pauth_helpers.S 211cffc956eSLeo Yanendif 212cffc956eSLeo Yan 213f58237ccSJens Wiklanderifeq (${SPD},spmd) 21425ae7ad1SJens WiklanderBL31_SOURCES += plat/common/plat_spmd_manifest.c \ 21525ae7ad1SJens Wiklander common/uuid.c \ 21625ae7ad1SJens Wiklander ${LIBFDT_SRCS} \ 21725ae7ad1SJens Wiklander ${FDT_WRAPPERS_SOURCES} 218f58237ccSJens Wiklanderendif 219301d27d9SRadoslaw Biernackiendif 220301d27d9SRadoslaw Biernacki 221301d27d9SRadoslaw Biernacki# Add the build options to pack Trusted OS Extra1 and Trusted OS Extra2 images 222301d27d9SRadoslaw Biernacki# in the FIP if the platform requires. 223301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA1),) 22451857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 22551857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1,,$(ENCRYPT_BL32))) 22651857762SSumit Gargelse 227301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra1,--tos-fw-extra1)) 228301d27d9SRadoslaw Biernackiendif 22951857762SSumit Gargendif 230301d27d9SRadoslaw Biernackiifneq ($(BL32_EXTRA2),) 23151857762SSumit Gargifneq (${DECRYPTION_SUPPORT},none) 23251857762SSumit Garg$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2,,$(ENCRYPT_BL32))) 23351857762SSumit Gargelse 234301d27d9SRadoslaw Biernacki$(eval $(call TOOL_ADD_IMG,bl32_extra2,--tos-fw-extra2)) 235301d27d9SRadoslaw Biernackiendif 23651857762SSumit Gargendif 237301d27d9SRadoslaw Biernacki 23836802e2cSJens Wiklanderifneq ($(QEMU_TB_FW_CONFIG_DTS),) 23936802e2cSJens WiklanderFDT_SOURCES += ${QEMU_TB_FW_CONFIG_DTS} 24036802e2cSJens WiklanderQEMU_TB_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TB_FW_CONFIG_DTS})).dtb 24136802e2cSJens Wiklander# Add the TB_FW_CONFIG to FIP 24236802e2cSJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TB_FW_CONFIG},--tb-fw-config,${QEMU_TB_FW_CONFIG})) 24336802e2cSJens Wiklanderendif 24436802e2cSJens Wiklander 24525ae7ad1SJens Wiklanderifneq ($(QEMU_TOS_FW_CONFIG_DTS),) 24625ae7ad1SJens WiklanderFDT_SOURCES += ${QEMU_TOS_FW_CONFIG_DTS} 24725ae7ad1SJens WiklanderQEMU_TOS_FW_CONFIG := ${BUILD_PLAT}/fdts/$(notdir $(basename ${QEMU_TOS_FW_CONFIG_DTS})).dtb 24825ae7ad1SJens Wiklander# Add the TOS_FW_CONFIG to FIP 24925ae7ad1SJens Wiklander$(eval $(call TOOL_ADD_PAYLOAD,${QEMU_TOS_FW_CONFIG},--tos-fw-config,${QEMU_TOS_FW_CONFIG})) 25025ae7ad1SJens Wiklanderendif 25125ae7ad1SJens Wiklander 252301d27d9SRadoslaw BiernackiSEPARATE_CODE_AND_RODATA := 1 253301d27d9SRadoslaw BiernackiENABLE_STACK_PROTECTOR := 0 254301d27d9SRadoslaw Biernackiifneq ($(ENABLE_STACK_PROTECTOR), 0) 255301d27d9SRadoslaw Biernacki PLAT_BL_COMMON_SOURCES += ${PLAT_QEMU_COMMON_PATH}/qemu_stack_protector.c 256301d27d9SRadoslaw Biernackiendif 257301d27d9SRadoslaw Biernacki 258301d27d9SRadoslaw BiernackiBL32_RAM_LOCATION := tdram 259301d27d9SRadoslaw Biernackiifeq (${BL32_RAM_LOCATION}, tsram) 260301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_SRAM_ID 261301d27d9SRadoslaw Biernackielse ifeq (${BL32_RAM_LOCATION}, tdram) 262301d27d9SRadoslaw Biernacki BL32_RAM_LOCATION_ID = SEC_DRAM_ID 263301d27d9SRadoslaw Biernackielse 264301d27d9SRadoslaw Biernacki $(error "Unsupported BL32_RAM_LOCATION value") 265301d27d9SRadoslaw Biernackiendif 266301d27d9SRadoslaw Biernacki 267301d27d9SRadoslaw Biernacki# Process flags 268301d27d9SRadoslaw Biernacki$(eval $(call add_define,BL32_RAM_LOCATION_ID)) 269301d27d9SRadoslaw Biernacki 27074464d5bSAndrew Walbran# Don't have the Linux kernel as a BL33 image by default 27174464d5bSAndrew WalbranARM_LINUX_KERNEL_AS_BL33 := 0 27274464d5bSAndrew Walbran$(eval $(call assert_boolean,ARM_LINUX_KERNEL_AS_BL33)) 27374464d5bSAndrew Walbran$(eval $(call add_define,ARM_LINUX_KERNEL_AS_BL33)) 27474464d5bSAndrew Walbran 27574464d5bSAndrew WalbranARM_PRELOADED_DTB_BASE := PLAT_QEMU_DT_BASE 27674464d5bSAndrew Walbran$(eval $(call add_define,ARM_PRELOADED_DTB_BASE)) 27774464d5bSAndrew Walbran 278ac17e52cSAndre Przywara# QEMU will use the RNDR instruction for the stack protector canary. 279ac17e52cSAndre PrzywaraENABLE_FEAT_RNG := 2 280ac17e52cSAndre Przywara 281337ff4f1SAndre Przywara# Later QEMU versions support SME and SVE. 282337ff4f1SAndre Przywaraifneq (${ARCH},aarch32) 283fc259b6cSJayanth Dodderi Chidanand ENABLE_SVE_FOR_NS := 2 284fc259b6cSJayanth Dodderi Chidanand ENABLE_SME_FOR_NS := 2 285337ff4f1SAndre Przywaraendif 28663bb9056SAndre Przywara 28763bb9056SAndre Przywaraqemu_fw.bios: bl1 fip 28863bb9056SAndre Przywara $(ECHO) " DD $@" 28963bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/bl1.bin ${BUILD_PLAT}/$@ 29063bb9056SAndre Przywara $(Q)dd if=${BUILD_PLAT}/fip.bin of=${BUILD_PLAT}/$@ bs=64k seek=4 status=none 29163bb9056SAndre Przywara 29263bb9056SAndre Przywaraqemu_fw.rom: qemu_fw.bios 29363bb9056SAndre Przywara $(ECHO) " DD $@" 29463bb9056SAndre Przywara $(Q)cp ${BUILD_PLAT}/$^ ${BUILD_PLAT}/$@ 29563bb9056SAndre Przywara $(Q)dd if=/dev/zero of=${BUILD_PLAT}/$@ bs=1M seek=64 count=0 status=none 29663bb9056SAndre Przywara 29763bb9056SAndre Przywaraifneq (${BL33},) 29863bb9056SAndre Przywaraall: qemu_fw.bios qemu_fw.rom 29963bb9056SAndre Przywaraendif 300cef76a7cSDongjiu Geng 301cef76a7cSDongjiu Gengifeq (${EL3_EXCEPTION_HANDLING},1) 302cef76a7cSDongjiu GengBL31_SOURCES += plat/common/aarch64/plat_ehf.c 303cef76a7cSDongjiu Gengendif 304