blob: c1ad860cd45a60bf8590b5cf7be906df42e3251d [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()
Kevin Peng62a87112020-07-07 15:07:46 +080018endif()
19
David Hu73f259b2020-12-07 10:58:41 +080020# In actual NS integration, NS side build should include the source files
21# exported by TF-M build.
22# Directly include interface folder to simplify the NS build in this demo, since
23# install always occurs at the end of build.
24set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src)
25set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include)
26
27#################### TF-M NS interface (header only) ###########################
28
29add_library(tfm_ns_interface INTERFACE)
30
31target_include_directories(tfm_ns_interface
32 INTERFACE
33 ${INTERFACE_INC_DIR}
34 ${CMAKE_BINARY_DIR}/generated/interface/include
35 ${INTERFACE_INC_DIR}/os_wrapper
David Hu8e683252020-12-17 18:02:32 +080036 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${INTERFACE_INC_DIR}/multi_core>
David Hu73f259b2020-12-07 10:58:41 +080037)
38
39# PSA interface files are generated from a template
40add_dependencies(tfm_ns_interface
41 tfm_generated_files
42)
43
44# Include selection of Secure Partitions from TF-M build.
45# It can be replaced by NS side configurations later.
46target_link_libraries(tfm_ns_interface
47 INTERFACE
48 tfm_partition_defs
49)
50
51target_compile_definitions(tfm_ns_interface
52 INTERFACE
53 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
54 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
55 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:TFM_NS_CLIENT_IDENTIFICATION>
56 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
57 $<$<BOOL:${TFM_MULTI_CORE_MULTI_CLIENT_CALL}>:TFM_MULTI_CORE_MULTI_CLIENT_CALL>
58 $<$<BOOL:${FORWARD_PROT_MSG}>:FORWARD_PROT_MSG>
59)
60
61###################### TF-M NS interface api (NS lib) ##########################
62
63add_library(tfm_api_ns STATIC)
64
65target_sources(tfm_api_ns
66 PRIVATE
67 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:${INTERFACE_SRC_DIR}/tfm_nspm_svc_handler.c>
68 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:${INTERFACE_SRC_DIR}/tfm_nspm_api.c>
69)
70
71if (${TFM_PSA_API})
72 target_sources(tfm_api_ns PRIVATE
73 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PLATFORM}>>:${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c>
74 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c>
75 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c>
76 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_CRYPTO}>>:${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c>
77 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_ipc_api.c>
78 )
79
80 if (TFM_MULTI_CORE_TOPOLOGY)
81 target_sources(tfm_api_ns PRIVATE
David Hu8e683252020-12-17 18:02:32 +080082 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c
83 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
84 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
85 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c
David Hu73f259b2020-12-07 10:58:41 +080086 )
87 else()
88 target_sources(tfm_api_ns PRIVATE
89 ${INTERFACE_SRC_DIR}/tfm_ns_interface.c
90 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
91 )
92 endif()
93else()
94 target_sources(tfm_api_ns PRIVATE
95 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_func_api.c>
96 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${INTERFACE_SRC_DIR}/tfm_audit_func_api.c>
97 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_func_api.c>
98 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_func_api.c>
99 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c>
100 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c>
101 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
102 ${INTERFACE_SRC_DIR}/tfm_ns_interface.c
103 )
104endif()
105
106target_link_libraries(tfm_api_ns
107 PUBLIC
108 tfm_ns_interface
109 PRIVATE
110 platform_ns
111 # CMSIS is currently only required to provide the NS client IDs. In
112 # future, this should probably be made more OS agnostic
113 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:CMSIS_5_tfm_ns>
114)
115
Raef Coles5ee45ed2020-09-24 11:25:44 +0100116############################# PSA test integration #############################
117
Raef Colesc922f252020-10-05 10:49:30 +0100118if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
119 if(NOT SUITE)
120 set(SUITE ${TEST_PSA_API})
121 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100122
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200123 if (NOT DEFINED PSA_API_TEST_TARGET)
124 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
125 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100126
Raef Colesc922f252020-10-05 10:49:30 +0100127 if(NOT TARGET)
128 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
129 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
130 else()
131 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
132 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100133 endif()
134
Raef Coles5ee45ed2020-09-24 11:25:44 +0100135
Raef Colesc922f252020-10-05 10:49:30 +0100136 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800137 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100138 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100139 ${CMAKE_BINARY_DIR}/generated/interface/include
140 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100141 endif()
142
Raef Colesc922f252020-10-05 10:49:30 +0100143 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100144 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100145 endif()
146 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
147 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
148 endif()
149
150 if (NOT TOOLCHAIN)
151 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
152 set(TOOLCHAIN GNUARM)
153 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
154 set(TOOLCHAIN ARMCLANG)
155 endif()
156 endif()
157
158 if (NOT CPU_ARCH)
159 if (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
160 set(CPU_ARCH armv8m_ml)
161 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
162 set(CPU_ARCH armv8m_bl)
163 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
164 set(CPU_ARCH armv7m)
165 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100166 endif()
167
168 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Kevin Peng62a87112020-07-07 15:07:46 +0800169endif()
170
Raef Coles5ee45ed2020-09-24 11:25:44 +0100171############################# Test integration #################################
Kevin Peng62a87112020-07-07 15:07:46 +0800172
Raef Coles5ee45ed2020-09-24 11:25:44 +0100173add_library(tfm_ns_integration_test STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800174
Raef Coles5ee45ed2020-09-24 11:25:44 +0100175target_sources(tfm_ns_integration_test
176 PRIVATE
177 tfm_integ_test.c
178)
Kevin Peng62a87112020-07-07 15:07:46 +0800179
Raef Coles5ee45ed2020-09-24 11:25:44 +0100180target_include_directories(tfm_ns_integration_test
181 PUBLIC
182 .
183)
Kevin Peng62a87112020-07-07 15:07:46 +0800184
Raef Coles5ee45ed2020-09-24 11:25:44 +0100185target_link_libraries(tfm_ns_integration_test
186 PUBLIC
187 $<$<BOOL:${TEST_NS}>:tfm_ns_tests>
David Hu73f259b2020-12-07 10:58:41 +0800188 tfm_test_framework_ns
Raef Coles5ee45ed2020-09-24 11:25:44 +0100189 PRIVATE
David Hu73f259b2020-12-07 10:58:41 +0800190 tfm_ns_interface
191 tfm_api_ns
Raef Coles5ee45ed2020-09-24 11:25:44 +0100192 CMSIS_5_tfm_ns
193)
Kevin Peng62a87112020-07-07 15:07:46 +0800194
Raef Coles5ee45ed2020-09-24 11:25:44 +0100195target_compile_definitions(tfm_ns_integration_test
196 PUBLIC
197 $<$<BOOL:${TEST_NS}>:TEST_FRAMEWORK_NS>
198 $<$<BOOL:${TEST_S}>:TEST_FRAMEWORK_S>
199)
Kevin Peng62a87112020-07-07 15:07:46 +0800200
Raef Coles5ee45ed2020-09-24 11:25:44 +0100201############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800202
Raef Coles5ee45ed2020-09-24 11:25:44 +0100203add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800204
Raef Coles5ee45ed2020-09-24 11:25:44 +0100205target_sources(tfm_ns
206 PRIVATE
207 main_ns.c
Kevin Peng0d3a3812020-12-23 02:17:57 +0000208 $<$<BOOL:${TEST_PSA_API}>:psa_api_test.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100209)
Kevin Peng62a87112020-07-07 15:07:46 +0800210
Raef Coles5ee45ed2020-09-24 11:25:44 +0100211target_link_libraries(tfm_ns
212 PRIVATE
213 platform_ns
214 CMSIS_5_tfm_ns
215 $<$<OR:$<BOOL:${TEST_NS}>,$<BOOL:${TEST_S}>>:tfm_ns_integration_test>
Kevin Peng0d3a3812020-12-23 02:17:57 +0000216 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
217 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
218 $<$<BOOL:${TEST_PSA_API}>:test_combine>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100219 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800220 tfm_api_ns
Kevin Pengaf602292020-10-20 17:49:52 +0800221 tfm_ns_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100222)
Kevin Peng62a87112020-07-07 15:07:46 +0800223
Kevin Peng0d3a3812020-12-23 02:17:57 +0000224target_compile_definitions(tfm_ns
225 PUBLIC
226 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
227)
228
Raef Coles5ee45ed2020-09-24 11:25:44 +0100229set_target_properties(tfm_ns PROPERTIES
230 SUFFIX ".axf"
231 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
232)
Kevin Peng62a87112020-07-07 15:07:46 +0800233
Raef Coles5ee45ed2020-09-24 11:25:44 +0100234target_link_options(tfm_ns
235 PRIVATE
236 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
237 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200238 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100239)
Kevin Peng62a87112020-07-07 15:07:46 +0800240
Raef Coles5ee45ed2020-09-24 11:25:44 +0100241add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800242
Raef Coles5ee45ed2020-09-24 11:25:44 +0100243############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800244
Raef Coles5ee45ed2020-09-24 11:25:44 +0100245include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800246
Raef Coles5ee45ed2020-09-24 11:25:44 +0100247set(FETCHCONTENT_QUIET FALSE)
248cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800249
Raef Coles5ee45ed2020-09-24 11:25:44 +0100250add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800251
Raef Coles5ee45ed2020-09-24 11:25:44 +0100252target_sources(CMSIS_5_tfm_ns
253 INTERFACE
254 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
255 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
256 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
257)
Kevin Peng62a87112020-07-07 15:07:46 +0800258
Raef Coles5ee45ed2020-09-24 11:25:44 +0100259target_include_directories(CMSIS_5_tfm_ns
260 INTERFACE
261 ${CMSIS_5_PATH}/Core/Include
262 ${CMSIS_5_PATH}/RTOS2/Include
263 ${CMSIS_5_PATH}/RTOS2/RTX/Include
264 ${CMSIS_5_PATH}/RTOS2/RTX/Config
265)
Kevin Peng62a87112020-07-07 15:07:46 +0800266
Raef Coles5ee45ed2020-09-24 11:25:44 +0100267target_link_libraries(CMSIS_5_tfm_ns
268 INTERFACE
269 platform_ns
270)