Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 1 | #------------------------------------------------------------------------------- |
Sherry Zhang | 73126e5 | 2022-02-15 14:27:49 +0800 | [diff] [blame] | 2 | # Copyright (c) 2020-2022, Arm Limited. All rights reserved. |
Chris Brand | cae2026 | 2022-06-23 12:05:33 -0700 | [diff] [blame] | 3 | # Copyright (c) 2022 Cypress Semiconductor Corporation (an Infineon company) |
| 4 | # or an affiliate of Cypress Semiconductor Corporation. All rights reserved. |
Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 5 | # |
| 6 | # SPDX-License-Identifier: BSD-3-Clause |
| 7 | # |
| 8 | #------------------------------------------------------------------------------- |
| 9 | |
Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 10 | install(DIRECTORY ${CMAKE_BINARY_DIR}/bin/ |
Anton Komlev | 968887a | 2021-12-22 23:24:13 +0000 | [diff] [blame] | 11 | DESTINATION ${TFM_INSTALL_PATH}/outputs |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 12 | ) |
| 13 | |
| 14 | set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include) |
| 15 | set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src) |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 16 | |
| 17 | set(INSTALL_INTERFACE_INC_DIR ${TFM_INSTALL_PATH}/interface/include) |
| 18 | set(INSTALL_INTERFACE_SRC_DIR ${TFM_INSTALL_PATH}/interface/src) |
| 19 | set(INSTALL_INTERFACE_LIB_DIR ${TFM_INSTALL_PATH}/interface/lib) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 20 | |
David Hu | b24aead | 2020-10-17 19:46:19 +0800 | [diff] [blame] | 21 | # export veneer lib |
Chris Brand | ca81902 | 2022-07-19 09:25:15 -0700 | [diff] [blame] | 22 | if (CONFIG_TFM_USE_TRUSTZONE) |
Raef Coles | 25fc175 | 2020-11-24 12:04:42 +0000 | [diff] [blame] | 23 | install(FILES ${CMAKE_BINARY_DIR}/secure_fw/s_veneers.o |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 24 | DESTINATION ${INSTALL_INTERFACE_LIB_DIR}) |
David Hu | b24aead | 2020-10-17 19:46:19 +0800 | [diff] [blame] | 25 | endif() |
| 26 | |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 27 | ####################### export headers ######################################### |
| 28 | |
| 29 | install(FILES ${INTERFACE_INC_DIR}/psa/client.h |
| 30 | ${INTERFACE_INC_DIR}/psa/error.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 31 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 32 | |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 33 | install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa_manifest/sid.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 34 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa_manifest) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 35 | |
| 36 | install(FILES ${INTERFACE_INC_DIR}/tfm_api.h |
| 37 | ${INTERFACE_INC_DIR}/tfm_ns_interface.h |
David Hu | dc8cb9e | 2021-11-10 12:45:59 +0800 | [diff] [blame] | 38 | ${INTERFACE_INC_DIR}/psa_config.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 39 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 40 | |
Sherry Zhnag | 482b88b | 2021-08-19 17:51:47 +0800 | [diff] [blame] | 41 | install(FILES ${INTERFACE_INC_DIR}/tfm_ns_client_ext.h |
| 42 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 43 | |
David Hu | 32bd615 | 2022-09-27 13:10:36 +0800 | [diff] [blame] | 44 | install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/config_impl.h |
| 45 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
| 46 | |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 47 | install(FILES ${INTERFACE_INC_DIR}/tfm_psa_call_pack.h |
| 48 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
| 49 | install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa/framework_feature.h |
| 50 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Xinyu Zhang | 93899d0 | 2021-05-11 10:48:52 +0800 | [diff] [blame] | 51 | |
Chris Brand | fbf3f46 | 2022-06-23 15:27:20 -0700 | [diff] [blame] | 52 | if (TFM_PARTITION_NS_AGENT_MAILBOX) |
David Hu | 04969a4 | 2020-06-14 21:25:35 +0800 | [diff] [blame] | 53 | install(FILES ${INTERFACE_INC_DIR}/multi_core/tfm_multi_core_api.h |
| 54 | ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox.h |
| 55 | ${INTERFACE_INC_DIR}/multi_core/tfm_mailbox.h |
David Hu | cb91581 | 2021-12-27 14:22:04 +0800 | [diff] [blame] | 56 | ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox_test.h |
David Hu | 186a129 | 2021-09-13 09:05:52 +0800 | [diff] [blame] | 57 | ${CMAKE_BINARY_DIR}/generated/interface/include/tfm_mailbox_config.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 58 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Chris Brand | fbf3f46 | 2022-06-23 15:27:20 -0700 | [diff] [blame] | 59 | endif() |
| 60 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 61 | if (TFM_PARTITION_PROTECTED_STORAGE) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 62 | install(FILES ${INTERFACE_INC_DIR}/psa/protected_storage.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 63 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
David Hu | dc8cb9e | 2021-11-10 12:45:59 +0800 | [diff] [blame] | 64 | install(FILES ${INTERFACE_INC_DIR}/tfm_ps_defs.h |
| 65 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 66 | endif() |
| 67 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 68 | if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 69 | install(FILES ${INTERFACE_INC_DIR}/psa/internal_trusted_storage.h |
| 70 | ${INTERFACE_INC_DIR}/psa/storage_common.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 71 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
David Hu | dc8cb9e | 2021-11-10 12:45:59 +0800 | [diff] [blame] | 72 | install(FILES ${INTERFACE_INC_DIR}/tfm_its_defs.h |
| 73 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 74 | endif() |
| 75 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 76 | if (TFM_PARTITION_CRYPTO) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 77 | install(FILES ${INTERFACE_INC_DIR}/psa/crypto_extra.h |
| 78 | ${INTERFACE_INC_DIR}/psa/crypto_compat.h |
| 79 | ${INTERFACE_INC_DIR}/psa/crypto.h |
| 80 | ${INTERFACE_INC_DIR}/psa/crypto_client_struct.h |
| 81 | ${INTERFACE_INC_DIR}/psa/crypto_sizes.h |
| 82 | ${INTERFACE_INC_DIR}/psa/crypto_struct.h |
| 83 | ${INTERFACE_INC_DIR}/psa/crypto_types.h |
| 84 | ${INTERFACE_INC_DIR}/psa/crypto_values.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 85 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 86 | install(FILES ${INTERFACE_INC_DIR}/tfm_crypto_defs.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 87 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 88 | endif() |
| 89 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 90 | if (TFM_PARTITION_INITIAL_ATTESTATION) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 91 | install(FILES ${INTERFACE_INC_DIR}/psa/initial_attestation.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 92 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
David Hu | dc8cb9e | 2021-11-10 12:45:59 +0800 | [diff] [blame] | 93 | install(FILES ${INTERFACE_INC_DIR}/tfm_attest_defs.h |
David Hu | 32bd615 | 2022-09-27 13:10:36 +0800 | [diff] [blame] | 94 | ${INTERFACE_INC_DIR}/tfm_attest_iat_defs.h |
David Hu | dc8cb9e | 2021-11-10 12:45:59 +0800 | [diff] [blame] | 95 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 96 | endif() |
| 97 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 98 | if(TFM_PARTITION_PLATFORM) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 99 | install(FILES ${INTERFACE_INC_DIR}/tfm_platform_api.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 100 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 101 | endif() |
| 102 | |
Sherry Zhang | 07b4241 | 2021-01-07 14:19:41 +0800 | [diff] [blame] | 103 | if(TFM_PARTITION_FIRMWARE_UPDATE) |
| 104 | install(FILES ${INTERFACE_INC_DIR}/psa/update.h |
Sherry Zhang | 73126e5 | 2022-02-15 14:27:49 +0800 | [diff] [blame] | 105 | ${CMAKE_BINARY_DIR}/generated/interface/include/psa/fwu_config.h |
Sherry Zhang | 07b4241 | 2021-01-07 14:19:41 +0800 | [diff] [blame] | 106 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
| 107 | install(FILES ${INTERFACE_INC_DIR}/tfm_fwu_defs.h |
| 108 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
| 109 | endif() |
| 110 | |
David Hu | 32bd615 | 2022-09-27 13:10:36 +0800 | [diff] [blame] | 111 | if(PLATFORM_DEFAULT_CRYPTO_KEYS) |
| 112 | install(DIRECTORY ${INTERFACE_INC_DIR}/crypto_keys |
| 113 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
| 114 | endif() |
| 115 | |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 116 | ####################### export sources ######################################### |
| 117 | |
Chris Brand | fbf3f46 | 2022-06-23 15:27:20 -0700 | [diff] [blame] | 118 | if (TFM_PARTITION_NS_AGENT_MAILBOX) |
David Hu | 04969a4 | 2020-06-14 21:25:35 +0800 | [diff] [blame] | 119 | install(FILES ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c |
| 120 | ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c |
| 121 | ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c |
David Hu | d597345 | 2020-11-26 16:47:46 +0800 | [diff] [blame] | 122 | ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_thread.c |
David Hu | 32bd615 | 2022-09-27 13:10:36 +0800 | [diff] [blame] | 123 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}/multi_core) |
Chris Brand | fbf3f46 | 2022-06-23 15:27:20 -0700 | [diff] [blame] | 124 | endif() |
David Hu | f07f3f1 | 2021-04-06 18:03:33 +0800 | [diff] [blame] | 125 | |
Chris Brand | fbf3f46 | 2022-06-23 15:27:20 -0700 | [diff] [blame] | 126 | if (TFM_PARTITION_NS_AGENT_TZ) |
| 127 | install(FILES ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c |
| 128 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
| 129 | endif() |
| 130 | |
| 131 | if (CONFIG_TFM_USE_TRUSTZONE) |
David Hu | f07f3f1 | 2021-04-06 18:03:33 +0800 | [diff] [blame] | 132 | install(FILES ${INTERFACE_SRC_DIR}/tfm_ns_interface.c.example |
| 133 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 134 | endif() |
| 135 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 136 | if (TFM_PARTITION_PROTECTED_STORAGE) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 137 | install(FILES ${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c |
| 138 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 139 | endif() |
| 140 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 141 | if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 142 | install(FILES ${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c |
| 143 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 144 | endif() |
| 145 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 146 | if (TFM_PARTITION_CRYPTO) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 147 | install(FILES ${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c |
| 148 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 149 | endif() |
| 150 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 151 | if (TFM_PARTITION_INITIAL_ATTESTATION) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 152 | install(FILES ${INTERFACE_SRC_DIR}/tfm_initial_attestation_ipc_api.c |
| 153 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 154 | endif() |
| 155 | |
Mark Horvath | fbc2c50 | 2022-09-09 16:16:07 +0200 | [diff] [blame] | 156 | if(TFM_PARTITION_PLATFORM) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 157 | install(FILES ${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c |
| 158 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 159 | endif() |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 160 | |
| 161 | |
| 162 | ##################### Export image signing information ######################### |
| 163 | |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 164 | set(INSTALL_IMAGE_SIGNING_DIR ${TFM_INSTALL_PATH}/image_signing) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 165 | |
| 166 | if(BL2) |
| 167 | install(DIRECTORY bl2/ext/mcuboot/scripts |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 168 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 169 | |
| 170 | if (MCUBOOT_ENC_IMAGES) |
| 171 | install(FILES ${MCUBOOT_KEY_ENC} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 172 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 173 | endif() |
| 174 | |
| 175 | install(FILES $<TARGET_OBJECTS:signing_layout_s> |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 176 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 177 | |
| 178 | if(MCUBOOT_IMAGE_NUMBER GREATER 1) |
| 179 | install(FILES $<TARGET_OBJECTS:signing_layout_ns> |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 180 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 181 | |
| 182 | install(FILES ${MCUBOOT_KEY_NS} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 183 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 184 | else() |
| 185 | install(FILES ${MCUBOOT_KEY_S} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 186 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 187 | endif() |
| 188 | endif() |
Sherry Zhang | 07b4241 | 2021-01-07 14:19:41 +0800 | [diff] [blame] | 189 | |
| 190 | if(TFM_PARTITION_FIRMWARE_UPDATE) |
Summer Qin | 566e03b | 2022-10-08 17:27:42 +0800 | [diff] [blame] | 191 | install(FILES ${INTERFACE_SRC_DIR}/tfm_firmware_update_ipc_api.c |
| 192 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Sherry Zhang | 07b4241 | 2021-01-07 14:19:41 +0800 | [diff] [blame] | 193 | endif() |
Chris Brand | 9edf081 | 2022-07-05 14:18:42 -0700 | [diff] [blame] | 194 | |
| 195 | ##################### Platform-specific installation ########################### |
| 196 | |
| 197 | if (EXISTS ${CMAKE_SOURCE_DIR}/platform/ext/target/${TFM_PLATFORM}/install.cmake) |
| 198 | include(platform/ext/target/${TFM_PLATFORM}/install.cmake) |
| 199 | endif() |