blob: a98f856ca61c3b4511c5c1a33f18170bab53554d [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
30#################### TF-M NS interface (header only) ###########################
31
32add_library(tfm_ns_interface INTERFACE)
33
34target_include_directories(tfm_ns_interface
35 INTERFACE
36 ${INTERFACE_INC_DIR}
37 ${CMAKE_BINARY_DIR}/generated/interface/include
38 ${INTERFACE_INC_DIR}/os_wrapper
David Hu8e683252020-12-17 18:02:32 +080039 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${INTERFACE_INC_DIR}/multi_core>
David Hu73f259b2020-12-07 10:58:41 +080040)
41
42# PSA interface files are generated from a template
43add_dependencies(tfm_ns_interface
44 tfm_generated_files
45)
46
47# Include selection of Secure Partitions from TF-M build.
48# It can be replaced by NS side configurations later.
49target_link_libraries(tfm_ns_interface
50 INTERFACE
51 tfm_partition_defs
52)
53
54target_compile_definitions(tfm_ns_interface
55 INTERFACE
56 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
57 $<$<STREQUAL:${TEST_PSA_API},IPC>:PSA_API_TEST_IPC>
58 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:TFM_NS_CLIENT_IDENTIFICATION>
59 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hu402a2982020-12-17 22:31:04 +080060 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:TFM_MULTI_CORE_NS_OS>
David Hu73f259b2020-12-07 10:58:41 +080061 $<$<BOOL:${FORWARD_PROT_MSG}>:FORWARD_PROT_MSG>
62)
63
64###################### TF-M NS interface api (NS lib) ##########################
65
66add_library(tfm_api_ns STATIC)
67
68target_sources(tfm_api_ns
69 PRIVATE
70 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:${INTERFACE_SRC_DIR}/tfm_nspm_svc_handler.c>
71 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:${INTERFACE_SRC_DIR}/tfm_nspm_api.c>
72)
73
74if (${TFM_PSA_API})
75 target_sources(tfm_api_ns PRIVATE
76 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PLATFORM}>>:${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c>
77 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c>
78 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>>:${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c>
79 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_CRYPTO}>>:${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c>
80 $<$<OR:$<BOOL:{$FORWARD_PROT_MSG}>,$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_ipc_api.c>
81 )
82
83 if (TFM_MULTI_CORE_TOPOLOGY)
84 target_sources(tfm_api_ns PRIVATE
David Hu8e683252020-12-17 18:02:32 +080085 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c
86 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
87 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hu402a2982020-12-17 22:31:04 +080088 $<$<BOOL:${TFM_MULTI_CORE_NS_OS}>:${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c>
David Hu73f259b2020-12-07 10:58:41 +080089 )
90 else()
91 target_sources(tfm_api_ns PRIVATE
92 ${INTERFACE_SRC_DIR}/tfm_ns_interface.c
93 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
94 )
95 endif()
96else()
97 target_sources(tfm_api_ns PRIVATE
98 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${INTERFACE_SRC_DIR}/tfm_platform_func_api.c>
99 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${INTERFACE_SRC_DIR}/tfm_audit_func_api.c>
100 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_ps_func_api.c>
101 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${INTERFACE_SRC_DIR}/tfm_its_func_api.c>
102 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c>
103 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c>
104 ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
105 ${INTERFACE_SRC_DIR}/tfm_ns_interface.c
106 )
107endif()
108
109target_link_libraries(tfm_api_ns
110 PUBLIC
111 tfm_ns_interface
112 PRIVATE
113 platform_ns
114 # CMSIS is currently only required to provide the NS client IDs. In
115 # future, this should probably be made more OS agnostic
116 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:CMSIS_5_tfm_ns>
117)
118
Raef Coles5ee45ed2020-09-24 11:25:44 +0100119############################# PSA test integration #############################
120
Raef Colesc922f252020-10-05 10:49:30 +0100121if(TEST_PSA_API AND NOT PSA_ARCH_TESTS_BINARY_PATH)
122 if(NOT SUITE)
123 set(SUITE ${TEST_PSA_API})
124 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100125
Øyvind Rønningstad205a34a2020-10-02 10:31:23 +0200126 if (NOT DEFINED PSA_API_TEST_TARGET)
127 string(REGEX REPLACE ".*/" "" PSA_API_TEST_TARGET ${TFM_PLATFORM})
128 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100129
Raef Colesc922f252020-10-05 10:49:30 +0100130 if(NOT TARGET)
131 if (NOT "${TEST_PSA_API}" STREQUAL "IPC")
132 set(TARGET tgt_dev_apis_tfm_${PSA_API_TEST_TARGET})
133 else()
134 set(TARGET tgt_ff_tfm_${PSA_API_TEST_TARGET})
135 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100136 endif()
137
Raef Coles5ee45ed2020-09-24 11:25:44 +0100138
Raef Colesc922f252020-10-05 10:49:30 +0100139 if(NOT PSA_INCLUDE_PATHS)
David Hua1fee3d2020-12-30 11:06:37 +0800140 set(PSA_INCLUDE_PATHS ${INTERFACE_INC_DIR}/
Raef Coles23d6a192020-10-22 15:43:38 +0100141 ${CMAKE_BINARY_DIR}/generated/api-tests/platform/manifests/
Raef Colesc922f252020-10-05 10:49:30 +0100142 ${CMAKE_BINARY_DIR}/generated/interface/include
143 )
Raef Coles5ee45ed2020-09-24 11:25:44 +0100144 endif()
145
Raef Colesc922f252020-10-05 10:49:30 +0100146 if(NOT SP_HEAP_MEM_SUPP)
Raef Coles06e6f652020-10-20 16:10:38 +0100147 set(SP_HEAP_MEM_SUPP 0)
Raef Colesc922f252020-10-05 10:49:30 +0100148 endif()
149 if(NOT PLATFORM_PSA_ISOLATION_LEVEL)
150 set(PLATFORM_PSA_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
151 endif()
152
153 if (NOT TOOLCHAIN)
154 if (${CMAKE_C_COMPILER_ID} STREQUAL GNU)
155 set(TOOLCHAIN GNUARM)
156 elseif (${CMAKE_C_COMPILER_ID} STREQUAL ARMClang)
157 set(TOOLCHAIN ARMCLANG)
158 endif()
159 endif()
160
161 if (NOT CPU_ARCH)
162 if (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.main)
163 set(CPU_ARCH armv8m_ml)
164 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv8-m.base)
165 set(CPU_ARCH armv8m_bl)
166 elseif (${CMAKE_SYSTEM_ARCHITECTURE} STREQUAL armv7-m)
167 set(CPU_ARCH armv7m)
168 endif()
Raef Coles5ee45ed2020-09-24 11:25:44 +0100169 endif()
170
171 add_subdirectory(${PSA_ARCH_TESTS_PATH}/api-tests ${CMAKE_CURRENT_BINARY_DIR}/psa_api_tests)
Kevin Peng62a87112020-07-07 15:07:46 +0800172endif()
173
Raef Coles5ee45ed2020-09-24 11:25:44 +0100174############################# Test integration #################################
Kevin Peng62a87112020-07-07 15:07:46 +0800175
Raef Coles5ee45ed2020-09-24 11:25:44 +0100176add_library(tfm_ns_integration_test STATIC EXCLUDE_FROM_ALL)
Kevin Peng62a87112020-07-07 15:07:46 +0800177
Raef Coles5ee45ed2020-09-24 11:25:44 +0100178target_sources(tfm_ns_integration_test
179 PRIVATE
180 tfm_integ_test.c
181)
Kevin Peng62a87112020-07-07 15:07:46 +0800182
Raef Coles5ee45ed2020-09-24 11:25:44 +0100183target_include_directories(tfm_ns_integration_test
184 PUBLIC
185 .
186)
Kevin Peng62a87112020-07-07 15:07:46 +0800187
Raef Coles5ee45ed2020-09-24 11:25:44 +0100188target_link_libraries(tfm_ns_integration_test
189 PUBLIC
190 $<$<BOOL:${TEST_NS}>:tfm_ns_tests>
David Hu73f259b2020-12-07 10:58:41 +0800191 tfm_test_framework_ns
Raef Coles5ee45ed2020-09-24 11:25:44 +0100192 PRIVATE
David Hu73f259b2020-12-07 10:58:41 +0800193 tfm_ns_interface
194 tfm_api_ns
Raef Coles5ee45ed2020-09-24 11:25:44 +0100195 CMSIS_5_tfm_ns
196)
Kevin Peng62a87112020-07-07 15:07:46 +0800197
Raef Coles5ee45ed2020-09-24 11:25:44 +0100198target_compile_definitions(tfm_ns_integration_test
199 PUBLIC
200 $<$<BOOL:${TEST_NS}>:TEST_FRAMEWORK_NS>
201 $<$<BOOL:${TEST_S}>:TEST_FRAMEWORK_S>
202)
Kevin Peng62a87112020-07-07 15:07:46 +0800203
Raef Coles5ee45ed2020-09-24 11:25:44 +0100204############################# TFM NS app #######################################
Kevin Peng62a87112020-07-07 15:07:46 +0800205
Raef Coles5ee45ed2020-09-24 11:25:44 +0100206add_executable(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800207
Raef Coles5ee45ed2020-09-24 11:25:44 +0100208target_sources(tfm_ns
209 PRIVATE
210 main_ns.c
Kevin Peng0d3a3812020-12-23 02:17:57 +0000211 $<$<BOOL:${TEST_PSA_API}>:psa_api_test.c>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100212)
Kevin Peng62a87112020-07-07 15:07:46 +0800213
Raef Coles5ee45ed2020-09-24 11:25:44 +0100214target_link_libraries(tfm_ns
215 PRIVATE
216 platform_ns
217 CMSIS_5_tfm_ns
218 $<$<OR:$<BOOL:${TEST_NS}>,$<BOOL:${TEST_S}>>:tfm_ns_integration_test>
Kevin Peng0d3a3812020-12-23 02:17:57 +0000219 $<$<BOOL:${TEST_PSA_API}>:val_nspe>
220 $<$<BOOL:${TEST_PSA_API}>:pal_nspe>
221 $<$<BOOL:${TEST_PSA_API}>:test_combine>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100222 $<$<NOT:$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>>:tfm_s_veneers>
David Hu73f259b2020-12-07 10:58:41 +0800223 tfm_api_ns
Kevin Pengaf602292020-10-20 17:49:52 +0800224 tfm_ns_log
Raef Coles5ee45ed2020-09-24 11:25:44 +0100225)
Kevin Peng62a87112020-07-07 15:07:46 +0800226
Kevin Peng0d3a3812020-12-23 02:17:57 +0000227target_compile_definitions(tfm_ns
228 PUBLIC
229 $<$<BOOL:${TEST_PSA_API}>:PSA_API_TEST_NS>
230)
231
Raef Coles5ee45ed2020-09-24 11:25:44 +0100232set_target_properties(tfm_ns PROPERTIES
233 SUFFIX ".axf"
234 RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin"
235)
Kevin Peng62a87112020-07-07 15:07:46 +0800236
Raef Coles5ee45ed2020-09-24 11:25:44 +0100237target_link_options(tfm_ns
238 PRIVATE
239 $<$<C_COMPILER_ID:GNU>:-Wl,-Map=${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
240 $<$<C_COMPILER_ID:ARMClang>:--map>
TTornblomd35ffa02020-09-29 13:31:31 +0200241 $<$<C_COMPILER_ID:IAR>:--map\;${CMAKE_BINARY_DIR}/bin/tfm_ns.map>
Raef Coles5ee45ed2020-09-24 11:25:44 +0100242)
Kevin Peng62a87112020-07-07 15:07:46 +0800243
Raef Coles5ee45ed2020-09-24 11:25:44 +0100244add_convert_to_bin_target(tfm_ns)
Kevin Peng62a87112020-07-07 15:07:46 +0800245
Raef Coles5ee45ed2020-09-24 11:25:44 +0100246############################# CMSIS ############################################
Kevin Peng62a87112020-07-07 15:07:46 +0800247
Raef Coles5ee45ed2020-09-24 11:25:44 +0100248include(FetchContent)
Kevin Peng62a87112020-07-07 15:07:46 +0800249
Raef Coles5ee45ed2020-09-24 11:25:44 +0100250set(FETCHCONTENT_QUIET FALSE)
251cmake_policy(SET CMP0079 NEW)
Kevin Peng62a87112020-07-07 15:07:46 +0800252
Raef Coles5ee45ed2020-09-24 11:25:44 +0100253add_library(CMSIS_5_tfm_ns INTERFACE)
Kevin Peng62a87112020-07-07 15:07:46 +0800254
Raef Coles5ee45ed2020-09-24 11:25:44 +0100255target_sources(CMSIS_5_tfm_ns
256 INTERFACE
257 ${CMSIS_5_PATH}/RTOS2/RTX/Config/RTX_Config.c
258 ${CMSIS_5_PATH}/RTOS2/RTX/Source/rtx_lib.c
259 ${CMAKE_CURRENT_SOURCE_DIR}/os_wrapper_cmsis_rtos_v2.c
260)
Kevin Peng62a87112020-07-07 15:07:46 +0800261
Raef Coles5ee45ed2020-09-24 11:25:44 +0100262target_include_directories(CMSIS_5_tfm_ns
263 INTERFACE
264 ${CMSIS_5_PATH}/Core/Include
265 ${CMSIS_5_PATH}/RTOS2/Include
266 ${CMSIS_5_PATH}/RTOS2/RTX/Include
267 ${CMSIS_5_PATH}/RTOS2/RTX/Config
268)
Kevin Peng62a87112020-07-07 15:07:46 +0800269
Raef Coles5ee45ed2020-09-24 11:25:44 +0100270target_link_libraries(CMSIS_5_tfm_ns
271 INTERFACE
272 platform_ns
273)