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