blob: 9212877c232d357d83193c0fb78251c336a56644 [file] [log] [blame]
Raef Colesa1f504c2020-07-10 09:58:55 +01001#-------------------------------------------------------------------------------
Kevin Penga2b68022023-01-13 13:54:05 +08002# Copyright (c) 2020-2023, Arm Limited. All rights reserved.
BohdanHunkof871df02023-02-03 14:36:41 +02003# Copyright (c) 2022-2023 Cypress Semiconductor Corporation (an Infineon company)
Chris Brandcae20262022-06-23 12:05:33 -07004# or an affiliate of Cypress Semiconductor Corporation. All rights reserved.
Raef Colesa1f504c2020-07-10 09:58:55 +01005#
6# SPDX-License-Identifier: BSD-3-Clause
7#
8#-------------------------------------------------------------------------------
9
Raef Colesa1f504c2020-07-10 09:58:55 +010010install(DIRECTORY ${CMAKE_BINARY_DIR}/bin/
Anton Komlev3dd98632023-09-20 16:26:30 +010011 DESTINATION bin
Raef Coles035c83b2020-09-29 10:32:52 +010012)
13
David Hub24aead2020-10-17 19:46:19 +080014# export veneer lib
Chris Brandca819022022-07-19 09:25:15 -070015if (CONFIG_TFM_USE_TRUSTZONE)
Raef Coles25fc1752020-11-24 12:04:42 +000016 install(FILES ${CMAKE_BINARY_DIR}/secure_fw/s_veneers.o
Raef Coles4fed4632020-12-08 12:56:47 +000017 DESTINATION ${INSTALL_INTERFACE_LIB_DIR})
David Hub24aead2020-10-17 19:46:19 +080018endif()
19
Raef Coles035c83b2020-09-29 10:32:52 +010020####################### export headers #########################################
21
22install(FILES ${INTERFACE_INC_DIR}/psa/client.h
23 ${INTERFACE_INC_DIR}/psa/error.h
Raef Coles4fed4632020-12-08 12:56:47 +000024 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Raef Coles035c83b2020-09-29 10:32:52 +010025
Raef Coles035c83b2020-09-29 10:32:52 +010026install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa_manifest/sid.h
Raef Coles4fed4632020-12-08 12:56:47 +000027 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa_manifest)
Raef Coles035c83b2020-09-29 10:32:52 +010028
Kevin Peng0e340ea2023-08-15 17:51:44 +080029install(FILES ${INTERFACE_INC_DIR}/tfm_veneers.h
Raef Coles035c83b2020-09-29 10:32:52 +010030 ${INTERFACE_INC_DIR}/tfm_ns_interface.h
Raef Coles4fed4632020-12-08 12:56:47 +000031 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010032
Sherry Zhnag482b88b2021-08-19 17:51:47 +080033install(FILES ${INTERFACE_INC_DIR}/tfm_ns_client_ext.h
34 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010035
David Hu895cdc32023-01-16 19:19:25 +080036install(FILES ${CMAKE_SOURCE_DIR}/secure_fw/include/config_tfm.h
37 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
David Hu6d1a9b62023-02-22 16:54:04 +080038install(FILES ${CMAKE_SOURCE_DIR}/config/config_base.h
39 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
David Hu895cdc32023-01-16 19:19:25 +080040
Summer Qin566e03b2022-10-08 17:27:42 +080041install(FILES ${INTERFACE_INC_DIR}/tfm_psa_call_pack.h
42 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
43install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa/framework_feature.h
44 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Xinyu Zhang93899d02021-05-11 10:48:52 +080045
Chris Brandfbf3f462022-06-23 15:27:20 -070046if (TFM_PARTITION_NS_AGENT_MAILBOX)
David Hu04969a42020-06-14 21:25:35 +080047 install(FILES ${INTERFACE_INC_DIR}/multi_core/tfm_multi_core_api.h
48 ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox.h
49 ${INTERFACE_INC_DIR}/multi_core/tfm_mailbox.h
David Hucb915812021-12-27 14:22:04 +080050 ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox_test.h
David Hu186a1292021-09-13 09:05:52 +080051 ${CMAKE_BINARY_DIR}/generated/interface/include/tfm_mailbox_config.h
David Hu71f6dcc2023-10-18 11:52:21 +080052 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/multi_core)
Chris Brandfbf3f462022-06-23 15:27:20 -070053endif()
54
Mark Horvathfbc2c502022-09-09 16:16:07 +020055if (TFM_PARTITION_PROTECTED_STORAGE)
Raef Coles035c83b2020-09-29 10:32:52 +010056 install(FILES ${INTERFACE_INC_DIR}/psa/protected_storage.h
Raef Coles4fed4632020-12-08 12:56:47 +000057 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +080058 install(FILES ${INTERFACE_INC_DIR}/tfm_ps_defs.h
59 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010060endif()
61
Mark Horvathfbc2c502022-09-09 16:16:07 +020062if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE)
Raef Coles035c83b2020-09-29 10:32:52 +010063 install(FILES ${INTERFACE_INC_DIR}/psa/internal_trusted_storage.h
64 ${INTERFACE_INC_DIR}/psa/storage_common.h
Raef Coles4fed4632020-12-08 12:56:47 +000065 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +080066 install(FILES ${INTERFACE_INC_DIR}/tfm_its_defs.h
67 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010068endif()
69
Mark Horvathfbc2c502022-09-09 16:16:07 +020070if (TFM_PARTITION_CRYPTO)
Raef Coles035c83b2020-09-29 10:32:52 +010071 install(FILES ${INTERFACE_INC_DIR}/psa/crypto_extra.h
72 ${INTERFACE_INC_DIR}/psa/crypto_compat.h
73 ${INTERFACE_INC_DIR}/psa/crypto.h
74 ${INTERFACE_INC_DIR}/psa/crypto_client_struct.h
Xinyu Zhangfce20372023-04-10 14:43:47 +080075 ${INTERFACE_INC_DIR}/psa/crypto_platform.h
Raef Coles035c83b2020-09-29 10:32:52 +010076 ${INTERFACE_INC_DIR}/psa/crypto_sizes.h
77 ${INTERFACE_INC_DIR}/psa/crypto_struct.h
78 ${INTERFACE_INC_DIR}/psa/crypto_types.h
79 ${INTERFACE_INC_DIR}/psa/crypto_values.h
Raef Coles4fed4632020-12-08 12:56:47 +000080 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
Raef Coles035c83b2020-09-29 10:32:52 +010081 install(FILES ${INTERFACE_INC_DIR}/tfm_crypto_defs.h
Raef Coles4fed4632020-12-08 12:56:47 +000082 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010083endif()
84
Mark Horvathfbc2c502022-09-09 16:16:07 +020085if (TFM_PARTITION_INITIAL_ATTESTATION)
David Hu9191b612023-06-08 12:02:39 +080086 install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa/initial_attestation.h
Raef Coles4fed4632020-12-08 12:56:47 +000087 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
David Hudc8cb9e2021-11-10 12:45:59 +080088 install(FILES ${INTERFACE_INC_DIR}/tfm_attest_defs.h
David Hu32bd6152022-09-27 13:10:36 +080089 ${INTERFACE_INC_DIR}/tfm_attest_iat_defs.h
David Hudc8cb9e2021-11-10 12:45:59 +080090 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010091endif()
92
Mark Horvathfbc2c502022-09-09 16:16:07 +020093if(TFM_PARTITION_PLATFORM)
Raef Coles035c83b2020-09-29 10:32:52 +010094 install(FILES ${INTERFACE_INC_DIR}/tfm_platform_api.h
Raef Coles4fed4632020-12-08 12:56:47 +000095 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +010096endif()
97
Sherry Zhang07b42412021-01-07 14:19:41 +080098if(TFM_PARTITION_FIRMWARE_UPDATE)
99 install(FILES ${INTERFACE_INC_DIR}/psa/update.h
Sherry Zhang73126e52022-02-15 14:27:49 +0800100 ${CMAKE_BINARY_DIR}/generated/interface/include/psa/fwu_config.h
Sherry Zhang07b42412021-01-07 14:19:41 +0800101 DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa)
102 install(FILES ${INTERFACE_INC_DIR}/tfm_fwu_defs.h
103 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
104endif()
105
David Hu32bd6152022-09-27 13:10:36 +0800106if(PLATFORM_DEFAULT_CRYPTO_KEYS)
107 install(DIRECTORY ${INTERFACE_INC_DIR}/crypto_keys
108 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
109endif()
110
Raef Coles035c83b2020-09-29 10:32:52 +0100111####################### export sources #########################################
112
Chris Brandfbf3f462022-06-23 15:27:20 -0700113if (TFM_PARTITION_NS_AGENT_MAILBOX)
David Hu04969a42020-06-14 21:25:35 +0800114 install(FILES ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c
115 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c
116 ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c
David Hud5973452020-11-26 16:47:46 +0800117 ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_thread.c
David Hu32bd6152022-09-27 13:10:36 +0800118 DESTINATION ${INSTALL_INTERFACE_SRC_DIR}/multi_core)
Chris Brandfbf3f462022-06-23 15:27:20 -0700119endif()
David Huf07f3f12021-04-06 18:03:33 +0800120
Chris Brandfbf3f462022-06-23 15:27:20 -0700121if (TFM_PARTITION_NS_AGENT_TZ)
122 install(FILES ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c
123 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
124endif()
125
BohdanHunkof871df02023-02-03 14:36:41 +0200126 install(DIRECTORY ${INTERFACE_INC_DIR}/os_wrapper
127 DESTINATION ${INSTALL_INTERFACE_INC_DIR})
128
Chris Brandfbf3f462022-06-23 15:27:20 -0700129if (CONFIG_TFM_USE_TRUSTZONE)
BohdanHunkof871df02023-02-03 14:36:41 +0200130 install(DIRECTORY ${INTERFACE_SRC_DIR}/os_wrapper
David Huf07f3f12021-04-06 18:03:33 +0800131 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100132endif()
133
Mark Horvathfbc2c502022-09-09 16:16:07 +0200134if (TFM_PARTITION_PROTECTED_STORAGE)
Summer Qind23bbb32022-10-18 15:30:06 +0800135 install(FILES ${INTERFACE_SRC_DIR}/tfm_ps_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800136 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100137endif()
138
Mark Horvathfbc2c502022-09-09 16:16:07 +0200139if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE)
Summer Qind23bbb32022-10-18 15:30:06 +0800140 install(FILES ${INTERFACE_SRC_DIR}/tfm_its_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800141 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100142endif()
143
Mark Horvathfbc2c502022-09-09 16:16:07 +0200144if (TFM_PARTITION_CRYPTO)
Summer Qind23bbb32022-10-18 15:30:06 +0800145 install(FILES ${INTERFACE_SRC_DIR}/tfm_crypto_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800146 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100147endif()
148
Mark Horvathfbc2c502022-09-09 16:16:07 +0200149if (TFM_PARTITION_INITIAL_ATTESTATION)
Summer Qind23bbb32022-10-18 15:30:06 +0800150 install(FILES ${INTERFACE_SRC_DIR}/tfm_attest_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800151 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100152endif()
153
Mark Horvathfbc2c502022-09-09 16:16:07 +0200154if(TFM_PARTITION_PLATFORM)
Summer Qind23bbb32022-10-18 15:30:06 +0800155 install(FILES ${INTERFACE_SRC_DIR}/tfm_platform_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800156 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Raef Coles035c83b2020-09-29 10:32:52 +0100157endif()
Raef Colesb6814d52020-12-08 13:15:40 +0000158
159
160##################### Export image signing information #########################
161
Raef Colesb6814d52020-12-08 13:15:40 +0000162if(BL2)
163 install(DIRECTORY bl2/ext/mcuboot/scripts
Anton Komlevaee4b612023-05-14 17:38:36 +0100164 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}
165 PATTERN "scripts/*.py"
166 PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
167 GROUP_EXECUTE GROUP_READ
168 PATTERN "scripts/wrapper/*.py"
169 PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
170 GROUP_EXECUTE GROUP_READ)
171
172 install(DIRECTORY ${MCUBOOT_PATH}/scripts/imgtool
173 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/scripts)
Raef Colesb6814d52020-12-08 13:15:40 +0000174
175 if (MCUBOOT_ENC_IMAGES)
176 install(FILES ${MCUBOOT_KEY_ENC}
Alamy Liu2c13c032021-01-20 09:55:50 -0800177 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
Raef Colesb6814d52020-12-08 13:15:40 +0000178 endif()
179
Anton Komlevaee4b612023-05-14 17:38:36 +0100180 # unconditionally install all necessary files for optional signing
181 install(FILES $<TARGET_OBJECTS:signing_layout_s>
182 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files)
183
184 if(MCUBOOT_IMAGE_NUMBER GREATER 1)
185 install(FILES $<TARGET_OBJECTS:signing_layout_ns>
186 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files)
Raef Colesb6814d52020-12-08 13:15:40 +0000187 endif()
Anton Komlevaee4b612023-05-14 17:38:36 +0100188
189 install(FILES ${MCUBOOT_KEY_NS} ${MCUBOOT_KEY_S}
190 DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys)
Raef Colesb6814d52020-12-08 13:15:40 +0000191endif()
Sherry Zhang07b42412021-01-07 14:19:41 +0800192
193if(TFM_PARTITION_FIRMWARE_UPDATE)
Summer Qind23bbb32022-10-18 15:30:06 +0800194 install(FILES ${INTERFACE_SRC_DIR}/tfm_fwu_api.c
Summer Qin566e03b2022-10-08 17:27:42 +0800195 DESTINATION ${INSTALL_INTERFACE_SRC_DIR})
Sherry Zhang07b42412021-01-07 14:19:41 +0800196endif()
Chris Brand9edf0812022-07-05 14:18:42 -0700197
Anton Komlevaee4b612023-05-14 17:38:36 +0100198###################### Install NS platform sources #############################
David Hu895cdc32023-01-16 19:19:25 +0800199
Anton Komlevaee4b612023-05-14 17:38:36 +0100200install(CODE "MESSAGE(\"----- Installing platform NS -----\")")
201
Anton Komlevaee4b612023-05-14 17:38:36 +0100202install(DIRECTORY ${PLATFORM_DIR}/ext/cmsis
203 DESTINATION ${INSTALL_PLATFORM_NS_DIR})
204
David Hu71f6dcc2023-10-18 11:52:21 +0800205install(DIRECTORY ${PLATFORM_DIR}/include
206 DESTINATION ${INSTALL_PLATFORM_NS_DIR})
207
Anton Komlevaee4b612023-05-14 17:38:36 +0100208install(FILES ${CMAKE_SOURCE_DIR}/cmake/spe-CMakeLists.cmake
Anton Komlev3dd98632023-09-20 16:26:30 +0100209 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100210 RENAME CMakeLists.txt)
211
David Huc28b9b22023-10-14 15:33:16 +0800212install(FILES ${PLATFORM_DIR}/ns/toolchain_ns_GNUARM.cmake
213 ${PLATFORM_DIR}/ns/toolchain_ns_ARMCLANG.cmake
Anton Komlevaee4b612023-05-14 17:38:36 +0100214 DESTINATION ${INSTALL_CMAKE_DIR})
215
Anton Komlevaee4b612023-05-14 17:38:36 +0100216install(FILES
217 ${CMAKE_SOURCE_DIR}/lib/fih/inc/fih.h
218 ${PLATFORM_DIR}/include/tfm_plat_ns.h
219 DESTINATION ${INSTALL_PLATFORM_NS_DIR}/include)
220
221if (TARGET psa_crypto_config)
222# FIXIT: This is a temporal patch to reduce the change scope and simplify review.
223# In the future we shall decouple this target from tfm_config becuase
224# "psa_crypto_config" target exists not in all configurations.
225# Functionally "psa_crypto_config" provides only include path for Crypto accelerator.
226install(TARGETS tfm_config psa_crypto_config psa_interface
Anton Komlev3dd98632023-09-20 16:26:30 +0100227 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100228 EXPORT tfm-config
229 )
230else()
231 install(TARGETS tfm_config psa_interface
Anton Komlev3dd98632023-09-20 16:26:30 +0100232 DESTINATION ${CMAKE_INSTALL_PREFIX}
Anton Komlevaee4b612023-05-14 17:38:36 +0100233 EXPORT tfm-config
234 )
235endif()
236
237target_include_directories(psa_interface
238 INTERFACE
239 $<INSTALL_INTERFACE:interface/include>
240 )
241
242install(EXPORT tfm-config
243 FILE spe_export.cmake
244 DESTINATION ${INSTALL_CMAKE_DIR})
245
246configure_file(${CMAKE_SOURCE_DIR}/config/spe_config.cmake.in
247 ${INSTALL_CMAKE_DIR}/spe_config.cmake @ONLY)