xref: /rk3399_ARM-atf/plat/nvidia/tegra/platform.mk (revision d886628de6a0863571f7e6a29b218c5669d4e551)
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