Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 1 | #------------------------------------------------------------------------------- |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 2 | # Copyright (c) 2020-2021, Arm Limited. All rights reserved. |
Charley Chu | e5fa2d0 | 2020-11-13 10:00:24 -0800 | [diff] [blame] | 3 | # Copyright (c) 2020, Cypress Semiconductor Corporation. All rights reserved. |
Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 4 | # |
| 5 | # SPDX-License-Identifier: BSD-3-Clause |
| 6 | # |
| 7 | #------------------------------------------------------------------------------- |
| 8 | |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 9 | # Generate correct filename |
Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 10 | string(TOUPPER ${TFM_PLATFORM} TFM_PLATFORM_UPPERCASE) |
| 11 | string(REGEX REPLACE "-" "_" TFM_PLATFORM_UPPERCASE_UNDERSCORE ${TFM_PLATFORM_UPPERCASE}) |
Øyvind Rønningstad | 1dab74b | 2020-12-01 15:26:39 +0100 | [diff] [blame] | 12 | string(REGEX REPLACE "^(\\.\\.([\\/\\\\]))+" "EXTERNAL\\2" TFM_PLATFORM_UPPERCASE_UNDERSCORE_NO_PARENT_DIR ${TFM_PLATFORM_UPPERCASE_UNDERSCORE}) |
Raef Coles | a1f504c | 2020-07-10 09:58:55 +0100 | [diff] [blame] | 13 | |
| 14 | install(DIRECTORY ${CMAKE_BINARY_DIR}/bin/ |
Raef Coles | a198a44 | 2020-11-24 11:42:53 +0000 | [diff] [blame] | 15 | DESTINATION ${TFM_INSTALL_PATH}/outputs/${TFM_PLATFORM_UPPERCASE_UNDERSCORE_NO_PARENT_DIR} |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 16 | ) |
| 17 | |
| 18 | set(INTERFACE_INC_DIR ${CMAKE_SOURCE_DIR}/interface/include) |
| 19 | set(INTERFACE_SRC_DIR ${CMAKE_SOURCE_DIR}/interface/src) |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 20 | |
| 21 | set(INSTALL_INTERFACE_INC_DIR ${TFM_INSTALL_PATH}/interface/include) |
| 22 | set(INSTALL_INTERFACE_SRC_DIR ${TFM_INSTALL_PATH}/interface/src) |
| 23 | set(INSTALL_INTERFACE_LIB_DIR ${TFM_INSTALL_PATH}/interface/lib) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 24 | |
David Hu | b24aead | 2020-10-17 19:46:19 +0800 | [diff] [blame] | 25 | # export veneer lib |
| 26 | if (NOT TFM_MULTI_CORE_TOPOLOGY) |
Raef Coles | 25fc175 | 2020-11-24 12:04:42 +0000 | [diff] [blame] | 27 | install(FILES ${CMAKE_BINARY_DIR}/secure_fw/s_veneers.o |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 28 | DESTINATION ${INSTALL_INTERFACE_LIB_DIR}) |
David Hu | b24aead | 2020-10-17 19:46:19 +0800 | [diff] [blame] | 29 | endif() |
| 30 | |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 31 | ####################### export headers ######################################### |
| 32 | |
| 33 | install(FILES ${INTERFACE_INC_DIR}/psa/client.h |
| 34 | ${INTERFACE_INC_DIR}/psa/error.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 35 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 36 | |
| 37 | install(FILES ${INTERFACE_INC_DIR}/os_wrapper/common.h |
| 38 | ${INTERFACE_INC_DIR}/os_wrapper/mutex.h |
Charley Chu | e5fa2d0 | 2020-11-13 10:00:24 -0800 | [diff] [blame] | 39 | ${INTERFACE_INC_DIR}/os_wrapper/semaphore.h |
| 40 | ${INTERFACE_INC_DIR}/os_wrapper/thread.h |
| 41 | ${INTERFACE_INC_DIR}/os_wrapper/tick.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 42 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/os_wrapper) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 43 | |
| 44 | install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/psa_manifest/sid.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 45 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa_manifest) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 46 | |
| 47 | install(FILES ${INTERFACE_INC_DIR}/tfm_api.h |
| 48 | ${INTERFACE_INC_DIR}/tfm_ns_interface.h |
| 49 | ${INTERFACE_INC_DIR}/tfm_ns_svc.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 50 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 51 | |
| 52 | install(FILES ${INTERFACE_INC_DIR}/ext/tz_context.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 53 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/ext) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 54 | |
| 55 | if (TFM_MULTI_CORE_TOPOLOGY) |
David Hu | 04969a4 | 2020-06-14 21:25:35 +0800 | [diff] [blame^] | 56 | install(FILES ${INTERFACE_INC_DIR}/multi_core/tfm_multi_core_api.h |
| 57 | ${INTERFACE_INC_DIR}/multi_core/tfm_ns_mailbox.h |
| 58 | ${INTERFACE_INC_DIR}/multi_core/tfm_mailbox.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 59 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 60 | else() |
| 61 | install(FILES ${CMAKE_BINARY_DIR}/generated/interface/include/tfm_veneers.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 62 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/tfm/veneers) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 63 | endif() |
| 64 | |
| 65 | if (TFM_NS_CLIENT_IDENTIFICATION) |
| 66 | install(FILES ${INTERFACE_INC_DIR}/tfm_nspm_api.h |
| 67 | ${INTERFACE_INC_DIR}/tfm_nspm_svc_handler.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 68 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 69 | endif() |
| 70 | |
| 71 | if (TFM_PARTITION_PROTECTED_STORAGE) |
| 72 | install(FILES ${INTERFACE_INC_DIR}/psa/protected_storage.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 73 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 74 | endif() |
| 75 | |
| 76 | if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
| 77 | install(FILES ${INTERFACE_INC_DIR}/psa/internal_trusted_storage.h |
| 78 | ${INTERFACE_INC_DIR}/psa/storage_common.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 79 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 80 | endif() |
| 81 | |
| 82 | if (TFM_PARTITION_CRYPTO) |
| 83 | install(FILES ${INTERFACE_INC_DIR}/psa/crypto_extra.h |
| 84 | ${INTERFACE_INC_DIR}/psa/crypto_compat.h |
| 85 | ${INTERFACE_INC_DIR}/psa/crypto.h |
| 86 | ${INTERFACE_INC_DIR}/psa/crypto_client_struct.h |
| 87 | ${INTERFACE_INC_DIR}/psa/crypto_sizes.h |
| 88 | ${INTERFACE_INC_DIR}/psa/crypto_struct.h |
| 89 | ${INTERFACE_INC_DIR}/psa/crypto_types.h |
| 90 | ${INTERFACE_INC_DIR}/psa/crypto_values.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 91 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 92 | install(FILES ${INTERFACE_INC_DIR}/tfm_crypto_defs.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 93 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 94 | endif() |
| 95 | |
| 96 | if (TFM_PARTITION_INITIAL_ATTESTATION) |
| 97 | install(FILES ${INTERFACE_INC_DIR}/psa/initial_attestation.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 98 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}/psa) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 99 | endif() |
| 100 | |
| 101 | if(TFM_PARTITION_AUDIT_LOG) |
| 102 | install(FILES ${INTERFACE_INC_DIR}/psa_audit_api.h |
| 103 | ${INTERFACE_INC_DIR}/psa_audit_defs.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 104 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 105 | endif() |
| 106 | |
| 107 | if(TFM_PARTITION_PLATFORM) |
| 108 | install(FILES ${INTERFACE_INC_DIR}/tfm_platform_api.h |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 109 | DESTINATION ${INSTALL_INTERFACE_INC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 110 | endif() |
| 111 | |
| 112 | ####################### export sources ######################################### |
| 113 | |
| 114 | if (TFM_MULTI_CORE_TOPOLOGY) |
David Hu | 04969a4 | 2020-06-14 21:25:35 +0800 | [diff] [blame^] | 115 | install(FILES ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox.c |
| 116 | ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_ns_api.c |
| 117 | ${INTERFACE_SRC_DIR}/multi_core/tfm_multi_core_psa_ns_api.c |
| 118 | ${INTERFACE_SRC_DIR}/multi_core/tfm_ns_mailbox_rtos_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 119 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 120 | else() |
| 121 | install(FILES ${INTERFACE_SRC_DIR}/tfm_ns_interface.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 122 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 123 | |
| 124 | if(TFM_PSA_API) |
| 125 | install(FILES ${INTERFACE_SRC_DIR}/tfm_psa_ns_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 126 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 127 | endif() |
| 128 | endif() |
| 129 | |
| 130 | if (TFM_NS_CLIENT_IDENTIFICATION) |
| 131 | install(FILES ${INTERFACE_SRC_DIR}/tfm_nspm_api.c |
| 132 | ${INTERFACE_SRC_DIR}/tfm_nspm_svc_handler.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 133 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 134 | endif() |
| 135 | |
| 136 | if (TFM_PARTITION_PROTECTED_STORAGE) |
| 137 | if (TFM_PSA_API) |
| 138 | install(FILES ${INTERFACE_SRC_DIR}/tfm_ps_ipc_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 139 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 140 | else() |
| 141 | install(FILES ${INTERFACE_SRC_DIR}/tfm_ps_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 142 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 143 | endif() |
| 144 | endif() |
| 145 | |
| 146 | if (TFM_PARTITION_INTERNAL_TRUSTED_STORAGE) |
| 147 | if (TFM_PSA_API) |
| 148 | install(FILES ${INTERFACE_SRC_DIR}/tfm_its_ipc_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 149 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 150 | else() |
| 151 | install(FILES ${INTERFACE_SRC_DIR}/tfm_its_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 152 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 153 | endif() |
| 154 | endif() |
| 155 | |
| 156 | if (TFM_PARTITION_CRYPTO) |
| 157 | if (TFM_PSA_API) |
| 158 | install(FILES ${INTERFACE_SRC_DIR}/tfm_crypto_ipc_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 159 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 160 | else() |
| 161 | install(FILES ${INTERFACE_SRC_DIR}/tfm_crypto_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 162 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 163 | endif() |
| 164 | endif() |
| 165 | |
| 166 | if (TFM_PARTITION_INITIAL_ATTESTATION) |
| 167 | if (TFM_PSA_API) |
| 168 | install(FILES ${INTERFACE_SRC_DIR}/tfm_initial_attestation_ipc_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 169 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 170 | else() |
| 171 | install(FILES ${INTERFACE_SRC_DIR}/tfm_initial_attestation_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 172 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 173 | endif() |
| 174 | endif() |
| 175 | |
| 176 | if(TFM_PARTITION_AUDIT_LOG) |
| 177 | install(FILES ${INTERFACE_SRC_DIR}/tfm_audit_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 178 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 179 | endif() |
| 180 | |
| 181 | if(TFM_PARTITION_PLATFORM) |
| 182 | if(TFM_PSA_API) |
| 183 | install(FILES ${INTERFACE_SRC_DIR}/tfm_platform_ipc_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 184 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 185 | else() |
| 186 | install(FILES ${INTERFACE_SRC_DIR}/tfm_platform_func_api.c |
Raef Coles | 4fed463 | 2020-12-08 12:56:47 +0000 | [diff] [blame] | 187 | DESTINATION ${INSTALL_INTERFACE_SRC_DIR}) |
Raef Coles | 035c83b | 2020-09-29 10:32:52 +0100 | [diff] [blame] | 188 | endif() |
| 189 | endif() |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 190 | |
| 191 | |
| 192 | ##################### Export image signing information ######################### |
| 193 | |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 194 | set(INSTALL_IMAGE_SIGNING_DIR ${TFM_INSTALL_PATH}/image_signing) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 195 | |
| 196 | if(BL2) |
| 197 | install(DIRECTORY bl2/ext/mcuboot/scripts |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 198 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 199 | |
| 200 | if (MCUBOOT_ENC_IMAGES) |
| 201 | install(FILES ${MCUBOOT_KEY_ENC} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 202 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 203 | endif() |
| 204 | |
| 205 | install(FILES $<TARGET_OBJECTS:signing_layout_s> |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 206 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 207 | |
| 208 | if(MCUBOOT_IMAGE_NUMBER GREATER 1) |
| 209 | install(FILES $<TARGET_OBJECTS:signing_layout_ns> |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 210 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/layout_files) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 211 | |
| 212 | install(FILES ${MCUBOOT_KEY_NS} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 213 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 214 | else() |
| 215 | install(FILES ${MCUBOOT_KEY_S} |
Alamy Liu | 2c13c03 | 2021-01-20 09:55:50 -0800 | [diff] [blame] | 216 | DESTINATION ${INSTALL_IMAGE_SIGNING_DIR}/keys) |
Raef Coles | b6814d5 | 2020-12-08 13:15:40 +0000 | [diff] [blame] | 217 | endif() |
| 218 | endif() |