xref: /rk3399_ARM-atf/plat/arm/css/common/css_common.mk (revision 75eb87f073664eb9957192e320aa4436b372b4e8)
1b4315306SDan Handley#
2158ed580SPranav Madhu# Copyright (c) 2015-2022, Arm Limited and Contributors. All rights reserved.
3b4315306SDan Handley#
482cb2c1aSdp-arm# SPDX-License-Identifier: BSD-3-Clause
5b4315306SDan Handley#
6b4315306SDan Handley
77fb9a32dSVikram Kanigiri
87fb9a32dSVikram Kanigiri# By default, SCP images are needed by CSS platforms.
97fb9a32dSVikram KanigiriCSS_LOAD_SCP_IMAGES	?=	1
107fb9a32dSVikram Kanigiri
11c04a3b6cSSoby Mathew# By default, SCMI driver is disabled for CSS platforms
1218e279ebSSoby MathewCSS_USE_SCMI_SDS_DRIVER	?=	0
13c04a3b6cSSoby Mathew
14bd9344f6SAntonio Nino DiazPLAT_INCLUDES		+=	-Iinclude/plat/arm/css/common/aarch64
15b4315306SDan Handley
16b4315306SDan Handley
176f249345SYatharth KocharPLAT_BL_COMMON_SOURCES	+=	plat/arm/css/common/${ARCH}/css_helpers.S
18b4315306SDan Handley
19c76e0d13SYatharth KocharBL1_SOURCES		+=	plat/arm/css/common/css_bl1_setup.c
20b4315306SDan Handley
2118e279ebSSoby MathewBL2_SOURCES		+=	plat/arm/css/common/css_bl2_setup.c
22b4315306SDan Handley
2318e279ebSSoby MathewBL2U_SOURCES		+=	plat/arm/css/common/css_bl2u_setup.c
24dcda29f6SYatharth Kochar
25b12a2b49SSoby MathewBL31_SOURCES		+=	plat/arm/css/common/css_pm.c			\
26c04a3b6cSSoby Mathew				plat/arm/css/common/css_topology.c
27c04a3b6cSSoby Mathew
2818e279ebSSoby Mathewifeq (${CSS_USE_SCMI_SDS_DRIVER},0)
29c411396eSAntonio Nino DiazBL31_SOURCES		+=	drivers/arm/css/mhu/css_mhu.c			\
302d4135e0SAntonio Nino Diaz				drivers/arm/css/scp/css_pm_scpi.c		\
312d4135e0SAntonio Nino Diaz				drivers/arm/css/scpi/css_scpi.c
32c04a3b6cSSoby Mathewelse
33c411396eSAntonio Nino DiazBL31_SOURCES		+=	drivers/arm/css/mhu/css_mhu_doorbell.c		\
34c411396eSAntonio Nino Diaz				drivers/arm/css/scmi/scmi_ap_core_proto.c	\
3514928b88SAntonio Nino Diaz				drivers/arm/css/scmi/scmi_common.c		\
3614928b88SAntonio Nino Diaz				drivers/arm/css/scmi/scmi_pwr_dmn_proto.c	\
3714928b88SAntonio Nino Diaz				drivers/arm/css/scmi/scmi_sys_pwr_proto.c	\
38*14a28923SPranav Madhu				drivers/delay_timer/delay_timer.c		\
392d4135e0SAntonio Nino Diaz				drivers/arm/css/scp/css_pm_scmi.c
40c04a3b6cSSoby Mathewendif
41b4315306SDan Handley
427fb9a32dSVikram Kanigiri# Process CSS_LOAD_SCP_IMAGES flag
437fb9a32dSVikram Kanigiri$(eval $(call assert_boolean,CSS_LOAD_SCP_IMAGES))
447fb9a32dSVikram Kanigiri$(eval $(call add_define,CSS_LOAD_SCP_IMAGES))
457fb9a32dSVikram Kanigiri
467fb9a32dSVikram Kanigiriifeq (${CSS_LOAD_SCP_IMAGES},1)
474d045d0eSMasahiro Yamada  NEED_SCP_BL2 := yes
487fb9a32dSVikram Kanigiri  ifneq (${TRUSTED_BOARD_BOOT},0)
4933950dd8SMasahiro Yamada    $(eval $(call TOOL_ADD_IMG,scp_bl2u,--scp-fwu-cfg,FWU_))
507fb9a32dSVikram Kanigiri  endif
517fb9a32dSVikram Kanigiri
5218e279ebSSoby Mathew  ifeq (${CSS_USE_SCMI_SDS_DRIVER},1)
532d4135e0SAntonio Nino Diaz    BL2U_SOURCES	+=	drivers/arm/css/scp/css_sds.c			\
545932d194SAntonio Nino Diaz				drivers/arm/css/sds/sds.c
55556b966fSSandrine Bailleux
562d4135e0SAntonio Nino Diaz    BL2_SOURCES		+=	drivers/arm/css/scp/css_sds.c			\
575932d194SAntonio Nino Diaz				drivers/arm/css/sds/sds.c
5818e279ebSSoby Mathew  else
59c411396eSAntonio Nino Diaz    BL2U_SOURCES	+=	drivers/arm/css/mhu/css_mhu.c			\
602d4135e0SAntonio Nino Diaz				drivers/arm/css/scp/css_bom_bootloader.c	\
612d4135e0SAntonio Nino Diaz				drivers/arm/css/scpi/css_scpi.c
6218e279ebSSoby Mathew
63c411396eSAntonio Nino Diaz    BL2_SOURCES		+=	drivers/arm/css/mhu/css_mhu.c			\
642d4135e0SAntonio Nino Diaz				drivers/arm/css/scp/css_bom_bootloader.c	\
652d4135e0SAntonio Nino Diaz				drivers/arm/css/scpi/css_scpi.c
66556b966fSSandrine Bailleux    # Enable option to detect whether the SCP ROM firmware in use predates version
67556b966fSSandrine Bailleux    # 1.7.0 and therefore, is incompatible.
68556b966fSSandrine Bailleux    CSS_DETECT_PRE_1_7_0_SCP	:=	1
69556b966fSSandrine Bailleux
70556b966fSSandrine Bailleux    # Process CSS_DETECT_PRE_1_7_0_SCP flag
71556b966fSSandrine Bailleux    $(eval $(call assert_boolean,CSS_DETECT_PRE_1_7_0_SCP))
72556b966fSSandrine Bailleux    $(eval $(call add_define,CSS_DETECT_PRE_1_7_0_SCP))
7318e279ebSSoby Mathew  endif
7418e279ebSSoby Mathewendif
75c04a3b6cSSoby Mathew
7618e279ebSSoby Mathewifeq (${CSS_USE_SCMI_SDS_DRIVER},1)
775932d194SAntonio Nino Diaz  PLAT_BL_COMMON_SOURCES	+=	drivers/arm/css/sds/${ARCH}/sds_helpers.S
7818e279ebSSoby Mathewendif
79c04a3b6cSSoby Mathew
8018e279ebSSoby Mathew# Process CSS_USE_SCMI_SDS_DRIVER flag
8118e279ebSSoby Mathew$(eval $(call assert_boolean,CSS_USE_SCMI_SDS_DRIVER))
8218e279ebSSoby Mathew$(eval $(call add_define,CSS_USE_SCMI_SDS_DRIVER))
832431d00fSAlexei Fedorov
842431d00fSAlexei Fedorov# Process CSS_NON_SECURE_UART flag
852431d00fSAlexei Fedorov# This undocumented build option is only to enable debug access to the UART
862431d00fSAlexei Fedorov# from non secure code, which is useful on some platforms.
872431d00fSAlexei Fedorov# Default (obviously) is off.
882431d00fSAlexei FedorovCSS_NON_SECURE_UART		:= 0
892431d00fSAlexei Fedorov$(eval $(call assert_boolean,CSS_NON_SECURE_UART))
902431d00fSAlexei Fedorov$(eval $(call add_define,CSS_NON_SECURE_UART))
912431d00fSAlexei Fedorov
92158ed580SPranav Madhu# Process CSS_SYSTEM_GRACEFUL_RESET flag
93158ed580SPranav Madhu# This build option can be used on CSS platforms that require all the CPUs
94158ed580SPranav Madhu# to execute the CPU specific power down sequence to complete a warm reboot
95158ed580SPranav Madhu# sequence in which only the CPUs are power cycled.
96158ed580SPranav MadhuCSS_SYSTEM_GRACEFUL_RESET	:= 0
97158ed580SPranav Madhu$(eval $(call add_define,CSS_SYSTEM_GRACEFUL_RESET))
98