xref: /rk3399_ARM-atf/plat/rockchip/rk3568/platform.mk (revision ba3668f1865b44635e8c7aa3a38d0d315850cec3)
1#
2# Copyright (c) 2023-2025, Arm Limited and Contributors. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6
7RK_PLAT			:=	plat/rockchip
8RK_PLAT_SOC		:=	${RK_PLAT}/${PLAT}
9RK_PLAT_COMMON		:=	${RK_PLAT}/common
10
11DISABLE_BIN_GENERATION	:=	1
12GICV3_SUPPORT_GIC600	:=	1
13include lib/coreboot/coreboot.mk
14include lib/libfdt/libfdt.mk
15include lib/xlat_tables_v2/xlat_tables.mk
16# GIC-600 configuration
17GICV3_IMPL		:=	GIC600
18# Include GICv3 driver files
19include drivers/arm/gic/v3/gicv3.mk
20
21PLAT_INCLUDES		:=	-Iinclude/bl31					\
22				-Iinclude/common				\
23				-Iinclude/drivers				\
24				-Iinclude/drivers/arm				\
25				-Iinclude/drivers/auth				\
26				-Iinclude/drivers/io				\
27				-Iinclude/drivers/ti/uart			\
28				-Iinclude/lib					\
29				-Iinclude/lib/cpus/${ARCH}			\
30				-Iinclude/lib/el3_runtime			\
31				-Iinclude/lib/pmf				\
32				-Iinclude/lib/psci				\
33				-Iinclude/plat/common				\
34				-Iinclude/services				\
35				-Iinclude/plat/common/				\
36				-Idrivers/arm/gic/v3/				\
37				-Idrivers/scmi-msg/				\
38				-I${RK_PLAT_COMMON}/				\
39				-I${RK_PLAT_COMMON}/pmusram/			\
40				-I${RK_PLAT_COMMON}/include/			\
41				-I${RK_PLAT_COMMON}/drivers/pmu/		\
42				-I${RK_PLAT_COMMON}/drivers/parameter/		\
43				-I${RK_PLAT_COMMON}/scmi/			\
44				-I${RK_PLAT_SOC}/				\
45				-I${RK_PLAT_SOC}/drivers/otp/			\
46				-I${RK_PLAT_SOC}/drivers/pmu/			\
47				-I${RK_PLAT_SOC}/drivers/soc/			\
48				-I${RK_PLAT_SOC}/drivers/scmi/			\
49				-I${RK_PLAT_SOC}/include/
50
51RK_GIC_SOURCES		:=	${GICV3_SOURCES}				\
52				plat/common/plat_gicv3.c			\
53				${RK_PLAT}/common/rockchip_gicv3.c
54
55PLAT_BL_COMMON_SOURCES	:=	${XLAT_TABLES_LIB_SRCS}				\
56				common/desc_image_load.c			\
57				plat/common/aarch64/crash_console_helpers.S	\
58				lib/bl_aux_params/bl_aux_params.c		\
59				plat/common/plat_psci_common.c
60
61ifneq (${ENABLE_STACK_PROTECTOR},0)
62PLAT_BL_COMMON_SOURCES	+=	${RK_PLAT_COMMON}/rockchip_stack_protector.c
63endif
64
65BL31_SOURCES		+=	${RK_GIC_SOURCES}				\
66				drivers/arm/cci/cci.c				\
67				lib/cpus/aarch64/cortex_a55.S			\
68				drivers/ti/uart/aarch64/16550_console.S		\
69				drivers/delay_timer/delay_timer.c		\
70				drivers/delay_timer/generic_delay_timer.c	\
71				drivers/scmi-msg/base.c				\
72				drivers/scmi-msg/clock.c			\
73				drivers/scmi-msg/entry.c			\
74				drivers/scmi-msg/reset_domain.c			\
75				drivers/scmi-msg/smt.c				\
76				$(LIBFDT_SRCS)					\
77				${RK_PLAT_COMMON}/aarch64/plat_helpers.S	\
78				${RK_PLAT_COMMON}/bl31_plat_setup.c		\
79				${RK_PLAT_COMMON}/params_setup.c		\
80				${RK_PLAT_COMMON}/plat_pm.c			\
81				${RK_PLAT_COMMON}/plat_topology.c		\
82				${RK_PLAT_COMMON}/rockchip_sip_svc.c		\
83				${RK_PLAT_COMMON}/pmusram/cpus_on_fixed_addr.S	\
84				${RK_PLAT_COMMON}/drivers/parameter/ddr_parameter.c	\
85				${RK_PLAT_COMMON}/aarch64/platform_common.c	\
86				${RK_PLAT_COMMON}/scmi/scmi.c			\
87				${RK_PLAT_COMMON}/scmi/scmi_clock.c		\
88				${RK_PLAT_COMMON}/scmi/scmi_rstd.c		\
89				${RK_PLAT_SOC}/drivers/otp/otp.c		\
90				${RK_PLAT_SOC}/drivers/scmi/rk3568_clk.c	\
91				${RK_PLAT_SOC}/drivers/soc/soc.c		\
92				${RK_PLAT_SOC}/drivers/pmu/pmu.c		\
93				${RK_PLAT_SOC}/plat_sip_calls.c
94
95ENABLE_PLAT_COMPAT	:=	0
96MULTI_CONSOLE_API	:=	1
97# System coherency is managed in hardware
98HW_ASSISTED_COHERENCY	:=	1
99#Enable errata for cortex_a55
100ERRATA_A55_1530923	:=	1
101
102# When building for systems with hardware-assisted coherency, there's no need to
103# use USE_COHERENT_MEM. Require that USE_COHERENT_MEM must be set to 0 too.
104USE_COHERENT_MEM	:=	0
105
106$(eval $(call add_define,PLAT_SKIP_OPTEE_S_EL1_INT_REGISTER))
107PLAT_EXTRA_LD_SCRIPT	:=	1
108
109# Do not enable SVE
110ENABLE_SVE_FOR_NS	:=	0
111