blob: e445b06242cfe63ebdb69c786a958e1f7a9e9540 [file] [log] [blame]
Raef Colesa1f504c2020-07-10 09:58:55 +01001#-------------------------------------------------------------------------------
Anton Komlev8ab4f042025-06-03 21:13:07 +01002# SPDX-FileCopyrightText: Copyright The TrustedFirmware-M Contributors
Raef Colesa1f504c2020-07-10 09:58:55 +01003#
4# SPDX-License-Identifier: BSD-3-Clause
5#
6#-------------------------------------------------------------------------------
7
Raef Colesa1f504c2020-07-10 09:58:55 +01008install(DIRECTORY ${CMAKE_BINARY_DIR}/bin/
Anton Komlev3dd98632023-09-20 16:26:30 +01009 DESTINATION bin
Raef Coles035c83b2020-09-29 10:32:52 +010010)
11
David Hub24aead2020-10-17 19:46:19 +080012# export veneer lib
Chris Brandca819022022-07-19 09:25:15 -070013if (CONFIG_TFM_USE_TRUSTZONE)
Raef Coles25fc1752020-11-24 12:04:42 +000014 install(FILES ${CMAKE_BINARY_DIR}/secure_fw/s_veneers.o
Raef Coles4fed4632020-12-08 12:56:47 +000015 DESTINATION ${INSTALL_INTERFACE_LIB_DIR})
David Hub24aead2020-10-17 19:46:19 +080016endif()
17
Raef Coles035c83b2020-09-29 10:32:52 +010018####################### export headers #########################################
19
Antonio de Angelis2fffac92025-01-20 14:03:35 +000020if (BL1 AND PLATFORM_DEFAULT_BL1)
21 install(DIRECTORY ${BL1_1_CONFIG_DIR}/
22 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/bl1_1_config)
23
24 install(DIRECTORY ${BL1_2_CONFIG_DIR}/
25 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/bl1_2_config)
26endif()
27
Raef Coles035c83b2020-09-29 10:32:52 +010028install(FILES ${INTERFACE_INC_DIR}/psa/client.h
29 ${INTERFACE_INC_DIR}/psa/error.h
Raef Coles4fed4632020-12-08 12:56:47 +000030 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Raef Coles035c83b2020-09-29 10:32:52 +010031
Raef Coles035c83b2020-09-29 10:32:52 +010032install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa_manifest/sid.h
Raef Coles4fed4632020-12-08 12:56:47 +000033 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa_manifest)
Raef Coles035c83b2020-09-29 10:32:52 +010034
Kevin Peng27cf4de2023-10-26 16:04:46 +080035install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/config_impl.h
36 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
37
Kevin Peng0e340ea2023-08-15 17:51:44 +080038install(FILES ${INTERFACE_INC_DIR}/tfm_veneers.h
Raef Coles035c83b2020-09-29 10:32:52 +010039 ${INTERFACE_INC_DIR}/tfm_ns_interface.h
Raef Coles4fed4632020-12-08 12:56:47 +000040 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010041
Sherry Zhnag482b88b2021-08-19 17:51:47 +080042install(FILES ${INTERFACE_INC_DIR}/tfm_ns_client_ext.h
43 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010044
David Hu895cdc32023-01-16 19:19:25 +080045install(FILES ${CMAKE_SOURCE_DIR}/secure_fw/include/config_tfm.h
46 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
David Hu6d1a9b62023-02-22 16:54:04 +080047install(FILES ${CMAKE_SOURCE_DIR}/config/config_base.h
48 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Nicola Mazzucatob369b332025-01-02 09:11:57 +000049install(FILES ${CMAKE_SOURCE_DIR}/secure_fw/spm/include/tfm_hybrid_platform.h
50 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
David Hu895cdc32023-01-16 19:19:25 +080051
Summer Qin566e03b2022-10-08 17:27:42 +080052install(FILES ${INTERFACE_INC_DIR}/tfm_psa_call_pack.h
53 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
54install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa/framework_feature.h
55 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Xinyu Zhang93899d02021-05-11 10:48:52 +080056
Chris Brandfbf3f462022-06-23 15:27:20 -070057if (TFM_PARTITION_NS_AGENT_MAILBOX)
David Hu04969a42020-06-14 21:25:35 +080058 install(FILES ${INTERFACE_INC_DIR}/multi_core/tfm_multi_core_api.h
59 ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox.h
60 ${INTERFACE_INC_DIR}/multi_core/tfm_mailbox.h
David Hucb915812021-12-27 14:22:04 +080061 ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox_test.h
David Hu186a1292021-09-13 09:05:52 +080062 ${CMAKE_BINARY_DIR}/generated/interface/include/tfm_mailbox_config.h
David Hu71f6dcc2023-10-18 11:52:21 +080063 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/multi_core)
Chris Brandfbf3f462022-06-23 15:27:20 -070064endif()
65
Mark Horvathfbc2c502022-09-09 16:16:07 +020066if (TFM_PARTITION_PROTECTED_STORAGE)
Raef Coles035c83b2020-09-29 10:32:52 +010067 install(FILES ${INTERFACE_INC_DIR}/psa/protected_storage.h
Jamie Fox133ce092023-11-01 18:42:42 +000068 ${INTERFACE_INC_DIR}/psa/storage_common.h
Raef Coles4fed4632020-12-08 12:56:47 +000069 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +080070 install(FILES ${INTERFACE_INC_DIR}/tfm_ps_defs.h
71 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010072endif()
73
Mark Horvathfbc2c502022-09-09 16:16:07 +020074if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE)
Raef Coles035c83b2020-09-29 10:32:52 +010075 install(FILES ${INTERFACE_INC_DIR}/psa/internal_trusted_storage.h
76 ${INTERFACE_INC_DIR}/psa/storage_common.h
Raef Coles4fed4632020-12-08 12:56:47 +000077 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +080078 install(FILES ${INTERFACE_INC_DIR}/tfm_its_defs.h
79 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010080endif()
81
Mark Horvathfbc2c502022-09-09 16:16:07 +020082if (TFM_PARTITION_CRYPTO)
Antonio de Angelis8bb98512024-01-16 14:13:36 +000083 install(FILES ${INTERFACE_INC_DIR}/psa/README.rst
84 ${INTERFACE_INC_DIR}/psa/build_info.h
Raef Coles035c83b2020-09-29 10:32:52 +010085 ${INTERFACE_INC_DIR}/psa/crypto.h
Antonio de Angelis8bb98512024-01-16 14:13:36 +000086 ${INTERFACE_INC_DIR}/psa/crypto_adjust_auto_enabled.h
Antonio de Angelisa0b00f42024-09-18 12:07:25 +010087 ${INTERFACE_INC_DIR}/psa/crypto_adjust_config_dependencies.h
Antonio de Angelis8bb98512024-01-16 14:13:36 +000088 ${INTERFACE_INC_DIR}/psa/crypto_adjust_config_key_pair_types.h
89 ${INTERFACE_INC_DIR}/psa/crypto_adjust_config_synonyms.h
90 ${INTERFACE_INC_DIR}/psa/crypto_builtin_composites.h
91 ${INTERFACE_INC_DIR}/psa/crypto_builtin_key_derivation.h
92 ${INTERFACE_INC_DIR}/psa/crypto_builtin_primitives.h
93 ${INTERFACE_INC_DIR}/psa/crypto_compat.h
94 ${INTERFACE_INC_DIR}/psa/crypto_driver_common.h
95 ${INTERFACE_INC_DIR}/psa/crypto_driver_contexts_composites.h
96 ${INTERFACE_INC_DIR}/psa/crypto_driver_contexts_key_derivation.h
97 ${INTERFACE_INC_DIR}/psa/crypto_driver_contexts_primitives.h
98 ${INTERFACE_INC_DIR}/psa/crypto_extra.h
99 ${INTERFACE_INC_DIR}/psa/crypto_legacy.h
Xinyu Zhangfce20372023-04-10 14:43:47 +0800100 ${INTERFACE_INC_DIR}/psa/crypto_platform.h
Antonio de Angelis8bb98512024-01-16 14:13:36 +0000101 ${INTERFACE_INC_DIR}/psa/crypto_se_driver.h
Raef Coles035c83b2020-09-29 10:32:52 +0100102 ${INTERFACE_INC_DIR}/psa/crypto_sizes.h
103 ${INTERFACE_INC_DIR}/psa/crypto_struct.h
104 ${INTERFACE_INC_DIR}/psa/crypto_types.h
105 ${INTERFACE_INC_DIR}/psa/crypto_values.h
Raef Coles4fed4632020-12-08 12:56:47 +0000106 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Raef Coles035c83b2020-09-29 10:32:52 +0100107 install(FILES ${INTERFACE_INC_DIR}/tfm_crypto_defs.h
Raef Coles4fed4632020-12-08 12:56:47 +0000108 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Antonio de Angelis8bb98512024-01-16 14:13:36 +0000109 install(DIRECTORY ${INTERFACE_INC_DIR}/mbedtls
110 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100111endif()
112
Mark Horvathfbc2c502022-09-09 16:16:07 +0200113if (TFM_PARTITION_INITIAL_ATTESTATION)
David Hu9191b612023-06-08 12:02:39 +0800114 install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa/initial_attestation.h
Raef Coles4fed4632020-12-08 12:56:47 +0000115 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +0800116 install(FILES ${INTERFACE_INC_DIR}/tfm_attest_defs.h
David Hu32bd6152022-09-27 13:10:36 +0800117 ${INTERFACE_INC_DIR}/tfm_attest_iat_defs.h
David Hudc8cb9e2021-11-10 12:45:59 +0800118 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100119endif()
120
Mark Horvathfbc2c502022-09-09 16:16:07 +0200121if(TFM_PARTITION_PLATFORM)
Raef Coles035c83b2020-09-29 10:32:52 +0100122 install(FILES ${INTERFACE_INC_DIR}/tfm_platform_api.h
Raef Coles4fed4632020-12-08 12:56:47 +0000123 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100124endif()
125
Sherry Zhang07b42412021-01-07 14:19:41 +0800126if(TFM_PARTITION_FIRMWARE_UPDATE)
127 install(FILES ${INTERFACE_INC_DIR}/psa/update.h
Sherry Zhang73126e52022-02-15 14:27:49 +0800128 ${CMAKE_BINARY_DIR}/generated/interface/include/psa/fwu_config.h
Sherry Zhang07b42412021-01-07 14:19:41 +0800129 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
130 install(FILES ${INTERFACE_INC_DIR}/tfm_fwu_defs.h
131 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
132endif()
133
David Hu32bd6152022-09-27 13:10:36 +0800134if(PLATFORM_DEFAULT_CRYPTO_KEYS)
135 install(DIRECTORY ${INTERFACE_INC_DIR}/crypto_keys
136 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
137endif()
138
Raef Coles035c83b2020-09-29 10:32:52 +0100139####################### export sources #########################################
140
Chris Brandfbf3f462022-06-23 15:27:20 -0700141if (TFM_PARTITION_NS_AGENT_MAILBOX)
David Hu04969a42020-06-14 21:25:35 +0800142 install(FILES ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c
143 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
144 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hud5973452020-11-26 16:47:46 +0800145 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_thread.c
Nicola Mazzucatof21b3002025-06-04 11:01:05 +0100146 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_common.c
David Hu32bd6152022-09-27 13:10:36 +0800147 DESTINATION ${INSTALL_INTERFACE_SRC_DIR}/multi_core)
Chris Brandfbf3f462022-06-23 15:27:20 -0700148endif()
David Huf07f3f12021-04-06 18:03:33 +0800149
Chris Brandfbf3f462022-06-23 15:27:20 -0700150if (TFM_PARTITION_NS_AGENT_TZ)
Xinyu Zhang1c12d562023-10-24 12:02:22 +0800151 install(FILES ${INTERFACE_SRC_DIR}/tfm_tz_psa_ns_api.c
Chris Brandfbf3f462022-06-23 15:27:20 -0700152 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
153endif()
154
Chris Brand4ac274d2024-01-03 15:31:37 -0800155install(DIRECTORY ${INTERFACE_INC_DIR}/os_wrapper
156 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
BohdanHunkof871df02023-02-03 14:36:41 +0200157
Chris Brandfbf3f462022-06-23 15:27:20 -0700158if (CONFIG_TFM_USE_TRUSTZONE)
BohdanHunkof871df02023-02-03 14:36:41 +0200159 install(DIRECTORY ${INTERFACE_SRC_DIR}/os_wrapper
David Huf07f3f12021-04-06 18:03:33 +0800160 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100161endif()
162
Mark Horvathfbc2c502022-09-09 16:16:07 +0200163if (TFM_PARTITION_PROTECTED_STORAGE)
Summer Qind23bbb32022-10-18 15:30:06 +0800164 install(FILES ${INTERFACE_SRC_DIR}/tfm_ps_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800165 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100166endif()
167
Mark Horvathfbc2c502022-09-09 16:16:07 +0200168if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE)
Summer Qind23bbb32022-10-18 15:30:06 +0800169 install(FILES ${INTERFACE_SRC_DIR}/tfm_its_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800170 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100171endif()
172
Mark Horvathfbc2c502022-09-09 16:16:07 +0200173if (TFM_PARTITION_CRYPTO)
Summer Qind23bbb32022-10-18 15:30:06 +0800174 install(FILES ${INTERFACE_SRC_DIR}/tfm_crypto_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800175 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100176endif()
177
Mark Horvathfbc2c502022-09-09 16:16:07 +0200178if (TFM_PARTITION_INITIAL_ATTESTATION)
Summer Qind23bbb32022-10-18 15:30:06 +0800179 install(FILES ${INTERFACE_SRC_DIR}/tfm_attest_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800180 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100181endif()
182
Mark Horvathfbc2c502022-09-09 16:16:07 +0200183if(TFM_PARTITION_PLATFORM)
Summer Qind23bbb32022-10-18 15:30:06 +0800184 install(FILES ${INTERFACE_SRC_DIR}/tfm_platform_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800185 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100186endif()
Raef Colesb6814d52020-12-08 13:15:40 +0000187
Raef Colesb6814d52020-12-08 13:15:40 +0000188##################### Export image signing information #########################
189
Raef Colescdf39312023-11-03 14:37:18 +0000190if(BL2 AND PLATFORM_DEFAULT_IMAGE_SIGNING)
Raef Colesb6814d52020-12-08 13:15:40 +0000191 install(DIRECTORY bl2/ext/mcuboot/scripts
Anton Komlevaee4b612023-05-14 17:38:36 +0100192 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}
193 PATTERN "scripts/*.py"
194 PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
195 GROUP_EXECUTE GROUP_READ
196 PATTERN "scripts/wrapper/*.py"
197 PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
198 GROUP_EXECUTE GROUP_READ)
199
200 install(DIRECTORY ${MCUBOOT_PATH}/scripts/imgtool
201 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/scripts)
Raef Colesb6814d52020-12-08 13:15:40 +0000202
203 if (MCUBOOT_ENC_IMAGES)
204 install(FILES ${MCUBOOT_KEY_ENC}
Raef Coles1d68b872023-11-06 16:33:34 +0000205 RENAME image_enc_key.pem
Alamy Liu2c13c032021-01-20 09:55:50 -0800206 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
Raef Colesb6814d52020-12-08 13:15:40 +0000207 endif()
208
Raef Coles1d68b872023-11-06 16:33:34 +0000209 install(FILES $<TARGET_OBJECTS:signing_layout_s>
Alamy Liu2c13c032021-01-20 09:55:50 -0800210 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files)
Raef Coles1d68b872023-11-06 16:33:34 +0000211 install(FILES ${MCUBOOT_KEY_S}
212 RENAME image_s_signing_private_key.pem
Bence Baloghde3e1212023-07-07 13:07:38 +0200213 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
David Hu76734222023-11-15 12:17:17 +0800214 # Specify the MCUBOOT_KEY_S path for NS build
215 set(MCUBOOT_INSTALL_KEY_S
216 ${INSTALL_IMAGE_SIGNING_DIR}/keys/image_s_signing_private_key.pem)
Raef Coles1d68b872023-11-06 16:33:34 +0000217 install(FILES $<TARGET_FILE_DIR:bl2>/image_s_signing_public_key.pem
Bence Balogh11074a22023-09-29 17:53:06 +0200218 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
Anton Komlevaee4b612023-05-14 17:38:36 +0100219
Raef Coles1d68b872023-11-06 16:33:34 +0000220 if(MCUBOOT_IMAGE_NUMBER GREATER 1)
221 install(FILES $<TARGET_OBJECTS:signing_layout_ns>
222 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files)
223 install(FILES ${MCUBOOT_KEY_NS}
224 RENAME image_ns_signing_private_key.pem
David Hu76734222023-11-15 12:17:17 +0800225 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
226 # Specify the MCUBOOT_KEY_NS path for NS build
227 set(MCUBOOT_INSTALL_KEY_NS
228 ${INSTALL_IMAGE_SIGNING_DIR}/keys/image_ns_signing_private_key.pem)
Raef Coles1d68b872023-11-06 16:33:34 +0000229 install(FILES $<TARGET_FILE_DIR:bl2>/image_ns_signing_public_key.pem
230 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
231 endif()
Raef Colesb6814d52020-12-08 13:15:40 +0000232endif()
Sherry Zhang07b42412021-01-07 14:19:41 +0800233
234if(TFM_PARTITION_FIRMWARE_UPDATE)
Summer Qind23bbb32022-10-18 15:30:06 +0800235 install(FILES ${INTERFACE_SRC_DIR}/tfm_fwu_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800236 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Sherry Zhang07b42412021-01-07 14:19:41 +0800237endif()
Chris Brand9edf0812022-07-05 14:18:42 -0700238
Jianliang Shenbd624ed2023-10-24 15:42:59 +0800239######################### Export common configurations #########################
David Hu895cdc32023-01-16 19:19:25 +0800240
Dávid Házie7932282023-11-11 23:59:53 +0100241install(FILES ${CMAKE_SOURCE_DIR}/config/cp_check.cmake
Jianliang Shenbd624ed2023-10-24 15:42:59 +0800242 DESTINATION ${INSTALL_CONFIG_DIR})
David Hu895cdc32023-01-16 19:19:25 +0800243
David Hu06017772023-11-07 18:22:42 +0800244################### Read recommended tf-m-tests version ########################
245
246include(${CMAKE_SOURCE_DIR}/lib/ext/tf-m-tests/read_version.cmake)
247
Anton Komlevaee4b612023-05-14 17:38:36 +0100248###################### Install NS platform sources #############################
Chris Brand9edf0812022-07-05 14:18:42 -0700249
Anton Komlevaee4b612023-05-14 17:38:36 +0100250install(CODE "MESSAGE(\"----- Installing platform NS -----\")")
251
Jamie Fox62683db2024-03-12 15:50:41 +0000252install(DIRECTORY $<BUILD_INTERFACE:${CMSIS_PATH}/CMSIS/Core/Include>
Jamie Fox1ec133d2024-06-20 16:20:15 +0100253 $<BUILD_INTERFACE:${CMSIS_PATH}/CMSIS/Driver/Include>
Gergely Korcsák3d54aca2024-02-05 17:29:58 +0100254 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/ext/cmsis)
David Hu66bd9a02023-10-18 22:34:19 +0800255
256if(PLATFORM_DEFAULT_UART_STDOUT)
257 install(FILES ${PLATFORM_DIR}/ext/common/uart_stdout.c
258 ${PLATFORM_DIR}/ext/common/uart_stdout.h
259 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/ext/common)
260endif()
Anton Komlevaee4b612023-05-14 17:38:36 +0100261
David Hu71f6dcc2023-10-18 11:52:21 +0800262install(DIRECTORY ${PLATFORM_DIR}/include
263 DESTINATION ${INSTALL_PLATFORM_NS_DIR})
264
Anton Komlevaee4b612023-05-14 17:38:36 +0100265install(FILES ${CMAKE_SOURCE_DIR}/cmake/spe-CMakeLists.cmake
Anton Komlev3dd98632023-09-20 16:26:30 +0100266 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100267 RENAME CMakeLists.txt)
268
David Huc28b9b22023-10-14 15:33:16 +0800269install(FILES ${PLATFORM_DIR}/ns/toolchain_ns_GNUARM.cmake
270 ${PLATFORM_DIR}/ns/toolchain_ns_ARMCLANG.cmake
David Hu2bbcb962023-11-01 14:29:53 +0800271 ${PLATFORM_DIR}/ns/toolchain_ns_IARARM.cmake
Matthew Dalzelleb375ba2025-02-05 16:23:45 +0000272 ${PLATFORM_DIR}/ns/toolchain_ns_CLANG.cmake
Anton Komlevaee4b612023-05-14 17:38:36 +0100273 DESTINATION ${INSTALL_CMAKE_DIR})
274
Anton Komlevaee4b612023-05-14 17:38:36 +0100275install(FILES
276 ${CMAKE_SOURCE_DIR}/lib/fih/inc/fih.h
277 ${PLATFORM_DIR}/include/tfm_plat_ns.h
278 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/include)
279
280if (TARGET psa_crypto_config)
281# FIXIT: This is a temporal patch to reduce the change scope and simplify review.
282# In the future we shall decouple this target from tfm_config becuase
283# "psa_crypto_config" target exists not in all configurations.
284# Functionally "psa_crypto_config" provides only include path for Crypto accelerator.
285install(TARGETS tfm_config psa_crypto_config psa_interface
Anton Komlev3dd98632023-09-20 16:26:30 +0100286 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100287 EXPORT tfm-config
288 )
289else()
290 install(TARGETS tfm_config psa_interface
Anton Komlev3dd98632023-09-20 16:26:30 +0100291 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100292 EXPORT tfm-config
293 )
294endif()
295
296target_include_directories(psa_interface
297 INTERFACE
298 $<INSTALL_INTERFACE:interface/include>
299 )
300
301install(EXPORT tfm-config
302 FILE spe_export.cmake
303 DESTINATION ${INSTALL_CMAKE_DIR})
304
305configure_file(${CMAKE_SOURCE_DIR}/config/spe_config.cmake.in
306 ${INSTALL_CMAKE_DIR}/spe_config.cmake @ONLY)
David Hu9af4d7d2023-11-01 07:52:17 +0800307
308# Toolchain utils
Anton Komlev8ab4f042025-06-03 21:13:07 +0100309install(FILES
310 cmake/set_extensions.cmake
311 cmake/mcpu_features.cmake
David Hu9af4d7d2023-11-01 07:52:17 +0800312 DESTINATION ${INSTALL_CMAKE_DIR})