1# 2# Arm SCP/MCP Software 3# Copyright (c) 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(morello-fvp-bl2) 13 14target_include_directories( 15 morello-fvp-bl2 PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}/../include" 16 "${CMAKE_CURRENT_SOURCE_DIR}") 17 18# cmake-lint: disable=E1122 19 20target_sources( 21 morello-fvp-bl2 22 PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/config_armv7m_mpu.c" 23 "${CMAKE_CURRENT_SOURCE_DIR}/config_ssc.c" 24 "${CMAKE_CURRENT_SOURCE_DIR}/config_system_info.c" 25 "${CMAKE_CURRENT_SOURCE_DIR}/config_power_domain.c" 26 "${CMAKE_CURRENT_SOURCE_DIR}/config_ppu_v0.c" 27 "${CMAKE_CURRENT_SOURCE_DIR}/config_ppu_v1.c" 28 "${CMAKE_CURRENT_SOURCE_DIR}/config_dmc_bing.c" 29 "${CMAKE_CURRENT_SOURCE_DIR}/config_system_power.c" 30 "${CMAKE_CURRENT_SOURCE_DIR}/config_mhu.c" 31 "${CMAKE_CURRENT_SOURCE_DIR}/config_transport.c" 32 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi.c" 33 "${CMAKE_CURRENT_SOURCE_DIR}/config_sds.c" 34 "${CMAKE_CURRENT_SOURCE_DIR}/config_timer.c" 35 "${CMAKE_CURRENT_SOURCE_DIR}/config_cmn_skeena.c" 36 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_system_power.c" 37 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_power_domain.c" 38 "${CMAKE_CURRENT_SOURCE_DIR}/config_pl011.c" 39 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_management.c" 40 "${CMAKE_CURRENT_SOURCE_DIR}/config_morello_pll.c" 41 "${CMAKE_CURRENT_SOURCE_DIR}/config_pik_clock.c" 42 "${CMAKE_CURRENT_SOURCE_DIR}/config_css_clock.c" 43 "${CMAKE_CURRENT_SOURCE_DIR}/config_clock.c" 44 "${CMAKE_CURRENT_SOURCE_DIR}/config_psu.c" 45 "${CMAKE_CURRENT_SOURCE_DIR}/config_mock_psu.c" 46 "${CMAKE_CURRENT_SOURCE_DIR}/config_dvfs.c" 47 "${CMAKE_CURRENT_SOURCE_DIR}/config_scmi_perf.c" 48 "${CMAKE_CURRENT_SOURCE_DIR}/config_apcontext.c" 49 "${CMAKE_CURRENT_SOURCE_DIR}/config_resource_perms.c" 50 "${CMAKE_CURRENT_SOURCE_DIR}/../src/morello_core.c") 51 52 53if(SCP_ENABLE_DEBUGGER) 54 target_compile_definitions(morello-fvp-bl2 PRIVATE BUILD_HAS_DEBUGGER) 55 target_sources(morello-fvp-bl2 PRIVATE "${CMAKE_CURRENT_SOURCE_DIR}/config_debugger_cli.c") 56endif() 57 58# 59# Some of our firmware includes require CMSIS. 60# 61 62target_link_libraries(morello-fvp-bl2 PUBLIC cmsis::core-m) 63 64# 65# We explicitly add the CMSIS include directories to our interfaceinclude 66# directories. Each module target adds these include directories totheir own, 67# allowing them to include any firmware includes we expose. 68# 69 70target_include_directories( 71 morello-fvp-bl2 72 PUBLIC $<TARGET_PROPERTY:cmsis::core-m,INTERFACE_INCLUDE_DIRECTORIES>) 73 74if(SCP_ENABLE_DEBUGGER) 75 list(APPEND SCP_MODULES "debugger-cli") 76endif() 77 78set(SCP_MODULES ${SCP_MODULES} PARENT_SCOPE) 79set(SCP_MODULE_PATHS ${SCP_MODULE_PATHS} PARENT_SCOPE) 80