blob: e16ba6c6e039fd98e8af17bc7e82a1896db434b9 [file] [log] [blame]
Raef Coles7d3545b2020-07-10 10:00:35 +01001#-------------------------------------------------------------------------------
Nicola Mazzucato6414e292025-05-09 22:05:05 +01002# SPDX-FileCopyrightText: Copyright The TrustedFirmware-M Contributors
Chris Brandd0790332022-05-20 13:36:30 -07003# Copyright (c) 2022 Cypress Semiconductor Corporation (an Infineon company)
4# or an affiliate of Cypress Semiconductor Corporation. All rights reserved.
Raef Coles7d3545b2020-07-10 10:00:35 +01005#
6# SPDX-License-Identifier: BSD-3-Clause
7#
8#-------------------------------------------------------------------------------
9
David Hu1249f0d2023-12-04 22:57:56 +080010cmake_minimum_required(VERSION 3.21)
Raef Coles7d3545b2020-07-10 10:00:35 +010011
Kevin Peng386374c2021-11-04 14:36:17 +080012# Generate framework feature
Kevin Peng710acf52021-11-16 11:42:41 +080013set(PSA_FRAMEWORK_ISOLATION_LEVEL ${TFM_ISOLATION_LEVEL})
Kevin Peng386374c2021-11-04 14:36:17 +080014configure_file(${CMAKE_CURRENT_SOURCE_DIR}/include/psa/framework_feature.h.in
Kevin Peng710acf52021-11-16 11:42:41 +080015 ${CMAKE_BINARY_DIR}/generated/interface/include/psa/framework_feature.h
16 @ONLY)
Raef Coles7d3545b2020-07-10 10:00:35 +010017
Raef Coles7d3545b2020-07-10 10:00:35 +010018###################### PSA interface (header only) #############################
19
20add_library(psa_interface INTERFACE)
21
22target_include_directories(psa_interface
23 INTERFACE
Anton Komlevaee4b612023-05-14 17:38:36 +010024 $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
25 $<BUILD_INTERFACE:${CMAKE_BINARY_DIR}/generated/interface/include>
26 $<BUILD_INTERFACE:$<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:${CMAKE_CURRENT_SOURCE_DIR}/include/multi_core>>
Raef Coles7d3545b2020-07-10 10:00:35 +010027)
28
Raef Coles7d3545b2020-07-10 10:00:35 +010029target_link_libraries(psa_interface
30 INTERFACE
Xinyu Zhangcdbe3622022-10-31 14:34:25 +080031 tfm_config
Raef Coles7d3545b2020-07-10 10:00:35 +010032)
33
34target_compile_definitions(psa_interface
35 INTERFACE
Raef Coles7d3545b2020-07-10 10:00:35 +010036 $<$<BOOL:${CONFIG_TFM_ENABLE_CTX_MGMT}>:CONFIG_TFM_ENABLE_CTX_MGMT>
Xinyu Zhangae99e2d2023-07-28 14:03:29 +080037 $<$<BOOL:${TFM_ISOLATION_LEVEL}>:TFM_ISOLATION_LEVEL=${TFM_ISOLATION_LEVEL}>
Chris Brandca819022022-07-19 09:25:15 -070038 $<$<BOOL:${CONFIG_TFM_USE_TRUSTZONE}>:CONFIG_TFM_USE_TRUSTZONE>
Raef Coles7d3545b2020-07-10 10:00:35 +010039 $<$<BOOL:${TFM_MULTI_CORE_TOPOLOGY}>:TFM_MULTI_CORE_TOPOLOGY>
Summer Qin2a299592022-02-07 17:37:10 +080040 $<$<BOOL:${CONFIG_TFM_PARTITION_META}>:CONFIG_TFM_PARTITION_META>
David Hub27a6632023-10-23 22:38:39 +080041 $<$<BOOL:${TEST_NS_MULTI_CORE}>:TFM_MULTI_CORE_TEST>
Nicola Mazzucato6414e292025-05-09 22:05:05 +010042 $<$<BOOL:${TFM_HYBRID_PLATFORM_API_BROKER}>:TFM_HYBRID_PLATFORM_API_BROKER>
Raef Coles7d3545b2020-07-10 10:00:35 +010043)
44
Anton Komlev26023ea2024-11-20 14:50:10 +000045add_dependencies(psa_interface manifest_tool)
46
Raef Coles7d3545b2020-07-10 10:00:35 +010047###################### PSA api (S lib) #########################################
48
Kevin Peng8b8f7a42022-08-05 17:56:30 +080049target_sources(tfm_sprt
50 PRIVATE
Summer Qind23bbb32022-10-18 15:30:06 +080051 $<$<BOOL:${TFM_PARTITION_INITIAL_ATTESTATION}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_attest_api.c>
52 $<$<BOOL:${TFM_PARTITION_CRYPTO}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_crypto_api.c>
53 $<$<BOOL:${TFM_PARTITION_FIRMWARE_UPDATE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_fwu_api.c>
54 $<$<BOOL:${TFM_PARTITION_INTERNAL_TRUSTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_its_api.c>
55 $<$<BOOL:${TFM_PARTITION_PLATFORM}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_platform_api.c>
56 $<$<BOOL:${TFM_PARTITION_PROTECTED_STORAGE}>:${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_ps_api.c>
Xinyu Zhang526bf5f2023-04-18 13:58:15 +080057 ${CMAKE_CURRENT_SOURCE_DIR}/src/tfm_psa_call.c
Kevin Peng8b8f7a42022-08-05 17:56:30 +080058)
59
David Hu8b526d42020-11-27 20:59:52 +080060###################### Export configurations to NS #############################
61
Mark Horvathfbc2c502022-09-09 16:16:07 +020062if (TFM_MULTI_CORE_TOPOLOGY)
David Hu8b526d42020-11-27 20:59:52 +080063 configure_file(${CMAKE_CURRENT_SOURCE_DIR}/include/multi_core/tfm_mailbox_config.h.in
David Hu186a1292021-09-13 09:05:52 +080064 ${CMAKE_BINARY_DIR}/generated/interface/include/tfm_mailbox_config.h
David Hu8b526d42020-11-27 20:59:52 +080065 NEWLINE_STYLE UNIX
66 )
67endif()