blob: c15c12fe012db67586ef9f4ad96475647a874821 [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 Brandddcf5292021-10-27 13:50:35 -07003# Copyright (c) 2022, Cypress Semiconductor Corp. All rights reserved.
Kevin Peng62a87112020-07-07 15:07:46 +08004#
5# SPDX-License-Identifier: BSD-3-Clause
6#
7#-------------------------------------------------------------------------------
8
Raef Coles5ee45ed2020-09-24 11:25:44 +01009cmake_minimum_required(VERSION 3.13)
Kevin Peng62a87112020-07-07 15:07:46 +080010project(tfm_ns LANGUAGES ASM C)
Kevin Peng62a87112020-07-07 15:07:46 +080011
Raef Coles5ee45ed2020-09-24 11:25:44 +010012# For multi-core projects, the NS app can be run on a different CPU to the
13# Secure code. To facilitate this, we once again reload the compiler to load the
14# setting for the NS CPU. Cmake settings are directory scoped so this affects
15# anything loaded from or declared in this dir.
16if (TFM_MULTI_CORE_TOPOLOGY)
17 include(${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/preload_ns.cmake)
Raef Coles34cffa72020-10-28 10:27:19 +000018 tfm_toolchain_reload_compiler()
David Hu402a2982020-12-17 22:31:04 +080019
20 # Enable TFM_MULTI_CORE_NS_OS when building with tf-m-tests NS App.
21 set(TFM_MULTI_CORE_NS_OS ON CACHE BOOL "Enable NS RTOS support in NS mailbox")
Kevin Peng62a87112020-07-07 15:07:46 +080022endif()
23
David Hu73f259b2020-12-07 10:58:41 +080024# In actual NS integration, NS side build should include the source files
25# exported by TF-M build.
26# Directly include interface folder to simplify the NS build in this demo, since
27# install always occurs at the end of build.
28set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src)
29set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include)
30
David Hucdc51fb2021-04-06 18:10:46 +080031# NS interface implemented by NSPE
32set(NS_INTERFACE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/../ns_interface)
33
Xinyu Zhangeebbea32021-09-01 15:26:39 +080034# nsid_manager
35set(NSID_MGR_DIR ${NS_INTERFACE_DIR}/ns_client_ext)
36
David Hu73f259b2020-12-07 10:58:41 +080037#################### TF-M NS interface (header only) ###########################
38
39add_library(tfm_ns_interface INTERFACE)
40
David Hucdc51fb2021-04-06 18:10:46 +080041# Include interface headers exported by TF-M
David Hu73f259b2020-12-07 10:58:41 +080042target_include_directories(tfm_ns_interface
43 INTERFACE
44 ${INTERFACE_INC_DIR}
45 ${CMAKE_BINARY_DIR}/generated/interface/include
David Hu8e683252020-12-17 18:02:32 +080046 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${INTERFACE_INC_DIR}/multi_core>
David Hu98adf322020-09-01 16:18:46 +080047 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${CMAKE_SOURCE_DIR}/platform/ext/cmsis>
David Hu73f259b2020-12-07 10:58:41 +080048)
49
David Hucdc51fb2021-04-06 18:10:46 +080050# Include NS local interface headers
51target_include_directories(tfm_ns_interface
52 INTERFACE
53 ${NS_INTERFACE_DIR}
Xinyu Zhangeebbea32021-09-01 15:26:39 +080054 ${NSID_MGR_DIR}
David Hucdc51fb2021-04-06 18:10:46 +080055)
56
David Hu73f259b2020-12-07 10:58:41 +080057# PSA interface files are generated from a template
58add_dependencies(tfm_ns_interface
59 tfm_generated_files
60)
61
62# Include selection of Secure Partitions from TF-M build.
63# It can be replaced by NS side configurations later.
64target_link_libraries(tfm_ns_interface
65 INTERFACE
66 tfm_partition_defs
67)
68
69target_compile_definitions(tfm_ns_interface
70 INTERFACE
71 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
72 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
Xinyu Zhangeebbea32021-09-01 15:26:39 +080073 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
Xinyu Zhang92fe7582021-09-24 17:11:49 +080074 $<$<BOOL:${TEST_NS_MANAGE_NSID}>:TEST_NS_MANAGE_NSID>
David Hu73f259b2020-12-07 10:58:41 +080075 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hu402a2982020-12-17 22:31:04 +080076 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:TFM_MULTI_CORE_NS_OS>
David Hu98adf322020-09-01 16:18:46 +080077 $<$<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 +080078 $<$<BOOL:${FORWARD_PROT_MSG}>:FORWARD_PROT_MSG>
79)
80
Kevin Peng06108cd2022-06-09 11:37:39 +080081target_compile_options(tfm_ns_interface
82 INTERFACE
83 ${COMPILER_CP_FLAG}
84)
85
David Hu73f259b2020-12-07 10:58:41 +080086###################### TF-M NS interface api (NS lib) ##########################
87
88add_library(tfm_api_ns STATIC)
89
Xinyu Zhangeebbea32021-09-01 15:26:39 +080090target_sources(tfm_api_ns
91 PRIVATE
92 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${NSID_MGR_DIR}/tfm_nsid_manager.c>
93)
94
David Hu73f259b2020-12-07 10:58:41 +080095if (${TFM_PSA_API})
96 target_sources(tfm_api_ns PRIVATE
Jianliang Shen7a814e42021-10-18 15:25:39 +080097 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PLATFORM}>>:${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c>
98 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c>
99 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c>
100 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_CRYPTO}>>:${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c>
101 $<$<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 +0800102 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_ipc_api.c>
103 )
David Hu73f259b2020-12-07 10:58:41 +0800104
105 if (TFM_MULTI_CORE_TOPOLOGY)
106 target_sources(tfm_api_ns PRIVATE
David Hu8e683252020-12-17 18:02:32 +0800107 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
108 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hu98adf322020-09-01 16:18:46 +0800109 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c>
110 $<$<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 +0800111 )
David Hucdc51fb2021-04-06 18:10:46 +0800112
113 # NS RTOS specific implementation of NS mailbox
114 target_sources(tfm_api_ns PRIVATE
115 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c>
shejia01e0dd80a2021-07-12 17:47:50 +0800116 $<$<BOOL:${TEST_NS_MULTI_CORE}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_test.c>
David Hucdc51fb2021-04-06 18:10:46 +0800117 )
David Hu73f259b2020-12-07 10:58:41 +0800118 else()
119 target_sources(tfm_api_ns PRIVATE
David Hu73f259b2020-12-07 10:58:41 +0800120 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
121 )
David Hucdc51fb2021-04-06 18:10:46 +0800122
123 # NS specific implementation of NS interface dispacther
124 target_sources(tfm_api_ns PRIVATE
125 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
126 )
David Hu73f259b2020-12-07 10:58:41 +0800127 endif()
128else()
129 target_sources(tfm_api_ns PRIVATE
130 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_func_api.c>
131 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${INTERFACE_SRC_DIR}/tfm_audit_func_api.c>
132 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_func_api.c>
133 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_func_api.c>
134 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c>
135 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c>
Sherry Zhang92c499a2021-03-08 18:14:15 +0800136 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_func_api.c>
David Hucdc51fb2021-04-06 18:10:46 +0800137 )
138
139 # NS specific implementation of NS interface dispacther
140 target_sources(tfm_api_ns PRIVATE
141 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
David Hu73f259b2020-12-07 10:58:41 +0800142 )
143endif()
144
145target_link_libraries(tfm_api_ns
146 PUBLIC
147 tfm_ns_interface
148 PRIVATE
Sherry Zhang8342d7d2021-10-14 17:57:26 +0800149 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800150 platform_ns
David Hu73f259b2020-12-07 10:58:41 +0800151)
152
Raef Coles5ee45ed2020-09-24 11:25:44 +0100153############################# PSA test integration #############################
154
Raef Colesc922f252020-10-05 10:49:30 +0100155if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
156 if(NOT SUITE)
157 set(SUITE ${TEST_PSA_API})
158 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100159
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200160 if (NOT DEFINED PSA_API_TEST_TARGET)
161 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
162 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100163
Raef Colesc922f252020-10-05 10:49:30 +0100164 if(NOT TARGET)
165 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
166 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
167 else()
168 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
169 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100170 endif()
171
Raef Coles5ee45ed2020-09-24 11:25:44 +0100172
Raef Colesc922f252020-10-05 10:49:30 +0100173 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800174 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100175 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100176 ${CMAKE_BINARY_DIR}/generated/interface/include
177 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100178 endif()
179
Raef Colesc922f252020-10-05 10:49:30 +0100180 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100181 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100182 endif()
183 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
184 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
185 endif()
186
187 if (NOT TOOLCHAIN)
188 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
189 set(TOOLCHAIN GNUARM)
190 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
191 set(TOOLCHAIN ARMCLANG)
192 endif()
193 endif()
194
195 if (NOT CPU_ARCH)
Chris Brandddcf5292021-10-27 13:50:35 -0700196 if (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
Raef Colesc922f252020-10-05 10:49:30 +0100197 set(CPU_ARCH armv8m_ml)
Chris Brandddcf5292021-10-27 13:50:35 -0700198 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
Raef Colesc922f252020-10-05 10:49:30 +0100199 set(CPU_ARCH armv8m_bl)
Chris Brandddcf5292021-10-27 13:50:35 -0700200 elseif (${TFM_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
Raef Colesc922f252020-10-05 10:49:30 +0100201 set(CPU_ARCH armv7m)
202 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100203 endif()
204
205 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Raef Coles4817eb82022-01-18 12:33:24 +0000206
207 if (TEST_PSA_API STREQUAL IPC)
208 target_include_directories(tfm_partitions
209 INTERFACE
210 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests
211 )
212
213 target_sources(tfm_psa_rot_partition_driver_partition
214 PRIVATE
215 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_driver_partition_psa.c
216 )
217 target_link_libraries(tfm_psa_rot_partition_driver_partition
218 PRIVATE
219 psa_interface
220 platform_s
221 )
222 target_compile_definitions(tfm_psa_rot_partition_driver_partition
223 PRIVATE
224 CONFIG_TFM_BUILDING_SPE=1
225 TFM_LVL=${TFM_ISOLATION_LEVEL}
226 )
227
228 target_sources(tfm_app_rot_partition_client_partition
229 PRIVATE
230 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_client_partition_psa.c
231 )
232 target_link_libraries(tfm_app_rot_partition_client_partition
233 PRIVATE
234 psa_interface
235 platform_s
236 )
237 target_compile_definitions(tfm_app_rot_partition_client_partition
238 PRIVATE
239 CONFIG_TFM_BUILDING_SPE=1
240 TFM_LVL=${TFM_ISOLATION_LEVEL}
241 )
242
243 target_sources(tfm_app_rot_partition_server_partition
244 PRIVATE
245 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/intermedia_server_partition_psa.c
246 )
247 target_link_libraries(tfm_app_rot_partition_server_partition
248 PRIVATE
249 psa_interface
250 platform_s
251 )
252 target_compile_definitions(tfm_app_rot_partition_server_partition
253 PRIVATE
254 CONFIG_TFM_BUILDING_SPE=1
255 TFM_LVL=${TFM_ISOLATION_LEVEL}
256 )
257
258 target_sources(tfm_partitions
259 INTERFACE
260 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_driver_partition_psa.c
261 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_client_partition_psa.c
262 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/auto_generated/load_info_server_partition_psa.c
263 )
264
265 target_link_libraries(tfm_partitions
266 INTERFACE
267 tfm_psa_rot_partition_driver_partition
268 tfm_app_rot_partition_client_partition
269 tfm_app_rot_partition_server_partition
270 )
271 endif()
Kevin Peng62a87112020-07-07 15:07:46 +0800272endif()
273
Raef Coles5ee45ed2020-09-24 11:25:44 +0100274############################# Test integration #################################
Kevin Peng62a87112020-07-07 15:07:46 +0800275
Kevin Peng342ec682022-04-29 10:36:58 +0800276add_library(tfm_test_app STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800277
Kevin Peng342ec682022-04-29 10:36:58 +0800278target_sources(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100279 PRIVATE
Kevin Peng342ec682022-04-29 10:36:58 +0800280 test_app.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100281)
Kevin Peng62a87112020-07-07 15:07:46 +0800282
Kevin Peng342ec682022-04-29 10:36:58 +0800283target_include_directories(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100284 PUBLIC
285 .
286)
Kevin Peng62a87112020-07-07 15:07:46 +0800287
Kevin Peng342ec682022-04-29 10:36:58 +0800288target_link_libraries(tfm_test_app
Raef Coles5ee45ed2020-09-24 11:25:44 +0100289 PRIVATE
David Huacba69e2021-09-10 15:36:48 +0800290 $<$<BOOL:${TEST_FRAMEWORK_NS}>:tfm_ns_tests>
Kevin Peng342ec682022-04-29 10:36:58 +0800291 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
292 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
293 $<$<BOOL:${TEST_PSA_API}>:test_combine>
Kevin Peng6e2e4352022-05-11 11:18:54 +0800294 tfm_api_ns
Paul Sokolovsky5d7925e2022-03-15 12:13:53 +0300295 tfm_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100296)
Kevin Peng62a87112020-07-07 15:07:46 +0800297
Kevin Peng342ec682022-04-29 10:36:58 +0800298target_compile_definitions(tfm_test_app
299 PRIVATE
shejia01e0dd80a2021-07-12 17:47:50 +0800300 $<$<BOOL:${TEST_FRAMEWORK_NS}>:TEST_FRAMEWORK_NS>
301 $<$<BOOL:${TEST_FRAMEWORK_S}>:TEST_FRAMEWORK_S>
shejia0126b2d782021-08-19 17:08:24 +0800302 $<$<BOOL:${TFM_LIB_MODEL}>:TFM_LIB_MODEL>
Kevin Peng342ec682022-04-29 10:36:58 +0800303 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100304)
Kevin Peng62a87112020-07-07 15:07:46 +0800305
Raef Coles5ee45ed2020-09-24 11:25:44 +0100306############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800307
Raef Coles5ee45ed2020-09-24 11:25:44 +0100308add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800309
Raef Coles5ee45ed2020-09-24 11:25:44 +0100310target_sources(tfm_ns
311 PRIVATE
312 main_ns.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100313)
Kevin Peng62a87112020-07-07 15:07:46 +0800314
Raef Coles5ee45ed2020-09-24 11:25:44 +0100315target_link_libraries(tfm_ns
316 PRIVATE
317 platform_ns
318 CMSIS_5_tfm_ns
Kevin Peng342ec682022-04-29 10:36:58 +0800319 tfm_test_app
Raef Colesb8f0c312021-05-26 14:17:37 +0100320 tfm_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100321)
Kevin Peng62a87112020-07-07 15:07:46 +0800322
Raef Coles5ee45ed2020-09-24 11:25:44 +0100323set_target_properties(tfm_ns PROPERTIES
324 SUFFIX ".axf"
325 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
326)
Kevin Peng62a87112020-07-07 15:07:46 +0800327
Raef Coles5ee45ed2020-09-24 11:25:44 +0100328target_link_options(tfm_ns
329 PRIVATE
330 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
331 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200332 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100333)
Kevin Peng62a87112020-07-07 15:07:46 +0800334
Raef Coles5ee45ed2020-09-24 11:25:44 +0100335add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800336
Raef Coles5ee45ed2020-09-24 11:25:44 +0100337############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800338
Raef Coles5ee45ed2020-09-24 11:25:44 +0100339include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800340
Raef Coles5ee45ed2020-09-24 11:25:44 +0100341set(FETCHCONTENT_QUIET FALSE)
342cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800343
Raef Coles5ee45ed2020-09-24 11:25:44 +0100344add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800345
Raef Coles5ee45ed2020-09-24 11:25:44 +0100346target_sources(CMSIS_5_tfm_ns
347 INTERFACE
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800348 ${NSID_MGR_DIR}/tz_shim_layer.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100349 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
350 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
351 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800352 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}/tfm_nsid_map_table.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100353)
Kevin Peng62a87112020-07-07 15:07:46 +0800354
Raef Coles5ee45ed2020-09-24 11:25:44 +0100355target_include_directories(CMSIS_5_tfm_ns
356 INTERFACE
357 ${CMSIS_5_PATH}/Core/Include
358 ${CMSIS_5_PATH}/RTOS2/Include
359 ${CMSIS_5_PATH}/RTOS2/RTX/Include
360 ${CMSIS_5_PATH}/RTOS2/RTX/Config
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800361 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100362)
Kevin Peng62a87112020-07-07 15:07:46 +0800363
Raef Coles5ee45ed2020-09-24 11:25:44 +0100364target_link_libraries(CMSIS_5_tfm_ns
365 INTERFACE
366 platform_ns
367)
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800368
369target_compile_definitions(CMSIS_5_tfm_ns
370 INTERFACE
371 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
372)