blob: 18123fadeb7eb110ef3aaf3d8589fefbe89eb389 [file] [log] [blame]
Kevin Peng62a87112020-07-07 15:07:46 +08001#-------------------------------------------------------------------------------
Summer Qin153f3df2022-11-17 15:51:02 +08002# Copyright (c) 2020-2023, Arm Limited. All rights reserved.
BohdanHunko75ee82b2023-02-03 14:47:01 +02003# Copyright (c) 2022-2023 Cypress Semiconductor Corporation (an Infineon company)
Chris Brand592c98e2022-05-20 14:46:54 -07004# or an affiliate of Cypress Semiconductor Corporation. All rights reserved.
Kevin Peng62a87112020-07-07 15:07:46 +08005#
6# SPDX-License-Identifier: BSD-3-Clause
7#
8#-------------------------------------------------------------------------------
9
Raef Coles5ee45ed2020-09-24 11:25:44 +010010cmake_minimum_required(VERSION 3.13)
Kevin Peng62a87112020-07-07 15:07:46 +080011project(tfm_ns LANGUAGES ASM C)
Kevin Peng62a87112020-07-07 15:07:46 +080012
Raef Coles5ee45ed2020-09-24 11:25:44 +010013# For multi-core projects, the NS app can be run on a different CPU to the
14# Secure code. To facilitate this, we once again reload the compiler to load the
15# setting for the NS CPU. Cmake settings are directory scoped so this affects
16# anything loaded from or declared in this dir.
Kevin Peng6b219f72023-01-13 12:00:49 +080017if (EXISTS ${TARGET_PLATFORM_PATH}/preload_ns.cmake)
18 include(${TARGET_PLATFORM_PATH}/preload_ns.cmake)
Raef Coles34cffa72020-10-28 10:27:19 +000019 tfm_toolchain_reload_compiler()
Chris Brand592c98e2022-05-20 14:46:54 -070020endif()
David Hu402a2982020-12-17 22:31:04 +080021
Chris Brand592c98e2022-05-20 14:46:54 -070022if (TFM_MULTI_CORE_TOPOLOGY)
David Hu402a2982020-12-17 22:31:04 +080023 # Enable TFM_MULTI_CORE_NS_OS when building with tf-m-tests NS App.
24 set(TFM_MULTI_CORE_NS_OS ON CACHE BOOL "Enable NS RTOS support in NS mailbox")
Kevin Peng62a87112020-07-07 15:07:46 +080025endif()
26
David Hu73f259b2020-12-07 10:58:41 +080027# In actual NS integration, NS side build should include the source files
28# exported by TF-M build.
29# Directly include interface folder to simplify the NS build in this demo, since
30# install always occurs at the end of build.
31set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src)
32set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include)
33
David Hucdc51fb2021-04-06 18:10:46 +080034# NS interface implemented by NSPE
35set(NS_INTERFACE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/../ns_interface)
36
Xinyu Zhangeebbea32021-09-01 15:26:39 +080037# nsid_manager
38set(NSID_MGR_DIR ${NS_INTERFACE_DIR}/ns_client_ext)
39
Kevin Peng7c54c5d2023-07-10 17:33:54 +080040############################# TF-M NS interface #####################################
41add_library(tfm_api_ns STATIC)
David Hu73f259b2020-12-07 10:58:41 +080042
David Hucdc51fb2021-04-06 18:10:46 +080043# Include interface headers exported by TF-M
Kevin Peng7c54c5d2023-07-10 17:33:54 +080044target_include_directories(tfm_api_ns
45 PUBLIC
David Hu73f259b2020-12-07 10:58:41 +080046 ${INTERFACE_INC_DIR}
47 ${CMAKE_BINARY_DIR}/generated/interface/include
Chris Brand5c8b6392022-05-20 14:46:12 -070048 $<$<BOOL:${TFM_PARTITION_NS_AGENT_MAILBOX}>:${INTERFACE_INC_DIR}/multi_core>
David Hu73f259b2020-12-07 10:58:41 +080049)
50
David Hucdc51fb2021-04-06 18:10:46 +080051# Include NS local interface headers
Kevin Peng7c54c5d2023-07-10 17:33:54 +080052target_include_directories(tfm_api_ns
53 PUBLIC
David Hucdc51fb2021-04-06 18:10:46 +080054 ${NS_INTERFACE_DIR}
Xinyu Zhangeebbea32021-09-01 15:26:39 +080055 ${NSID_MGR_DIR}
David Hucdc51fb2021-04-06 18:10:46 +080056)
57
David Hu73f259b2020-12-07 10:58:41 +080058# Include selection of Secure Partitions from TF-M build.
59# It can be replaced by NS side configurations later.
Kevin Peng7c54c5d2023-07-10 17:33:54 +080060target_link_libraries(tfm_api_ns
61 PUBLIC
Xinyu Zhang0e8266b2023-06-19 18:19:31 +080062 tfm_config
David Hu73f259b2020-12-07 10:58:41 +080063)
64
Kevin Peng7c54c5d2023-07-10 17:33:54 +080065target_compile_definitions(tfm_api_ns
66 PUBLIC
David Hu73f259b2020-12-07 10:58:41 +080067 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
Xinyu Zhangeebbea32021-09-01 15:26:39 +080068 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
Xinyu Zhang92fe7582021-09-24 17:11:49 +080069 $<$<BOOL:${TEST_NS_MANAGE_NSID}>:TEST_NS_MANAGE_NSID>
Chris Brand5c8b6392022-05-20 14:46:12 -070070 $<$<BOOL:${CONFIG_TFM_USE_TRUSTZONE}>:CONFIG_TFM_USE_TRUSTZONE>
David Hu73f259b2020-12-07 10:58:41 +080071 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hue7b73172022-10-12 22:26:41 +080072 $<$<BOOL:${TFM_PARTITION_NS_AGENT_MAILBOX}>:TFM_PARTITION_NS_AGENT_MAILBOX>
David Hu402a2982020-12-17 22:31:04 +080073 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:TFM_MULTI_CORE_NS_OS>
David Hu98adf322020-09-01 16:18:46 +080074 $<$<AND:$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>,$<BOOL:${TFM_MULTI_CORE_NS_OS}>>:TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD>
David Hu73f259b2020-12-07 10:58:41 +080075)
76
Kevin Peng7c54c5d2023-07-10 17:33:54 +080077target_compile_options(tfm_api_ns
78 PUBLIC
Kevin Peng06108cd2022-06-09 11:37:39 +080079 ${COMPILER_CP_FLAG}
80)
81
Xinyu Zhangeebbea32021-09-01 15:26:39 +080082target_sources(tfm_api_ns
83 PRIVATE
84 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${NSID_MGR_DIR}/tfm_nsid_manager.c>
85)
86
Summer Qind13f55b2022-10-09 11:29:57 +080087target_sources(tfm_api_ns PRIVATE
Summer Qinadddea52022-10-18 15:33:48 +080088 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_api.c>
89 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_api.c>
90 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_api.c>
91 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_api.c>
92 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_attest_api.c>
93 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_fwu_api.c>
Summer Qind13f55b2022-10-09 11:29:57 +080094 )
David Hu73f259b2020-12-07 10:58:41 +080095
Summer Qind13f55b2022-10-09 11:29:57 +080096if (TFM_PARTITION_NS_AGENT_MAILBOX)
David Hu73f259b2020-12-07 10:58:41 +080097 target_sources(tfm_api_ns PRIVATE
Summer Qind13f55b2022-10-09 11:29:57 +080098 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
99 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
100 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c>
101 $<$<AND:$<BOOL:${TFM_MULTI_CORE_NS_OS}>,$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_thread.c>
102 )
103
104 # NS RTOS specific implementation of NS mailbox
105 target_sources(tfm_api_ns PRIVATE
106 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c>
107 $<$<BOOL:${TEST_NS_MULTI_CORE}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_test.c>
David Hucdc51fb2021-04-06 18:10:46 +0800108 )
David Hu73f259b2020-12-07 10:58:41 +0800109endif()
110
Chris Brand5c8b6392022-05-20 14:46:12 -0700111target_sources(tfm_api_ns PRIVATE
Summer Qind13f55b2022-10-09 11:29:57 +0800112 $<$<BOOL:${CONFIG_TFM_USE_TRUSTZONE}>:${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c>
BohdanHunko75ee82b2023-02-03 14:47:01 +0200113 # NS specific implementation of NS interface dispatcher
114 $<$<BOOL:${CONFIG_TFM_USE_TRUSTZONE}>:${INTERFACE_SRC_DIR}/os_wrapper/tfm_ns_interface_rtos.c>
Chris Brand5c8b6392022-05-20 14:46:12 -0700115)
116
David Hu73f259b2020-12-07 10:58:41 +0800117target_link_libraries(tfm_api_ns
David Hu73f259b2020-12-07 10:58:41 +0800118 PRIVATE
Chris Brand5c8b6392022-05-20 14:46:12 -0700119 $<$<BOOL:${CONFIG_TFM_USE_TRUSTZONE}>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800120 platform_ns
David Hu73f259b2020-12-07 10:58:41 +0800121)
122
Raef Coles5ee45ed2020-09-24 11:25:44 +0100123############################# PSA test integration #############################
124
Raef Colesc922f252020-10-05 10:49:30 +0100125if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
126 if(NOT SUITE)
127 set(SUITE ${TEST_PSA_API})
128 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100129
Kevin Peng7cf20ef2023-03-27 15:29:58 +0800130 if (NOT DEFINED PSA_API_TEST_TARGET OR PSA_API_TEST_TARGET STREQUAL "")
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200131 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
132 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100133
Raef Colesc922f252020-10-05 10:49:30 +0100134 if(NOT TARGET)
135 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
136 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
137 else()
138 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
139 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100140 endif()
141
Raef Coles5ee45ed2020-09-24 11:25:44 +0100142
Raef Colesc922f252020-10-05 10:49:30 +0100143 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800144 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100145 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100146 ${CMAKE_BINARY_DIR}/generated/interface/include
147 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100148 endif()
149
Raef Colesc922f252020-10-05 10:49:30 +0100150 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100151 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100152 endif()
153 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
154 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
155 endif()
156
157 if (NOT TOOLCHAIN)
158 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
159 set(TOOLCHAIN GNUARM)
160 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
161 set(TOOLCHAIN ARMCLANG)
162 endif()
163 endif()
164
165 if (NOT CPU_ARCH)
Chris Brandddcf5292021-10-27 13:50:35 -0700166 if (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
Raef Colesc922f252020-10-05 10:49:30 +0100167 set(CPU_ARCH armv8m_ml)
Chris Brandddcf5292021-10-27 13:50:35 -0700168 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
Raef Colesc922f252020-10-05 10:49:30 +0100169 set(CPU_ARCH armv8m_bl)
Dávid Házi43aeb692023-03-30 10:22:27 +0200170 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8.1-m.main)
171 set(CPU_ARCH armv81m_ml)
Chris Brandddcf5292021-10-27 13:50:35 -0700172 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
Raef Colesc922f252020-10-05 10:49:30 +0100173 set(CPU_ARCH armv7m)
174 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100175 endif()
176
177 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Raef Coles4817eb82022-01-18 12:33:24 +0000178
179 if (TEST_PSA_API STREQUAL IPC)
180 target_include_directories(tfm_partitions
181 INTERFACE
182 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests
183 )
184
185 target_sources(tfm_psa_rot_partition_driver_partition
186 PRIVATE
187 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_driver_partition_psa.c
188 )
189 target_link_libraries(tfm_psa_rot_partition_driver_partition
190 PRIVATE
191 psa_interface
192 platform_s
193 )
194 target_compile_definitions(tfm_psa_rot_partition_driver_partition
195 PRIVATE
196 CONFIG_TFM_BUILDING_SPE=1
Xinyu Zhang03d6a932023-07-28 14:09:33 +0800197 TFM_ISOLATION_LEVEL=${TFM_ISOLATION_LEVEL}
Raef Coles4817eb82022-01-18 12:33:24 +0000198 )
199
200 target_sources(tfm_app_rot_partition_client_partition
201 PRIVATE
202 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_client_partition_psa.c
203 )
204 target_link_libraries(tfm_app_rot_partition_client_partition
205 PRIVATE
206 psa_interface
207 platform_s
208 )
209 target_compile_definitions(tfm_app_rot_partition_client_partition
210 PRIVATE
211 CONFIG_TFM_BUILDING_SPE=1
Xinyu Zhang03d6a932023-07-28 14:09:33 +0800212 TFM_ISOLATION_LEVEL=${TFM_ISOLATION_LEVEL}
Raef Coles4817eb82022-01-18 12:33:24 +0000213 )
214
215 target_sources(tfm_app_rot_partition_server_partition
216 PRIVATE
217 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_server_partition_psa.c
218 )
219 target_link_libraries(tfm_app_rot_partition_server_partition
220 PRIVATE
221 psa_interface
222 platform_s
223 )
224 target_compile_definitions(tfm_app_rot_partition_server_partition
225 PRIVATE
226 CONFIG_TFM_BUILDING_SPE=1
Xinyu Zhang03d6a932023-07-28 14:09:33 +0800227 TFM_ISOLATION_LEVEL=${TFM_ISOLATION_LEVEL}
Raef Coles4817eb82022-01-18 12:33:24 +0000228 )
229
230 target_sources(tfm_partitions
231 INTERFACE
232 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_driver_partition_psa.c
233 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_client_partition_psa.c
234 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_server_partition_psa.c
235 )
236
237 target_link_libraries(tfm_partitions
238 INTERFACE
239 tfm_psa_rot_partition_driver_partition
240 tfm_app_rot_partition_client_partition
241 tfm_app_rot_partition_server_partition
242 )
243 endif()
Kevin Peng62a87112020-07-07 15:07:46 +0800244endif()
245
Raef Coles5ee45ed2020-09-24 11:25:44 +0100246############################# Test integration #################################
Kevin Peng7f78a8f2023-07-21 14:15:54 +0800247if(CONFIG_TFM_ERPC_TEST_FRAMEWORK)
248 add_subdirectory(${CMAKE_CURRENT_LIST_DIR}/../erpc/server/app ${CMAKE_CURRENT_BINARY_DIR}/erpc)
Summer Qin153f3df2022-11-17 15:51:02 +0800249endif()
250
Kevin Peng342ec682022-04-29 10:36:58 +0800251add_library(tfm_test_app STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800252
Kevin Peng342ec682022-04-29 10:36:58 +0800253target_sources(tfm_test_app
chesun01a985c002023-04-12 16:16:12 +0800254 PUBLIC
255 $<$<BOOL:${CONFIG_GNU_SYSCALL_STUB_ENABLED}>:${CMAKE_SOURCE_DIR}/platform/ext/common/syscalls_stub.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100256 PRIVATE
Summer Qin153f3df2022-11-17 15:51:02 +0800257 $<$<NOT:$<BOOL:${CONFIG_TFM_ERPC_TEST_FRAMEWORK}>>:test_app.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100258)
Kevin Peng62a87112020-07-07 15:07:46 +0800259
Kevin Peng342ec682022-04-29 10:36:58 +0800260target_include_directories(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100261 PUBLIC
262 .
263)
Kevin Peng62a87112020-07-07 15:07:46 +0800264
Kevin Peng342ec682022-04-29 10:36:58 +0800265target_link_libraries(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100266 PRIVATE
David Huaecf9972023-04-06 17:41:16 +0800267 $<$<BOOL:${TFM_NS_REG_TEST}>:tfm_ns_tests>
Kevin Peng342ec682022-04-29 10:36:58 +0800268 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
269 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
270 $<$<BOOL:${TEST_PSA_API}>:test_combine>
Kevin Peng7f78a8f2023-07-21 14:15:54 +0800271 $<$<BOOL:${CONFIG_TFM_ERPC_TEST_FRAMEWORK}>:erpc_app>
Kevin Peng6e2e4352022-05-11 11:18:54 +0800272 tfm_api_ns
Paul Sokolovsky5d7925e2022-03-15 12:13:53 +0300273 tfm_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100274)
Kevin Peng62a87112020-07-07 15:07:46 +0800275
Kevin Peng342ec682022-04-29 10:36:58 +0800276target_compile_definitions(tfm_test_app
Jianliang Shen407bfef2023-08-07 16:37:25 +0800277 PUBLIC
David Huaecf9972023-04-06 17:41:16 +0800278 $<$<BOOL:${TFM_NS_REG_TEST}>:TFM_NS_REG_TEST>
Kevin Peng342ec682022-04-29 10:36:58 +0800279 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100280)
Kevin Peng62a87112020-07-07 15:07:46 +0800281
Jianliang Shen407bfef2023-08-07 16:37:25 +0800282############################# Profiling integration ############################
283
284if(CONFIG_TFM_ENALBE_PROFILING)
285 add_subdirectory(${TFM_PROFILING_PATH}/profiling_cases/tfm_ns_profiling
286 ${CMAKE_CURRENT_BINARY_DIR}/profiling_cases)
287endif()
288
Raef Coles5ee45ed2020-09-24 11:25:44 +0100289############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800290
Raef Coles5ee45ed2020-09-24 11:25:44 +0100291add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800292
Raef Coles5ee45ed2020-09-24 11:25:44 +0100293target_sources(tfm_ns
294 PRIVATE
295 main_ns.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100296)
Kevin Peng62a87112020-07-07 15:07:46 +0800297
Raef Coles5ee45ed2020-09-24 11:25:44 +0100298target_link_libraries(tfm_ns
299 PRIVATE
Raef Coles5ee45ed2020-09-24 11:25:44 +0100300 CMSIS_5_tfm_ns
Kevin Peng342ec682022-04-29 10:36:58 +0800301 tfm_test_app
Raef Colesb8f0c312021-05-26 14:17:37 +0100302 tfm_log
Kevin Peng3e612b82023-07-14 11:41:49 +0800303 platform_ns
Jianliang Shen407bfef2023-08-07 16:37:25 +0800304 $<$<BOOL:${CONFIG_TFM_ENALBE_PROFILING}>:tfm_ns_profiling>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100305)
Kevin Peng62a87112020-07-07 15:07:46 +0800306
Raef Coles5ee45ed2020-09-24 11:25:44 +0100307set_target_properties(tfm_ns PROPERTIES
308 SUFFIX ".axf"
309 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
310)
Kevin Peng62a87112020-07-07 15:07:46 +0800311
Raef Coles5ee45ed2020-09-24 11:25:44 +0100312target_link_options(tfm_ns
313 PRIVATE
314 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
315 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200316 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100317)
Kevin Peng62a87112020-07-07 15:07:46 +0800318
Raef Coles5ee45ed2020-09-24 11:25:44 +0100319add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800320
Raef Coles5ee45ed2020-09-24 11:25:44 +0100321############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800322
Raef Coles5ee45ed2020-09-24 11:25:44 +0100323include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800324
Raef Coles5ee45ed2020-09-24 11:25:44 +0100325set(FETCHCONTENT_QUIET FALSE)
326cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800327
Raef Coles5ee45ed2020-09-24 11:25:44 +0100328add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800329
Raef Coles5ee45ed2020-09-24 11:25:44 +0100330target_sources(CMSIS_5_tfm_ns
331 INTERFACE
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800332 ${NSID_MGR_DIR}/tz_shim_layer.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100333 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
334 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
335 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800336 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}/tfm_nsid_map_table.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100337)
Kevin Peng62a87112020-07-07 15:07:46 +0800338
Raef Coles5ee45ed2020-09-24 11:25:44 +0100339target_include_directories(CMSIS_5_tfm_ns
340 INTERFACE
341 ${CMSIS_5_PATH}/Core/Include
342 ${CMSIS_5_PATH}/RTOS2/Include
343 ${CMSIS_5_PATH}/RTOS2/RTX/Include
344 ${CMSIS_5_PATH}/RTOS2/RTX/Config
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800345 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100346)
Kevin Peng62a87112020-07-07 15:07:46 +0800347
Raef Coles5ee45ed2020-09-24 11:25:44 +0100348target_link_libraries(CMSIS_5_tfm_ns
349 INTERFACE
350 platform_ns
351)
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800352
353target_compile_definitions(CMSIS_5_tfm_ns
354 INTERFACE
355 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
356)