blob: 96134940d7d780555c20fe946d41b4b39df1fe40 [file] [log] [blame]
Kevin Peng62a87112020-07-07 15:07:46 +08001#-------------------------------------------------------------------------------
David Hu48369db2020-12-17 17:31:54 +08002# Copyright (c) 2020-2021, Arm Limited. All rights reserved.
Kevin Peng62a87112020-07-07 15:07:46 +08003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Raef Coles5ee45ed2020-09-24 11:25:44 +01008cmake_minimum_required(VERSION 3.13)
Kevin Peng62a87112020-07-07 15:07:46 +08009project(tfm_ns LANGUAGES ASM C)
Kevin Peng62a87112020-07-07 15:07:46 +080010
Raef Coles5ee45ed2020-09-24 11:25:44 +010011# For multi-core projects, the NS app can be run on a different CPU to the
12# Secure code. To facilitate this, we once again reload the compiler to load the
13# setting for the NS CPU. Cmake settings are directory scoped so this affects
14# anything loaded from or declared in this dir.
15if (TFM_MULTI_CORE_TOPOLOGY)
16 include(${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/preload_ns.cmake)
Raef Coles34cffa72020-10-28 10:27:19 +000017 tfm_toolchain_reload_compiler()
David Hu402a2982020-12-17 22:31:04 +080018
19 # Enable TFM_MULTI_CORE_NS_OS when building with tf-m-tests NS App.
20 set(TFM_MULTI_CORE_NS_OS ON CACHE BOOL "Enable NS RTOS support in NS mailbox")
Kevin Peng62a87112020-07-07 15:07:46 +080021endif()
22
David Hu73f259b2020-12-07 10:58:41 +080023# In actual NS integration, NS side build should include the source files
24# exported by TF-M build.
25# Directly include interface folder to simplify the NS build in this demo, since
26# install always occurs at the end of build.
27set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src)
28set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include)
29
David Hucdc51fb2021-04-06 18:10:46 +080030# NS interface implemented by NSPE
31set(NS_INTERFACE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/../ns_interface)
32
Xinyu Zhangeebbea32021-09-01 15:26:39 +080033# nsid_manager
34set(NSID_MGR_DIR ${NS_INTERFACE_DIR}/ns_client_ext)
35
David Hu73f259b2020-12-07 10:58:41 +080036#################### TF-M NS interface (header only) ###########################
37
38add_library(tfm_ns_interface INTERFACE)
39
David Hucdc51fb2021-04-06 18:10:46 +080040# Include interface headers exported by TF-M
David Hu73f259b2020-12-07 10:58:41 +080041target_include_directories(tfm_ns_interface
42 INTERFACE
43 ${INTERFACE_INC_DIR}
44 ${CMAKE_BINARY_DIR}/generated/interface/include
David Hu8e683252020-12-17 18:02:32 +080045 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${INTERFACE_INC_DIR}/multi_core>
David Hu98adf322020-09-01 16:18:46 +080046 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${CMAKE_SOURCE_DIR}/platform/ext/cmsis>
David Hu73f259b2020-12-07 10:58:41 +080047)
48
David Hucdc51fb2021-04-06 18:10:46 +080049# Include NS local interface headers
50target_include_directories(tfm_ns_interface
51 INTERFACE
52 ${NS_INTERFACE_DIR}
Xinyu Zhangeebbea32021-09-01 15:26:39 +080053 ${NSID_MGR_DIR}
David Hucdc51fb2021-04-06 18:10:46 +080054)
55
David Hu73f259b2020-12-07 10:58:41 +080056# PSA interface files are generated from a template
57add_dependencies(tfm_ns_interface
58 tfm_generated_files
59)
60
61# Include selection of Secure Partitions from TF-M build.
62# It can be replaced by NS side configurations later.
63target_link_libraries(tfm_ns_interface
64 INTERFACE
65 tfm_partition_defs
66)
67
68target_compile_definitions(tfm_ns_interface
69 INTERFACE
70 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
71 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
Xinyu Zhangeebbea32021-09-01 15:26:39 +080072 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
David Hu73f259b2020-12-07 10:58:41 +080073 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hu402a2982020-12-17 22:31:04 +080074 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:TFM_MULTI_CORE_NS_OS>
David Hu98adf322020-09-01 16:18:46 +080075 $<$<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 +080076 $<$<BOOL:${FORWARD_PROT_MSG}>:FORWARD_PROT_MSG>
77)
78
79###################### TF-M NS interface api (NS lib) ##########################
80
81add_library(tfm_api_ns STATIC)
82
Xinyu Zhangeebbea32021-09-01 15:26:39 +080083target_sources(tfm_api_ns
84 PRIVATE
85 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${NSID_MGR_DIR}/tfm_nsid_manager.c>
86)
87
David Hu73f259b2020-12-07 10:58:41 +080088if (${TFM_PSA_API})
89 target_sources(tfm_api_ns PRIVATE
Jianliang Shen7a814e42021-10-18 15:25:39 +080090 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PLATFORM}>>:${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c>
91 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c>
92 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c>
93 $<$<OR:$<BOOL:${FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_CRYPTO}>>:${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c>
94 $<$<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 +080095 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_ipc_api.c>
96 )
David Hu73f259b2020-12-07 10:58:41 +080097
98 if (TFM_MULTI_CORE_TOPOLOGY)
99 target_sources(tfm_api_ns PRIVATE
David Hu8e683252020-12-17 18:02:32 +0800100 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
101 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hu98adf322020-09-01 16:18:46 +0800102 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_NS_OS_MAILBOX_THREAD}>>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c>
103 $<$<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 +0800104 )
David Hucdc51fb2021-04-06 18:10:46 +0800105
106 # NS RTOS specific implementation of NS mailbox
107 target_sources(tfm_api_ns PRIVATE
108 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c>
shejia01e0dd80a2021-07-12 17:47:50 +0800109 $<$<BOOL:${TEST_NS_MULTI_CORE}>:${NS_INTERFACE_DIR}/multi_core/tfm_ns_mailbox_test.c>
David Hucdc51fb2021-04-06 18:10:46 +0800110 )
David Hu73f259b2020-12-07 10:58:41 +0800111 else()
112 target_sources(tfm_api_ns PRIVATE
David Hu73f259b2020-12-07 10:58:41 +0800113 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
114 )
David Hucdc51fb2021-04-06 18:10:46 +0800115
116 # NS specific implementation of NS interface dispacther
117 target_sources(tfm_api_ns PRIVATE
118 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
119 )
David Hu73f259b2020-12-07 10:58:41 +0800120 endif()
121else()
122 target_sources(tfm_api_ns PRIVATE
123 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_func_api.c>
124 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${INTERFACE_SRC_DIR}/tfm_audit_func_api.c>
125 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_func_api.c>
126 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_func_api.c>
127 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c>
128 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c>
Sherry Zhang92c499a2021-03-08 18:14:15 +0800129 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${INTERFACE_SRC_DIR}/tfm_firmware_update_func_api.c>
David Hucdc51fb2021-04-06 18:10:46 +0800130 )
131
132 # NS specific implementation of NS interface dispacther
133 target_sources(tfm_api_ns PRIVATE
134 ${CMAKE_CURRENT_SOURCE_DIR}/tfm_ns_interface.c
David Hu73f259b2020-12-07 10:58:41 +0800135 )
136endif()
137
138target_link_libraries(tfm_api_ns
139 PUBLIC
140 tfm_ns_interface
141 PRIVATE
Sherry Zhang8342d7d2021-10-14 17:57:26 +0800142 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800143 platform_ns
David Hu73f259b2020-12-07 10:58:41 +0800144)
145
Raef Coles5ee45ed2020-09-24 11:25:44 +0100146############################# PSA test integration #############################
147
Raef Colesc922f252020-10-05 10:49:30 +0100148if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
149 if(NOT SUITE)
150 set(SUITE ${TEST_PSA_API})
151 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100152
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200153 if (NOT DEFINED PSA_API_TEST_TARGET)
154 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
155 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100156
Raef Colesc922f252020-10-05 10:49:30 +0100157 if(NOT TARGET)
158 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
159 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
160 else()
161 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
162 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100163 endif()
164
Raef Coles5ee45ed2020-09-24 11:25:44 +0100165
Raef Colesc922f252020-10-05 10:49:30 +0100166 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800167 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100168 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100169 ${CMAKE_BINARY_DIR}/generated/interface/include
170 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100171 endif()
172
Raef Colesc922f252020-10-05 10:49:30 +0100173 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100174 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100175 endif()
176 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
177 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
178 endif()
179
180 if (NOT TOOLCHAIN)
181 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
182 set(TOOLCHAIN GNUARM)
183 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
184 set(TOOLCHAIN ARMCLANG)
185 endif()
186 endif()
187
188 if (NOT CPU_ARCH)
189 if (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
190 set(CPU_ARCH armv8m_ml)
191 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
192 set(CPU_ARCH armv8m_bl)
193 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
194 set(CPU_ARCH armv7m)
195 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100196 endif()
197
198 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Kevin Peng62a87112020-07-07 15:07:46 +0800199endif()
200
Raef Coles5ee45ed2020-09-24 11:25:44 +0100201############################# Test integration #################################
Kevin Peng62a87112020-07-07 15:07:46 +0800202
Raef Coles5ee45ed2020-09-24 11:25:44 +0100203add_library(tfm_ns_integration_test STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800204
Raef Coles5ee45ed2020-09-24 11:25:44 +0100205target_sources(tfm_ns_integration_test
206 PRIVATE
207 tfm_integ_test.c
208)
Kevin Peng62a87112020-07-07 15:07:46 +0800209
Raef Coles5ee45ed2020-09-24 11:25:44 +0100210target_include_directories(tfm_ns_integration_test
211 PUBLIC
212 .
213)
Kevin Peng62a87112020-07-07 15:07:46 +0800214
Raef Coles5ee45ed2020-09-24 11:25:44 +0100215target_link_libraries(tfm_ns_integration_test
Raef Coles5ee45ed2020-09-24 11:25:44 +0100216 PRIVATE
David Huacba69e2021-09-10 15:36:48 +0800217 $<$<BOOL:${TEST_FRAMEWORK_NS}>:tfm_ns_tests>
218 $<$<BOOL:${TEST_FRAMEWORK_S}>:tfm_ns_interface>
219 $<$<BOOL:${TEST_FRAMEWORK_S}>:tfm_api_ns>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100220)
Kevin Peng62a87112020-07-07 15:07:46 +0800221
Raef Coles5ee45ed2020-09-24 11:25:44 +0100222target_compile_definitions(tfm_ns_integration_test
223 PUBLIC
shejia01e0dd80a2021-07-12 17:47:50 +0800224 $<$<BOOL:${TEST_FRAMEWORK_NS}>:TEST_FRAMEWORK_NS>
225 $<$<BOOL:${TEST_FRAMEWORK_S}>:TEST_FRAMEWORK_S>
shejia0126b2d782021-08-19 17:08:24 +0800226 $<$<BOOL:${TFM_LIB_MODEL}>:TFM_LIB_MODEL>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100227)
Kevin Peng62a87112020-07-07 15:07:46 +0800228
Raef Coles5ee45ed2020-09-24 11:25:44 +0100229############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800230
Raef Coles5ee45ed2020-09-24 11:25:44 +0100231add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800232
Raef Coles5ee45ed2020-09-24 11:25:44 +0100233target_sources(tfm_ns
234 PRIVATE
235 main_ns.c
Kevin Peng0d3a3812020-12-23 02:17:57 +0000236 $<$<BOOL:${TEST_PSA_API}>:psa_api_test.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100237)
Kevin Peng62a87112020-07-07 15:07:46 +0800238
Raef Coles5ee45ed2020-09-24 11:25:44 +0100239target_link_libraries(tfm_ns
240 PRIVATE
241 platform_ns
242 CMSIS_5_tfm_ns
shejia01e0dd80a2021-07-12 17:47:50 +0800243 $<$<OR:$<BOOL:${TEST_FRAMEWORK_NS}>,$<BOOL:${TEST_FRAMEWORK_S}>>:tfm_ns_integration_test>
Kevin Peng0d3a3812020-12-23 02:17:57 +0000244 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
245 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
246 $<$<BOOL:${TEST_PSA_API}>:test_combine>
David Hu73f259b2020-12-07 10:58:41 +0800247 tfm_api_ns
Kevin Pengaf602292020-10-20 17:49:52 +0800248 tfm_ns_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100249)
Kevin Peng62a87112020-07-07 15:07:46 +0800250
Kevin Peng0d3a3812020-12-23 02:17:57 +0000251target_compile_definitions(tfm_ns
252 PUBLIC
253 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
254)
255
Raef Coles5ee45ed2020-09-24 11:25:44 +0100256set_target_properties(tfm_ns PROPERTIES
257 SUFFIX ".axf"
258 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
259)
Kevin Peng62a87112020-07-07 15:07:46 +0800260
Raef Coles5ee45ed2020-09-24 11:25:44 +0100261target_link_options(tfm_ns
262 PRIVATE
263 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
264 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200265 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100266)
Kevin Peng62a87112020-07-07 15:07:46 +0800267
Raef Coles5ee45ed2020-09-24 11:25:44 +0100268add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800269
Raef Coles5ee45ed2020-09-24 11:25:44 +0100270############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800271
Raef Coles5ee45ed2020-09-24 11:25:44 +0100272include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800273
Raef Coles5ee45ed2020-09-24 11:25:44 +0100274set(FETCHCONTENT_QUIET FALSE)
275cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800276
Raef Coles5ee45ed2020-09-24 11:25:44 +0100277add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800278
Raef Coles5ee45ed2020-09-24 11:25:44 +0100279target_sources(CMSIS_5_tfm_ns
280 INTERFACE
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800281 ${NSID_MGR_DIR}/tz_shim_layer.c
Raef Coles5ee45ed2020-09-24 11:25:44 +0100282 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
283 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
284 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800285 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}/tfm_nsid_map_table.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100286)
Kevin Peng62a87112020-07-07 15:07:46 +0800287
Raef Coles5ee45ed2020-09-24 11:25:44 +0100288target_include_directories(CMSIS_5_tfm_ns
289 INTERFACE
290 ${CMSIS_5_PATH}/Core/Include
291 ${CMSIS_5_PATH}/RTOS2/Include
292 ${CMSIS_5_PATH}/RTOS2/RTX/Include
293 ${CMSIS_5_PATH}/RTOS2/RTX/Config
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800294 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:${CMAKE_CURRENT_SOURCE_DIR}>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100295)
Kevin Peng62a87112020-07-07 15:07:46 +0800296
Raef Coles5ee45ed2020-09-24 11:25:44 +0100297target_link_libraries(CMSIS_5_tfm_ns
298 INTERFACE
299 platform_ns
300)
Xinyu Zhangeebbea32021-09-01 15:26:39 +0800301
302target_compile_definitions(CMSIS_5_tfm_ns
303 INTERFACE
304 $<$<BOOL:${TFM_NS_MANAGE_NSID}>:TFM_NS_MANAGE_NSID>
305)