xref: /rk3399_ARM-atf/plat/nxp/soc-ls1046a/soc.mk (revision 79664cfcf90f164595b5362ffbbe5b4d3239bdf3)
1cc708597SJiafei Pan#
2cc708597SJiafei Pan# Copyright 2018-2022 NXP
3cc708597SJiafei Pan#
4cc708597SJiafei Pan# SPDX-License-Identifier: BSD-3-Clause
5cc708597SJiafei Pan#
6cc708597SJiafei Pan
7cc708597SJiafei Pan# SoC-specific build parameters
8cc708597SJiafei PanSOC		:=	ls1046a
9cc708597SJiafei PanPLAT_PATH	:=	plat/nxp
10cc708597SJiafei PanPLAT_COMMON_PATH:=	plat/nxp/common
11cc708597SJiafei PanPLAT_DRIVERS_PATH:=	drivers/nxp
12cc708597SJiafei PanPLAT_SOC_PATH	:=	${PLAT_PATH}/soc-${SOC}
13cc708597SJiafei PanBOARD_PATH	:=	${PLAT_SOC_PATH}/${BOARD}
14cc708597SJiafei Pan
15cc708597SJiafei Pan# Get SoC-specific defnitions
16cc708597SJiafei Paninclude ${PLAT_SOC_PATH}/soc.def
17cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/plat_make_helper/soc_common_def.mk
18cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/plat_make_helper/plat_build_macros.mk
19cc708597SJiafei Pan
20cc708597SJiafei Pan# For Security Features
21cc708597SJiafei PanDISABLE_FUSE_WRITE	:= 1
22cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,SMMU_NEEDED,BL2))
23*0ca1d8fbSHoward Luifeq (${TRUSTED_BOARD_BOOT}, 1)
24cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,SFP_NEEDED,BL2))
25cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,SNVS_NEEDED,BL2))
26cc708597SJiafei PanSECURE_BOOT	:= yes
27cc708597SJiafei Panendif
28cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,CRYPTO_NEEDED,BL_COMM))
29cc708597SJiafei Pan
30cc708597SJiafei Pan# Selecting Drivers for SoC
31cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,DCFG_NEEDED,BL_COMM))
32cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,CSU_NEEDED,BL_COMM))
33cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,TIMER_NEEDED,BL_COMM))
34cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,INTERCONNECT_NEEDED,BL_COMM))
35cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,GIC_NEEDED,BL31))
36cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,CONSOLE_NEEDED,BL_COMM))
37cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,PMU_NEEDED,BL_COMM))
38cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,DDR_DRIVER_NEEDED,BL2))
39cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,TZASC_NEEDED,BL2))
40cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,I2C_NEEDED,BL2))
41cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,IMG_LOADR_NEEDED,BL2))
42cc708597SJiafei Pan
43cc708597SJiafei Pan# Selecting PSCI & SIP_SVC support
44cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,PSCI_NEEDED,BL31))
45cc708597SJiafei Pan$(eval $(call SET_NXP_MAKE_FLAG,SIPSVC_NEEDED,BL31))
46cc708597SJiafei Pan
47cc708597SJiafei Pan# Source File Addition
48cc708597SJiafei PanPLAT_INCLUDES		+=	-I${PLAT_COMMON_PATH}/include/default\
49cc708597SJiafei Pan				-I${BOARD_PATH}\
50cc708597SJiafei Pan				-I${PLAT_COMMON_PATH}/include/default/ch_${CHASSIS}\
51cc708597SJiafei Pan				-I${PLAT_SOC_PATH}/include\
52cc708597SJiafei Pan				-I${PLAT_COMMON_PATH}/soc_errata
53cc708597SJiafei Pan
54cc708597SJiafei Panifeq (${SECURE_BOOT},yes)
55cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/tbbr/tbbr.mk
56cc708597SJiafei Panendif
57cc708597SJiafei Pan
58cc708597SJiafei Panifeq ($(WARM_BOOT),yes)
59cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/warm_reset/warm_reset.mk
60cc708597SJiafei Panendif
61cc708597SJiafei Pan
62cc708597SJiafei Panifeq (${NXP_NV_SW_MAINT_LAST_EXEC_DATA}, yes)
63cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/nv_storage/nv_storage.mk
64cc708597SJiafei Panendif
65cc708597SJiafei Pan
66cc708597SJiafei Panifeq (${PSCI_NEEDED}, yes)
67cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/psci/psci.mk
68cc708597SJiafei Panendif
69cc708597SJiafei Pan
70cc708597SJiafei Panifeq (${SIPSVC_NEEDED}, yes)
71cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/sip_svc/sipsvc.mk
72cc708597SJiafei Panendif
73cc708597SJiafei Pan
74cc708597SJiafei Pan# For fuse-fip & fuse-programming
75cc708597SJiafei Panifeq (${FUSE_PROG}, 1)
76cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/fip_handler/fuse_fip/fuse.mk
77cc708597SJiafei Panendif
78cc708597SJiafei Pan
79cc708597SJiafei Panifeq (${IMG_LOADR_NEEDED},yes)
80cc708597SJiafei Paninclude $(PLAT_COMMON_PATH)/img_loadr/img_loadr.mk
81cc708597SJiafei Panendif
82cc708597SJiafei Pan
83cc708597SJiafei Pan# Adding source files for the above selected drivers.
84cc708597SJiafei Paninclude ${PLAT_DRIVERS_PATH}/drivers.mk
85cc708597SJiafei Pan
86cc708597SJiafei Pan# Adding SoC specific files
87cc708597SJiafei Paninclude ${PLAT_COMMON_PATH}/soc_errata/errata.mk
88cc708597SJiafei Pan
89cc708597SJiafei PanPLAT_INCLUDES		+=	${NV_STORAGE_INCLUDES}\
90cc708597SJiafei Pan				${WARM_RST_INCLUDES}
91cc708597SJiafei Pan
92cc708597SJiafei PanBL31_SOURCES		+=	${PLAT_SOC_PATH}/$(ARCH)/${SOC}.S\
93cc708597SJiafei Pan				${WARM_RST_BL31_SOURCES}\
94cc708597SJiafei Pan				${PSCI_SOURCES}\
95cc708597SJiafei Pan				${SIPSVC_SOURCES}\
96cc708597SJiafei Pan				${PLAT_COMMON_PATH}/$(ARCH)/bl31_data.S
97cc708597SJiafei Pan
98cc708597SJiafei PanPLAT_BL_COMMON_SOURCES	+=	${PLAT_COMMON_PATH}/$(ARCH)/ls_helpers.S\
99cc708597SJiafei Pan				${PLAT_SOC_PATH}/aarch64/${SOC}_helpers.S\
100cc708597SJiafei Pan				${NV_STORAGE_SOURCES}\
101cc708597SJiafei Pan				${WARM_RST_BL_COMM_SOURCES}\
102cc708597SJiafei Pan				${PLAT_SOC_PATH}/soc.c
103cc708597SJiafei Pan
104cc708597SJiafei Panifeq (${TEST_BL31}, 1)
105cc708597SJiafei PanBL31_SOURCES		+=	${PLAT_SOC_PATH}/$(ARCH)/bootmain64.S\
106cc708597SJiafei Pan				${PLAT_SOC_PATH}/$(ARCH)/nonboot64.S
107cc708597SJiafei Panendif
108cc708597SJiafei Pan
109cc708597SJiafei PanBL2_SOURCES		+=	${DDR_CNTLR_SOURCES}\
110cc708597SJiafei Pan				${TBBR_SOURCES}\
111cc708597SJiafei Pan				${FUSE_SOURCES}
112cc708597SJiafei Pan
113cc708597SJiafei Pan# Adding TFA setup files
114cc708597SJiafei Paninclude ${PLAT_PATH}/common/setup/common.mk
115