blob: 2fce668fa7328a318013b4a9cf2ac64ca0728bfe [file] [log] [blame]
Raef Coles7d3545b2020-07-10 10:00:35 +01001#-------------------------------------------------------------------------------
2# Copyright (c) 2020, Arm Limited. All rights reserved.
3#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Raef Coles69817322020-10-19 14:14:14 +01008cmake_minimum_required(VERSION 3.15)
Raef Coles7d3545b2020-07-10 10:00:35 +01009cmake_policy(SET CMP0076 NEW)
10cmake_policy(SET CMP0079 NEW)
11
12
13if (TFM_MULTI_CORE_TOPOLOGY)
14 include(${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/preload_ns.cmake)
Raef Colese3bf94d2020-11-03 11:49:56 +000015 tfm_toolchain_reload_compiler()
Raef Coles7d3545b2020-07-10 10:00:35 +010016 # The platform target is created in this directory/file so that it has the
17 # same settings as the main ns target.
18 add_library(platform_ns STATIC)
19endif()
20
21###################### PSA interface (header only) #############################
22
23add_library(psa_interface INTERFACE)
24
25target_include_directories(psa_interface
26 INTERFACE
27 ${CMAKE_CURRENT_SOURCE_DIR}/include
28 ${CMAKE_BINARY_DIR}/generated/interface/include
29 ${CMAKE_CURRENT_SOURCE_DIR}/include/os_wrapper
30)
31
32# PSA interface files are generated from a template
33add_dependencies(psa_interface
34 tfm_generated_files
35)
36
37target_link_libraries(psa_interface
38 INTERFACE
39 tfm_partition_defs
40)
41
42target_compile_definitions(psa_interface
43 INTERFACE
44 $<$<BOOL:${TFM_PSA_API}>:TFM_PSA_API>
45 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:TFM_NS_CLIENT_IDENTIFICATION>
46 $<$<BOOL:${CONFIG_TFM_ENABLE_CTX_MGMT}>:CONFIG_TFM_ENABLE_CTX_MGMT>
47 $<$<BOOL:${TFM_ISOLATION_LEVEL}>:TFM_LVL=${TFM_ISOLATION_LEVEL}>
48 $<$<VERSION_GREATER:${TFM_ISOLATION_LEVEL},1>:CONFIG_TFM_ENABLE_MEMORY_PROTECT>
49 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
David Hu60863942020-10-14 14:49:19 +080050 $<$<BOOL:${TFM_MULTI_CORE_MULTI_CLIENT_CALL}>:TFM_MULTI_CORE_MULTI_CLIENT_CALL>
Raef Coles7d3545b2020-07-10 10:00:35 +010051)
52
53###################### PSA api (S lib) #########################################
54
55target_sources(tfm_secure_api
56 INTERFACE
57 $<$<BOOL:${TFM_PSA_API}>:${CMAKE_CURRENT_SOURCE_DIR}/src/psa/psa_client.c>
58 $<$<BOOL:${TFM_PSA_API}>:${CMAKE_CURRENT_SOURCE_DIR}/src/psa/psa_service.c>
59 $<$<BOOL:${TFM_PSA_API}>:${CMAKE_CURRENT_SOURCE_DIR}/src/psa/psa_lifecycle.c>
60 ${CMAKE_CURRENT_SOURCE_DIR}/src/log/tfm_log_raw.c
61)
62
63###################### PSA api (NS lib) ########################################
64
65add_library(psa_api_ns STATIC)
66
67target_sources(psa_api_ns
68 PRIVATE
69 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:src/tfm_nspm_svc_handler.c>
70 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:src/tfm_nspm_api.c>
Raef Coles7d3545b2020-07-10 10:00:35 +010071)
72
73if (${TFM_PSA_API})
74 target_sources(psa_api_ns PRIVATE
75 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_platform_ipc_api.c>
76 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_ps_ipc_api.c>
77 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_its_ipc_api.c>
78 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_crypto_ipc_api.c>
79 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_initial_attestation_ipc_api.c>
80 )
81
82 if (TFM_MULTI_CORE_TOPOLOGY)
83 target_sources(psa_api_ns PRIVATE
84 src/tfm_ns_mailbox.c
85 src/tfm_multi_core_api.c
86 src/tfm_multi_core_psa_ns_api.c
87 )
88 else()
89 target_sources(psa_api_ns PRIVATE
90 src/tfm_ns_interface.c
91 src/tfm_psa_ns_api.c
92 )
93 endif()
94else()
95 target_sources(psa_api_ns PRIVATE
96 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_platform_func_api.c>
97 $<$<BOOL:${TFM_PARTITION_AUDIT_LOG}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_audit_func_api.c>
98 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_ps_func_api.c>
99 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_its_func_api.c>
100 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_crypto_func_api.c>
101 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_initial_attestation_func_api.c>
102 src/tfm_psa_ns_api.c
103 )
104 if (NOT TFM_MULTI_CORE_TOPOLOGY)
105 target_sources(psa_api_ns PRIVATE
106 src/tfm_ns_interface.c
107 )
108 endif()
109
110endif()
111
112target_link_libraries(psa_api_ns
113 PUBLIC
114 psa_interface
115 PRIVATE
116 platform_ns
117 # CMSIS is currently only required to provide the NS client IDs. In
118 # future, this should probably be made more OS agnostic
119 $<$<BOOL:${TFM_NS_CLIENT_IDENTIFICATION}>:CMSIS_5_tfm_ns>
120)