blob: cb917a4e3d4f0cba589678febdf2fc15b22d0270 [file] [log] [blame]
Kevin Peng62a87112020-07-07 15:07:46 +08001#-------------------------------------------------------------------------------
Raef Colesb8f0c312021-05-26 14:17:37 +01002# Copyright (c) 2020-2022, Arm Limited. All rights reserved.
Chris Brand592c98e2022-05-20 14:46:54 -07003# Copyright (c) 2022 Cypress Semiconductor Corporation (an Infineon company)
4# 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.
Chris Brand592c98e2022-05-20 14:46:54 -070017if (EXISTS ${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/preload_ns.cmake)
Raef Coles5ee45ed2020-09-24 11:25:44 +010018 include(${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/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
David Hu73f259b2020-12-07 10:58:41 +080040#################### TF-M NS interface (header only) ###########################
41
42add_library(tfm_ns_interface INTERFACE)
43
David Hucdc51fb2021-04-06 18:10:46 +080044# Include interface headers exported by TF-M
David Hu73f259b2020-12-07 10:58:41 +080045target_include_directories(tfm_ns_interface
46 INTERFACE
47 ${INTERFACE_INC_DIR}
48 ${CMAKE_BINARY_DIR}/generated/interface/include
David Hu8e683252020-12-17 18:02:32 +080049 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${INTERFACE_INC_DIR}/multi_core>
David Hu98adf322020-09-01 16:18:46 +080050 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${CMAKE_SOURCE_DIR}/platform/ext/cmsis>
David Hu73f259b2020-12-07 10:58:41 +080051)
52
David Hucdc51fb2021-04-06 18:10:46 +080053# Include NS local interface headers
54target_include_directories(tfm_ns_interface
55 INTERFACE
56 ${NS_INTERFACE_DIR}
Xinyu Zhangeebbea32021-09-01 15:26:39 +080057 ${NSID_MGR_DIR}
David Hucdc51fb2021-04-06 18:10:46 +080058)
59
David Hu73f259b2020-12-07 10:58:41 +080060# PSA interface files are generated from a template
61add_dependencies(tfm_ns_interface
62 tfm_generated_files
63)
64
65# Include selection of Secure Partitions from TF-M build.
66# It can be replaced by NS side configurations later.
67target_link_libraries(tfm_ns_interface
68 INTERFACE
69 tfm_partition_defs
70)
71
72target_compile_definitions(tfm_ns_interface
73 INTERFACE
74 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
75 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
Xinyu Zhangeebbea32021-09-01 15:26:39 +080076 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
Xinyu Zhang92fe7582021-09-24 17:11:49 +080077 $<$<BOOL:${TEST_NS_MANAGE_NSID}>:TEST_NS_MANAGE_NSID>
David Hu73f259b2020-12-07 10:58:41 +080078 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hu402a2982020-12-17 22:31:04 +080079 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:TFM_MULTI_CORE_NS_OS>
David Hu98adf322020-09-01 16:18:46 +080080 $<$<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 +080081 $<$<BOOL:${FORWARD_PROT_MSG}>:FORWARD_PROT_MSG>
82)
83
Kevin Peng06108cd2022-06-09 11:37:39 +080084target_compile_options(tfm_ns_interface
85 INTERFACE
86 ${COMPILER_CP_FLAG}
87)
88
David Hu73f259b2020-12-07 10:58:41 +080089###################### TF-M NS interface api (NS lib) ##########################
90
91add_library(tfm_api_ns STATIC)
92
Xinyu Zhangeebbea32021-09-01 15:26:39 +080093target_sources(tfm_api_ns
94 PRIVATE
95 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${NSID_MGR_DIR}/tfm_nsid_manager.c>
96)
97
David Hu73f259b2020-12-07 10:58:41 +080098if (${TFM_PSA_API})
99 target_sources(tfm_api_ns PRIVATE
Jianliang Shen7a814e42021-10-18 15:25:39 +0800100 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PLATFORM}>>:${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c>
101 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c>
102 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c>
103 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_CRYPTO}>>:${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c>
104 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_ipc_api.c>
Sherry Zhang92c499a2021-03-08 18:14:15 +0800105 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_ipc_api.c>
106 )
David Hu73f259b2020-12-07 10:58:41 +0800107
108 if (TFM_MULTI_CORE_TOPOLOGY)
109 target_sources(tfm_api_ns PRIVATE
David Hu8e683252020-12-17 18:02:32 +0800110 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
111 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hu98adf322020-09-01 16:18:46 +0800112 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c>
113 $<$<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>
David Hu73f259b2020-12-07 10:58:41 +0800114 )
David Hucdc51fb2021-04-06 18:10:46 +0800115
116 # NS RTOS specific implementation of NS mailbox
117 target_sources(tfm_api_ns PRIVATE
118 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c>
shejia01e0dd80a2021-07-12 17:47:50 +0800119 $<$<BOOL:${TEST_NS_MULTI_CORE}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_test.c>
David Hucdc51fb2021-04-06 18:10:46 +0800120 )
David Hu73f259b2020-12-07 10:58:41 +0800121 else()
122 target_sources(tfm_api_ns PRIVATE
David Hu73f259b2020-12-07 10:58:41 +0800123 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
124 )
David Hucdc51fb2021-04-06 18:10:46 +0800125
126 # NS specific implementation of NS interface dispacther
127 target_sources(tfm_api_ns PRIVATE
128 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
129 )
David Hu73f259b2020-12-07 10:58:41 +0800130 endif()
131else()
132 target_sources(tfm_api_ns PRIVATE
133 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_func_api.c>
134 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${INTERFACE_SRC_DIR}/tfm_audit_func_api.c>
135 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_func_api.c>
136 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_func_api.c>
137 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c>
138 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c>
Sherry Zhang92c499a2021-03-08 18:14:15 +0800139 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_func_api.c>
David Hucdc51fb2021-04-06 18:10:46 +0800140 )
141
142 # NS specific implementation of NS interface dispacther
143 target_sources(tfm_api_ns PRIVATE
144 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
David Hu73f259b2020-12-07 10:58:41 +0800145 )
146endif()
147
148target_link_libraries(tfm_api_ns
149 PUBLIC
150 tfm_ns_interface
151 PRIVATE
Sherry Zhang8342d7d2021-10-14 17:57:26 +0800152 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800153 platform_ns
David Hu73f259b2020-12-07 10:58:41 +0800154)
155
Raef Coles5ee45ed2020-09-24 11:25:44 +0100156############################# PSA test integration #############################
157
Raef Colesc922f252020-10-05 10:49:30 +0100158if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
159 if(NOT SUITE)
160 set(SUITE ${TEST_PSA_API})
161 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100162
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200163 if (NOT DEFINED PSA_API_TEST_TARGET)
164 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
165 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100166
Raef Colesc922f252020-10-05 10:49:30 +0100167 if(NOT TARGET)
168 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
169 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
170 else()
171 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
172 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100173 endif()
174
Raef Coles5ee45ed2020-09-24 11:25:44 +0100175
Raef Colesc922f252020-10-05 10:49:30 +0100176 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800177 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100178 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100179 ${CMAKE_BINARY_DIR}/generated/interface/include
180 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100181 endif()
182
Raef Colesc922f252020-10-05 10:49:30 +0100183 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100184 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100185 endif()
186 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
187 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
188 endif()
189
190 if (NOT TOOLCHAIN)
191 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
192 set(TOOLCHAIN GNUARM)
193 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
194 set(TOOLCHAIN ARMCLANG)
195 endif()
196 endif()
197
198 if (NOT CPU_ARCH)
Chris Brandddcf5292021-10-27 13:50:35 -0700199 if (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
Raef Colesc922f252020-10-05 10:49:30 +0100200 set(CPU_ARCH armv8m_ml)
Chris Brandddcf5292021-10-27 13:50:35 -0700201 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
Raef Colesc922f252020-10-05 10:49:30 +0100202 set(CPU_ARCH armv8m_bl)
Chris Brandddcf5292021-10-27 13:50:35 -0700203 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
Raef Colesc922f252020-10-05 10:49:30 +0100204 set(CPU_ARCH armv7m)
205 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100206 endif()
207
208 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Raef Coles4817eb82022-01-18 12:33:24 +0000209
210 if (TEST_PSA_API STREQUAL IPC)
211 target_include_directories(tfm_partitions
212 INTERFACE
213 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests
214 )
215
216 target_sources(tfm_psa_rot_partition_driver_partition
217 PRIVATE
218 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_driver_partition_psa.c
219 )
220 target_link_libraries(tfm_psa_rot_partition_driver_partition
221 PRIVATE
222 psa_interface
223 platform_s
224 )
225 target_compile_definitions(tfm_psa_rot_partition_driver_partition
226 PRIVATE
227 CONFIG_TFM_BUILDING_SPE=1
228 TFM_LVL=${TFM_ISOLATION_LEVEL}
229 )
230
231 target_sources(tfm_app_rot_partition_client_partition
232 PRIVATE
233 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_client_partition_psa.c
234 )
235 target_link_libraries(tfm_app_rot_partition_client_partition
236 PRIVATE
237 psa_interface
238 platform_s
239 )
240 target_compile_definitions(tfm_app_rot_partition_client_partition
241 PRIVATE
242 CONFIG_TFM_BUILDING_SPE=1
243 TFM_LVL=${TFM_ISOLATION_LEVEL}
244 )
245
246 target_sources(tfm_app_rot_partition_server_partition
247 PRIVATE
248 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_server_partition_psa.c
249 )
250 target_link_libraries(tfm_app_rot_partition_server_partition
251 PRIVATE
252 psa_interface
253 platform_s
254 )
255 target_compile_definitions(tfm_app_rot_partition_server_partition
256 PRIVATE
257 CONFIG_TFM_BUILDING_SPE=1
258 TFM_LVL=${TFM_ISOLATION_LEVEL}
259 )
260
261 target_sources(tfm_partitions
262 INTERFACE
263 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_driver_partition_psa.c
264 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_client_partition_psa.c
265 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_server_partition_psa.c
266 )
267
268 target_link_libraries(tfm_partitions
269 INTERFACE
270 tfm_psa_rot_partition_driver_partition
271 tfm_app_rot_partition_client_partition
272 tfm_app_rot_partition_server_partition
273 )
274 endif()
Kevin Peng62a87112020-07-07 15:07:46 +0800275endif()
276
Raef Coles5ee45ed2020-09-24 11:25:44 +0100277############################# Test integration #################################
Kevin Peng62a87112020-07-07 15:07:46 +0800278
Kevin Peng342ec682022-04-29 10:36:58 +0800279add_library(tfm_test_app STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800280
Kevin Peng342ec682022-04-29 10:36:58 +0800281target_sources(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100282 PRIVATE
Kevin Peng342ec682022-04-29 10:36:58 +0800283 test_app.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100284)
Kevin Peng62a87112020-07-07 15:07:46 +0800285
Kevin Peng342ec682022-04-29 10:36:58 +0800286target_include_directories(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100287 PUBLIC
288 .
289)
Kevin Peng62a87112020-07-07 15:07:46 +0800290
Kevin Peng342ec682022-04-29 10:36:58 +0800291target_link_libraries(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100292 PRIVATE
David Huacba69e2021-09-10 15:36:48 +0800293 $<$<BOOL:${TEST_FRAMEWORK_NS}>:tfm_ns_tests>
Kevin Peng342ec682022-04-29 10:36:58 +0800294 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
295 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
296 $<$<BOOL:${TEST_PSA_API}>:test_combine>
Kevin Peng6e2e4352022-05-11 11:18:54 +0800297 tfm_api_ns
Paul Sokolovsky5d7925e2022-03-15 12:13:53 +0300298 tfm_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100299)
Kevin Peng62a87112020-07-07 15:07:46 +0800300
Kevin Peng342ec682022-04-29 10:36:58 +0800301target_compile_definitions(tfm_test_app
302 PRIVATE
shejia01e0dd80a2021-07-12 17:47:50 +0800303 $<$<BOOL:${TEST_FRAMEWORK_NS}>:TEST_FRAMEWORK_NS>
304 $<$<BOOL:${TEST_FRAMEWORK_S}>:TEST_FRAMEWORK_S>
shejia0126b2d782021-08-19 17:08:24 +0800305 $<$<BOOL:${TFM_LIB_MODEL}>:TFM_LIB_MODEL>
Kevin Peng342ec682022-04-29 10:36:58 +0800306 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100307)
Kevin Peng62a87112020-07-07 15:07:46 +0800308
Raef Coles5ee45ed2020-09-24 11:25:44 +0100309############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800310
Raef Coles5ee45ed2020-09-24 11:25:44 +0100311add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800312
Raef Coles5ee45ed2020-09-24 11:25:44 +0100313target_sources(tfm_ns
314 PRIVATE
315 main_ns.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100316)
Kevin Peng62a87112020-07-07 15:07:46 +0800317
Raef Coles5ee45ed2020-09-24 11:25:44 +0100318target_link_libraries(tfm_ns
319 PRIVATE
320 platform_ns
321 CMSIS_5_tfm_ns
Kevin Peng342ec682022-04-29 10:36:58 +0800322 tfm_test_app
Raef Colesb8f0c312021-05-26 14:17:37 +0100323 tfm_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100324)
Kevin Peng62a87112020-07-07 15:07:46 +0800325
Raef Coles5ee45ed2020-09-24 11:25:44 +0100326set_target_properties(tfm_ns PROPERTIES
327 SUFFIX ".axf"
328 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
329)
Kevin Peng62a87112020-07-07 15:07:46 +0800330
Raef Coles5ee45ed2020-09-24 11:25:44 +0100331target_link_options(tfm_ns
332 PRIVATE
333 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
334 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200335 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100336)
Kevin Peng62a87112020-07-07 15:07:46 +0800337
Raef Coles5ee45ed2020-09-24 11:25:44 +0100338add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800339
Raef Coles5ee45ed2020-09-24 11:25:44 +0100340############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800341
Raef Coles5ee45ed2020-09-24 11:25:44 +0100342include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800343
Raef Coles5ee45ed2020-09-24 11:25:44 +0100344set(FETCHCONTENT_QUIET FALSE)
345cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800346
Raef Coles5ee45ed2020-09-24 11:25:44 +0100347add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800348
Raef Coles5ee45ed2020-09-24 11:25:44 +0100349target_sources(CMSIS_5_tfm_ns
350 INTERFACE
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800351 ${NSID_MGR_DIR}/tz_shim_layer.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100352 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
353 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
354 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800355 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}/tfm_nsid_map_table.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100356)
Kevin Peng62a87112020-07-07 15:07:46 +0800357
Raef Coles5ee45ed2020-09-24 11:25:44 +0100358target_include_directories(CMSIS_5_tfm_ns
359 INTERFACE
360 ${CMSIS_5_PATH}/Core/Include
361 ${CMSIS_5_PATH}/RTOS2/Include
362 ${CMSIS_5_PATH}/RTOS2/RTX/Include
363 ${CMSIS_5_PATH}/RTOS2/RTX/Config
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800364 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100365)
Kevin Peng62a87112020-07-07 15:07:46 +0800366
Raef Coles5ee45ed2020-09-24 11:25:44 +0100367target_link_libraries(CMSIS_5_tfm_ns
368 INTERFACE
369 platform_ns
370)
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800371
372target_compile_definitions(CMSIS_5_tfm_ns
373 INTERFACE
374 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
375)