1b4315306SDan Handley# 21dc0714fSMasahiro Yamada# Copyright (c) 2015-2018, 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 14b4315306SDan HandleyPLAT_INCLUDES += -Iinclude/plat/arm/css/common \ 15b4315306SDan Handley -Iinclude/plat/arm/css/common/aarch64 16b4315306SDan Handley 17b4315306SDan Handley 186f249345SYatharth KocharPLAT_BL_COMMON_SOURCES += plat/arm/css/common/${ARCH}/css_helpers.S 19b4315306SDan Handley 20c76e0d13SYatharth KocharBL1_SOURCES += plat/arm/css/common/css_bl1_setup.c 21b4315306SDan Handley 2218e279ebSSoby MathewBL2_SOURCES += plat/arm/css/common/css_bl2_setup.c 23b4315306SDan Handley 2418e279ebSSoby MathewBL2U_SOURCES += plat/arm/css/common/css_bl2u_setup.c 25dcda29f6SYatharth Kochar 26b12a2b49SSoby MathewBL31_SOURCES += plat/arm/css/common/css_pm.c \ 27c04a3b6cSSoby Mathew plat/arm/css/common/css_topology.c 28c04a3b6cSSoby Mathew 2918e279ebSSoby Mathewifeq (${CSS_USE_SCMI_SDS_DRIVER},0) 30c04a3b6cSSoby MathewBL31_SOURCES += plat/arm/css/drivers/scp/css_pm_scpi.c \ 31a427785cSSamarth Parikh plat/arm/css/drivers/mhu/css_mhu.c \ 32b12a2b49SSoby Mathew plat/arm/css/drivers/scpi/css_scpi.c 33c04a3b6cSSoby Mathewelse 34c04a3b6cSSoby MathewBL31_SOURCES += plat/arm/css/drivers/scp/css_pm_scmi.c \ 35bfe3c449SDimitris Papastamos plat/arm/css/drivers/scmi/scmi_ap_core_proto.c \ 36c04a3b6cSSoby Mathew plat/arm/css/drivers/scmi/scmi_common.c \ 37c04a3b6cSSoby Mathew plat/arm/css/drivers/scmi/scmi_pwr_dmn_proto.c \ 38a427785cSSamarth Parikh plat/arm/css/drivers/scmi/scmi_sys_pwr_proto.c \ 39a427785cSSamarth Parikh plat/arm/css/drivers/mhu/css_mhu_doorbell.c 40c04a3b6cSSoby Mathewendif 41b4315306SDan Handley 42b4315306SDan Handleyifneq (${RESET_TO_BL31},0) 43d178637dSJuan Castillo $(error "Using BL31 as the reset vector is not supported on CSS platforms. \ 44b4315306SDan Handley Please set RESET_TO_BL31 to 0.") 45b4315306SDan Handleyendif 46b4315306SDan Handley 477fb9a32dSVikram Kanigiri# Process CSS_LOAD_SCP_IMAGES flag 487fb9a32dSVikram Kanigiri$(eval $(call assert_boolean,CSS_LOAD_SCP_IMAGES)) 497fb9a32dSVikram Kanigiri$(eval $(call add_define,CSS_LOAD_SCP_IMAGES)) 507fb9a32dSVikram Kanigiri 517fb9a32dSVikram Kanigiriifeq (${CSS_LOAD_SCP_IMAGES},1) 524d045d0eSMasahiro Yamada NEED_SCP_BL2 := yes 537fb9a32dSVikram Kanigiri ifneq (${TRUSTED_BOARD_BOOT},0) 5433950dd8SMasahiro Yamada $(eval $(call TOOL_ADD_IMG,scp_bl2u,--scp-fwu-cfg,FWU_)) 557fb9a32dSVikram Kanigiri endif 567fb9a32dSVikram Kanigiri 5718e279ebSSoby Mathew ifeq (${CSS_USE_SCMI_SDS_DRIVER},1) 5818e279ebSSoby Mathew BL2U_SOURCES += plat/arm/css/drivers/scp/css_sds.c \ 5918e279ebSSoby Mathew plat/arm/css/drivers/sds/sds.c 60556b966fSSandrine Bailleux 6118e279ebSSoby Mathew BL2_SOURCES += plat/arm/css/drivers/scp/css_sds.c \ 6218e279ebSSoby Mathew plat/arm/css/drivers/sds/sds.c 6318e279ebSSoby Mathew else 6418e279ebSSoby Mathew BL2U_SOURCES += plat/arm/css/drivers/scp/css_bom_bootloader.c \ 65a427785cSSamarth Parikh plat/arm/css/drivers/mhu/css_mhu.c \ 6618e279ebSSoby Mathew plat/arm/css/drivers/scpi/css_scpi.c 6718e279ebSSoby Mathew 6818e279ebSSoby Mathew BL2_SOURCES += plat/arm/css/drivers/scp/css_bom_bootloader.c \ 69a427785cSSamarth Parikh plat/arm/css/drivers/mhu/css_mhu.c \ 7018e279ebSSoby Mathew plat/arm/css/drivers/scpi/css_scpi.c 71556b966fSSandrine Bailleux # Enable option to detect whether the SCP ROM firmware in use predates version 72556b966fSSandrine Bailleux # 1.7.0 and therefore, is incompatible. 73556b966fSSandrine Bailleux CSS_DETECT_PRE_1_7_0_SCP := 1 74556b966fSSandrine Bailleux 75556b966fSSandrine Bailleux # Process CSS_DETECT_PRE_1_7_0_SCP flag 76556b966fSSandrine Bailleux $(eval $(call assert_boolean,CSS_DETECT_PRE_1_7_0_SCP)) 77556b966fSSandrine Bailleux $(eval $(call add_define,CSS_DETECT_PRE_1_7_0_SCP)) 7818e279ebSSoby Mathew endif 7918e279ebSSoby Mathewendif 80c04a3b6cSSoby Mathew 8118e279ebSSoby Mathewifeq (${CSS_USE_SCMI_SDS_DRIVER},1) 8218e279ebSSoby Mathew PLAT_BL_COMMON_SOURCES += plat/arm/css/drivers/sds/${ARCH}/sds_helpers.S 8318e279ebSSoby Mathewendif 84c04a3b6cSSoby Mathew 8518e279ebSSoby Mathew# Process CSS_USE_SCMI_SDS_DRIVER flag 8618e279ebSSoby Mathew$(eval $(call assert_boolean,CSS_USE_SCMI_SDS_DRIVER)) 8718e279ebSSoby Mathew$(eval $(call add_define,CSS_USE_SCMI_SDS_DRIVER)) 88*2431d00fSAlexei Fedorov 89*2431d00fSAlexei Fedorov# Process CSS_NON_SECURE_UART flag 90*2431d00fSAlexei Fedorov# This undocumented build option is only to enable debug access to the UART 91*2431d00fSAlexei Fedorov# from non secure code, which is useful on some platforms. 92*2431d00fSAlexei Fedorov# Default (obviously) is off. 93*2431d00fSAlexei FedorovCSS_NON_SECURE_UART := 0 94*2431d00fSAlexei Fedorov$(eval $(call assert_boolean,CSS_NON_SECURE_UART)) 95*2431d00fSAlexei Fedorov$(eval $(call add_define,CSS_NON_SECURE_UART)) 96*2431d00fSAlexei Fedorov 97