108438e24SVarun Wadekar# 28d56e24bSVarun Wadekar# Copyright (c) 2015-2019, ARM Limited and Contributors. All rights reserved. 3b20a8b92SVarun Wadekar# Copyright (c) 2020, NVIDIA Corporation. All rights reserved. 408438e24SVarun Wadekar# 582cb2c1aSdp-arm# SPDX-License-Identifier: BSD-3-Clause 608438e24SVarun Wadekar# 708438e24SVarun Wadekar 808438e24SVarun WadekarSOC_DIR := plat/nvidia/tegra/soc/${TARGET_SOC} 971cb26eaSVarun Wadekar 1003af25bcSVarun Wadekar# dump the state on crash console 1103af25bcSVarun WadekarCRASH_REPORTING := 1 1203af25bcSVarun Wadekar$(eval $(call add_define,CRASH_REPORTING)) 13990c1e01SVarun Wadekar 146c16918fSVarun Wadekar# enable assert() for release/debug builds 156c16918fSVarun WadekarENABLE_ASSERTIONS := 1 1661c418baSVarun WadekarPLAT_LOG_LEVEL_ASSERT := 50 17db0d1070SVarun Wadekar$(eval $(call add_define,PLAT_LOG_LEVEL_ASSERT)) 186c16918fSVarun Wadekar 1903af25bcSVarun Wadekar# enable dynamic memory mapping 2003af25bcSVarun WadekarPLAT_XLAT_TABLES_DYNAMIC := 1 2103af25bcSVarun Wadekar$(eval $(call add_define,PLAT_XLAT_TABLES_DYNAMIC)) 2203af25bcSVarun Wadekar 23adb20a17SVarun Wadekar# Enable exception handling at EL3 24adb20a17SVarun WadekarEL3_EXCEPTION_HANDLING := 1 25adb20a17SVarun WadekarGICV2_G0_FOR_EL3 := 1 26adb20a17SVarun Wadekar 2703af25bcSVarun Wadekar# Enable PSCI v1.0 extended state ID format 2803af25bcSVarun WadekarPSCI_EXTENDED_STATE_ID := 1 2903af25bcSVarun Wadekar 3003af25bcSVarun Wadekar# code and read-only data should be put on separate memory pages 3103af25bcSVarun WadekarSEPARATE_CODE_AND_RODATA := 1 3203af25bcSVarun Wadekar 3303af25bcSVarun Wadekar# do not use coherent memory 3403af25bcSVarun WadekarUSE_COHERENT_MEM := 0 3503af25bcSVarun Wadekar 363872fc2dSDavid Cunado# do not enable SVE 373872fc2dSDavid CunadoENABLE_SVE_FOR_NS := 0 383872fc2dSDavid Cunado 39fda818c9SVarun Wadekar# enable D-cache early during CPU warmboot 40fda818c9SVarun WadekarWARMBOOT_ENABLE_DCACHE_EARLY := 1 41fda818c9SVarun Wadekar 42b695af1dSAnthony Zhou# remove the standard libc 43b695af1dSAnthony ZhouOVERRIDE_LIBC := 1 44b695af1dSAnthony Zhou 45b20a8b92SVarun Wadekar# Flag to enable WDT FIQ interrupt handling for Tegra SoCs 46b20a8b92SVarun Wadekar# prior to Tegra186 47ebe076daSVarun WadekarENABLE_TEGRA_WDT_LEGACY_FIQ_HANDLING ?= 0 48b20a8b92SVarun Wadekar 496f47acdbSVarun Wadekar# Flag to allow relocation of BL32 image to TZDRAM during boot 506f47acdbSVarun WadekarRELOCATE_BL32_IMAGE ?= 0 516f47acdbSVarun Wadekar 52359acf77SVarun Wadekar# Enable stack protection 53359acf77SVarun WadekarENABLE_STACK_PROTECTOR := strong 54359acf77SVarun Wadekar 55*d886628dSVarun Wadekar# Enable SDEI 56*d886628dSVarun WadekarSDEI_SUPPORT := 1 57*d886628dSVarun Wadekar 5808438e24SVarun Wadekarinclude plat/nvidia/tegra/common/tegra_common.mk 5908438e24SVarun Wadekarinclude ${SOC_DIR}/platform_${TARGET_SOC}.mk 601f95e28cSVarun Wadekar 61ebe076daSVarun Wadekar$(eval $(call add_define,ENABLE_TEGRA_WDT_LEGACY_FIQ_HANDLING)) 626f47acdbSVarun Wadekar$(eval $(call add_define,RELOCATE_BL32_IMAGE)) 63b20a8b92SVarun Wadekar 641f95e28cSVarun Wadekar# modify BUILD_PLAT to point to SoC specific build directory 651f95e28cSVarun WadekarBUILD_PLAT := ${BUILD_BASE}/${PLAT}/${TARGET_SOC}/${BUILD_TYPE} 666311f63dSVarun Wadekar 677f9d75d2SVarun Wadekar# platform cflags (enable signed comparisons, disable stdlib) 687f9d75d2SVarun WadekarTF_CFLAGS += -Wsign-compare -nostdlib 69b695af1dSAnthony Zhou 70b695af1dSAnthony Zhou# override with necessary libc files for the Tegra platform 71b695af1dSAnthony Zhouoverride LIBC_SRCS := $(addprefix lib/libc/, \ 72*d886628dSVarun Wadekar aarch64/setjmp.S \ 73b695af1dSAnthony Zhou assert.c \ 74b695af1dSAnthony Zhou memcpy.c \ 75b695af1dSAnthony Zhou memmove.c \ 76b695af1dSAnthony Zhou memset.c \ 77b695af1dSAnthony Zhou printf.c \ 78b695af1dSAnthony Zhou putchar.c \ 79b695af1dSAnthony Zhou strlen.c \ 80b695af1dSAnthony Zhou snprintf.c) 81b695af1dSAnthony Zhou 82b695af1dSAnthony ZhouINCLUDES += -Iinclude/lib/libc \ 83b695af1dSAnthony Zhou -Iinclude/lib/libc/$(ARCH) \ 84c2ad38ceSVarun Wadekar 85c2ad38ceSVarun Wadekarifneq ($(findstring armlink,$(notdir $(LD))),) 86c2ad38ceSVarun Wadekar# o suppress warnings for section mismatches, undefined symbols 87c2ad38ceSVarun Wadekar# o use only those libraries that are specified in the input file 88c2ad38ceSVarun Wadekar# list to resolve references 89c2ad38ceSVarun Wadekar# o create a static callgraph of functions 90c2ad38ceSVarun Wadekar# o resolve undefined symbols to el3_panic 91c2ad38ceSVarun Wadekar# o include only required sections 92c2ad38ceSVarun WadekarTF_LDFLAGS += --diag_suppress=L6314,L6332 --no_scanlib --callgraph 93c2ad38ceSVarun WadekarTF_LDFLAGS += --keep="*(__pubsub*)" --keep="*(rt_svc_descs*)" --keep="*(*cpu_ops)" 94c2ad38ceSVarun Wadekarifeq (${ENABLE_PMF},1) 95c2ad38ceSVarun WadekarTF_LDFLAGS += --keep="*(*pmf_svc_descs*)" 96c2ad38ceSVarun Wadekarendif 97c2ad38ceSVarun Wadekarendif 98