1# 2# Arm SCP/MCP Software 3# Copyright (c) 2021-2022, Arm Limited and Contributors. All rights reserved. 4# 5# SPDX-License-Identifier: BSD-3-Clause 6# 7 8# 9# Create the firmware target. 10# 11 12add_executable(sgm776-bl2) 13 14target_include_directories( 15 sgm776-bl2 PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/../include" 16 "${CMAKE_CURRENT_SOURCE_DIR}") 17 18# cmake-lint: disable=E1122 19 20target_sources( 21 sgm776-bl2 22 PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/config_pl011.c" 23 "${CMAKE_CURRENT_SOURCE_DIR}/config_timer.c" 24 "${CMAKE_CURRENT_SOURCE_DIR}/config_ddr_phy500.c" 25 "${CMAKE_CURRENT_SOURCE_DIR}/config_dmc500.c" 26 "${CMAKE_CURRENT_SOURCE_DIR}/config_sensor.c" 27 "${CMAKE_CURRENT_SOURCE_DIR}/config_ppu_v1.c" 28 "${CMAKE_CURRENT_SOURCE_DIR}/config_system_power.c" 29 "${CMAKE_CURRENT_SOURCE_DIR}/config_power_domain.c" 30 "${CMAKE_CURRENT_SOURCE_DIR}/config_sds.c" 31 "${CMAKE_CURRENT_SOURCE_DIR}/config_mhu.c" 32 "${CMAKE_CURRENT_SOURCE_DIR}/config_transport.c" 33 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi.c" 34 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_system_power.c" 35 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_clock.c" 36 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_perf.c" 37 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_apcore.c" 38 "${CMAKE_CURRENT_SOURCE_DIR}/config_system_pll.c" 39 "${CMAKE_CURRENT_SOURCE_DIR}/config_pik_clock.c" 40 "${CMAKE_CURRENT_SOURCE_DIR}/config_css_clock.c" 41 "${CMAKE_CURRENT_SOURCE_DIR}/config_clock.c" 42 "${CMAKE_CURRENT_SOURCE_DIR}/config_psu.c" 43 "${CMAKE_CURRENT_SOURCE_DIR}/config_mock_psu.c" 44 "${CMAKE_CURRENT_SOURCE_DIR}/config_dvfs.c" 45 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_power_domain.c" 46 PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/../src/sgm776_core.c" 47 "${CMAKE_CURRENT_SOURCE_DIR}/../src/config_sid.c" 48 "${CMAKE_CURRENT_SOURCE_DIR}/../src/config_system_info.c") 49 50if(SCP_ENABLE_RESOURCE_PERMISSIONS) 51 target_sources( 52 sgm776-bl2 53 PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/config_resource_perms.c") 54endif() 55 56# 57# Some of our firmware includes require CMSIS. 58# 59 60target_link_libraries(sgm776-bl2 PUBLIC cmsis::core-m) 61 62# 63# We explicitly add the CMSIS include directories to our interface include 64# directories. Each module target adds these include directories to their own, 65# allowing them to include any firmware includes we expose. 66# 67 68target_include_directories( 69 sgm776-bl2 70 PUBLIC $<TARGET_PROPERTY:cmsis::core-m,INTERFACE_INCLUDE_DIRECTORIES>) 71 72if(SCP_ENABLE_RESOURCE_PERMISSIONS) 73 list(APPEND SCP_MODULES "resource-perms") 74endif() 75 76set(SCP_MODULES ${SCP_MODULES} PARENT_SCOPE) 77set(SCP_MODULE_PATHS ${SCP_MODULE_PATHS} PARENT_SCOPE) 78