blob: 2e18d2b9a9f5786d4e8383d2a02f8944912603f4 [file] [log] [blame]
Gilles Peskinee820c0a2023-08-03 17:45:20 +02001option(USE_STATIC_MBEDTLS_LIBRARY "Build Mbed TLS static library." ON)
2option(USE_SHARED_MBEDTLS_LIBRARY "Build Mbed TLS shared library." OFF)
3option(LINK_WITH_PTHREAD "Explicitly link Mbed TLS library to pthread." OFF)
4option(LINK_WITH_TRUSTED_STORAGE "Explicitly link Mbed TLS library to trusted_storage." OFF)
Paul Bakker9d3a7e42011-01-05 15:24:43 +00005
Ashley Duncand85a7e92019-04-29 20:35:06 +12006# Set the project root directory if it's not already defined, as may happen if
7# the library folder is included directly by a parent project, without
8# including the top level CMakeLists.txt.
9if(NOT DEFINED MBEDTLS_DIR)
10 set(MBEDTLS_DIR ${CMAKE_SOURCE_DIR})
11endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +000012
Ronald Cronc29afb62024-07-01 14:50:54 +020013set(TF_PSA_CRYPTO_CORE_DIR ../tf-psa-crypto/core)
14set(TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR ../tf-psa-crypto/drivers/builtin/src)
15
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020016set(src_crypto
Ronald Cronc29afb62024-07-01 14:50:54 +020017 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/aes.c
18 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/aesni.c
19 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/aesce.c
20 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/aria.c
21 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/asn1parse.c
22 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/asn1write.c
23 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/base64.c
24 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/bignum.c
25 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/bignum_core.c
26 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/bignum_mod.c
27 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/bignum_mod_raw.c
28 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/block_cipher.c
29 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/camellia.c
30 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ccm.c
31 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/chacha20.c
32 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/chachapoly.c
33 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/cipher.c
34 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/cipher_wrap.c
35 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/constant_time.c
36 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/cmac.c
37 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ctr_drbg.c
38 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/des.c
39 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/dhm.c
40 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecdh.c
41 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecdsa.c
42 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecjpake.c
43 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecp.c
44 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecp_curves.c
45 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ecp_curves_new.c
46 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/entropy.c
47 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/entropy_poll.c
48 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/error.c
49 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/gcm.c
50 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/hkdf.c
51 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/hmac_drbg.c
52 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/lmots.c
53 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/lms.c
54 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/md.c
55 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/md5.c
56 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/memory_buffer_alloc.c
57 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/nist_kw.c
58 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/oid.c
59 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pem.c
60 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pk.c
61 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pk_ecc.c
62 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pk_wrap.c
63 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pkcs12.c
64 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pkcs5.c
65 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pkparse.c
66 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/pkwrite.c
67 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/platform.c
68 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/platform_util.c
69 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/poly1305.c
70 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto.c
71 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_aead.c
72 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_cipher.c
73 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_client.c
74 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c
75 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_ecp.c
76 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_ffdh.c
77 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_hash.c
78 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_mac.c
79 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_pake.c
80 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_rsa.c
81 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_se.c
82 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_slot_management.c
83 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_storage.c
84 ${TF_PSA_CRYPTO_CORE_DIR}/psa_its_file.c
85 ${TF_PSA_CRYPTO_CORE_DIR}/psa_util.c
86 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/ripemd160.c
87 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/rsa.c
88 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/rsa_alt_helpers.c
89 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/sha1.c
90 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/sha256.c
91 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/sha512.c
92 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/sha3.c
93 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/threading.c
94 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/timing.c
95 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/version.c
96 ${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/version_features.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020097)
98
99set(src_x509
Daniel Axtensaa91d4e2020-05-29 00:23:21 +1000100 pkcs7.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200101 x509.c
102 x509_create.c
103 x509_crl.c
104 x509_crt.c
105 x509_csr.c
Andrzej Kurekc508dc22023-07-07 08:20:02 -0400106 x509write.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200107 x509write_crt.c
108 x509write_csr.c
109)
110
111set(src_tls
112 debug.c
Gilles Peskine89e31ad2022-11-26 14:18:45 +0100113 mps_reader.c
114 mps_trace.c
Andres AG788aa4a2016-09-14 14:32:09 +0100115 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200116 ssl_cache.c
117 ssl_ciphersuites.c
Ronald Cron3d580bf2022-02-18 17:24:56 +0100118 ssl_client.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200119 ssl_cookie.c
Gilles Peskine898db6b2022-11-26 14:15:32 +0100120 ssl_debug_helpers_generated.c
Hanno Becker6e7051a2020-02-05 11:33:54 +0000121 ssl_msg.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200122 ssl_ticket.c
Hanno Becker471c0c92020-02-05 11:32:03 +0000123 ssl_tls.c
Ronald Cronde1adee2022-03-07 16:20:30 +0100124 ssl_tls12_client.c
125 ssl_tls12_server.c
Hanno Beckerbe9d6642020-08-21 13:20:06 +0100126 ssl_tls13_keys.c
Jerry Yu3cc4c2a2021-08-06 16:29:08 +0800127 ssl_tls13_server.c
128 ssl_tls13_client.c
Jerry Yu65dd2cc2021-08-18 16:38:40 +0800129 ssl_tls13_generic.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200130)
131
David Horstmanna8d14062021-10-20 17:14:23 +0100132if(GEN_FILES)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200133 find_package(Perl REQUIRED)
Manuel Pégourié-Gonnardcbdedc52021-05-11 12:47:30 +0200134
Ronald Cron3d817ad2024-06-14 08:43:28 +0200135 file(GLOB crypto_error_headers ${CMAKE_CURRENT_SOURCE_DIR}/../tf-psa-crypto/drivers/builtin/include/mbedtls/*.h)
136 file(GLOB tls_error_headers ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls/*.h)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200137 add_custom_command(
138 OUTPUT
Ronald Cronc29afb62024-07-01 14:50:54 +0200139 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/error.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200140 COMMAND
141 ${PERL_EXECUTABLE}
142 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_errors.pl
Ronald Cron3d817ad2024-06-14 08:43:28 +0200143 ${CMAKE_CURRENT_SOURCE_DIR}/../tf-psa-crypto/drivers/builtin/include/mbedtls
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200144 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
145 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
Ronald Cronc29afb62024-07-01 14:50:54 +0200146 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/error.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200147 DEPENDS
148 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_errors.pl
Ronald Cron3d817ad2024-06-14 08:43:28 +0200149 ${crypto_error_headers}
150 ${tls_error_headers}
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200151 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/error.fmt
152 )
Manuel Pégourié-Gonnardcbdedc52021-05-11 12:47:30 +0200153
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200154 add_custom_command(
155 OUTPUT
Ronald Cronc29afb62024-07-01 14:50:54 +0200156 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/version_features.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200157 COMMAND
158 ${PERL_EXECUTABLE}
159 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
160 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
161 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
Ronald Cronc29afb62024-07-01 14:50:54 +0200162 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/version_features.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200163 DEPENDS
164 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
165 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls/mbedtls_config.h
166 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/version_features.fmt
167 )
Jerry Yueb96fb52021-12-02 11:03:59 +0800168
169 add_custom_command(
170 OUTPUT
171 ${CMAKE_CURRENT_BINARY_DIR}/ssl_debug_helpers_generated.c
172 COMMAND
173 ${MBEDTLS_PYTHON_EXECUTABLE}
174 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
Jerry Yue6369b02021-12-02 13:51:26 +0800175 --mbedtls-root ${CMAKE_CURRENT_SOURCE_DIR}/..
176 ${CMAKE_CURRENT_BINARY_DIR}
Jerry Yueb96fb52021-12-02 11:03:59 +0800177 DEPENDS
178 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
Ronald Cron3d817ad2024-06-14 08:43:28 +0200179 ${tls_error_headers}
Jerry Yueb96fb52021-12-02 11:03:59 +0800180 )
Archana6f21e452021-11-23 14:46:51 +0530181
182 add_custom_command(
183 OUTPUT
Ronald Cronc29afb62024-07-01 14:50:54 +0200184 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers.h
185 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c
Archana6f21e452021-11-23 14:46:51 +0530186 COMMAND
187 ${MBEDTLS_PYTHON_EXECUTABLE}
188 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Ronald Cronc29afb62024-07-01 14:50:54 +0200189 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}
Archana6f21e452021-11-23 14:46:51 +0530190 DEPENDS
191 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Xiaokang Qianfe9666b2023-09-11 10:36:20 +0000192 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/driver_templates/psa_crypto_driver_wrappers.h.jinja
193 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/driver_templates/psa_crypto_driver_wrappers_no_static.c.jinja
Archana6f21e452021-11-23 14:46:51 +0530194 )
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200195else()
Ronald Cronc29afb62024-07-01 14:50:54 +0200196 link_to_source(${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/error.c)
197 link_to_source(${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/version_features.c)
Jerry Yueb96fb52021-12-02 11:03:59 +0800198 link_to_source(ssl_debug_helpers_generated.c)
Ronald Cronc29afb62024-07-01 14:50:54 +0200199 link_to_source(${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers.h)
200 link_to_source(${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200201endif()
Manuel Pégourié-Gonnard65a72032021-05-11 13:02:44 +0200202
Paul Bakker76f03112013-11-28 17:20:04 +0100203if(CMAKE_COMPILER_IS_GNUCC)
Michael Schuster1da4ed12024-06-05 01:45:54 +0200204 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations")
Paul Bakker76f03112013-11-28 17:20:04 +0100205endif(CMAKE_COMPILER_IS_GNUCC)
206
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200207if(CMAKE_COMPILER_IS_CLANG)
Michael Schuster1da4ed12024-06-05 01:45:54 +0200208 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200209endif(CMAKE_COMPILER_IS_CLANG)
210
Krzysztof Stachowiakde6effa2018-10-31 12:46:37 +0100211if(CMAKE_COMPILER_IS_MSVC)
212 option(MSVC_STATIC_RUNTIME "Build the libraries with /MT compiler flag" OFF)
213 if(MSVC_STATIC_RUNTIME)
214 foreach(flag_var
215 CMAKE_C_FLAGS CMAKE_C_FLAGS_DEBUG CMAKE_C_FLAGS_RELEASE
216 CMAKE_C_FLAGS_MINSIZEREL CMAKE_C_FLAGS_RELWITHDEBINFO
217 CMAKE_C_FLAGS_CHECK)
218 string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
219 endforeach(flag_var)
220 endif()
221endif()
222
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200223if(WIN32)
Simon Butchere068aa72018-03-14 15:10:31 +0000224 set(libs ${libs} ws2_32 bcrypt)
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200225endif(WIN32)
226
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100227if(CMAKE_C_COMPILER_ID MATCHES "AppleClang")
228 set(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100229 set(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Steven WdV9f0858d2024-03-19 11:39:22 +0100230endif()
231if(CMAKE_CXX_COMPILER_ID MATCHES "AppleClang")
232 set(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100233 set(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100234endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200235
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400236if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100237 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400238endif(HAIKU)
239
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200240if(LINK_WITH_PTHREAD)
Paul Elliott7fd162e2024-01-24 18:05:53 +0000241 set(libs ${libs} ${CMAKE_THREAD_LIBS_INIT})
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200242endif()
243
Moshe Shahar7e367652019-07-15 15:50:19 +0300244if(LINK_WITH_TRUSTED_STORAGE)
245 set(libs ${libs} trusted_storage)
246endif()
247
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000248if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200249 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000250endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000251
Raef Coles995c66f2020-10-13 16:30:41 +0100252set(mbedtls_target "${MBEDTLS_TARGET_PREFIX}mbedtls")
253set(mbedx509_target "${MBEDTLS_TARGET_PREFIX}mbedx509")
254set(mbedcrypto_target "${MBEDTLS_TARGET_PREFIX}mbedcrypto")
255
256set(mbedtls_target ${mbedtls_target} PARENT_SCOPE)
257set(mbedx509_target ${mbedx509_target} PARENT_SCOPE)
258set(mbedcrypto_target ${mbedcrypto_target} PARENT_SCOPE)
259
260if (USE_STATIC_MBEDTLS_LIBRARY)
261 set(mbedtls_static_target ${mbedtls_target})
262 set(mbedx509_static_target ${mbedx509_target})
263 set(mbedcrypto_static_target ${mbedcrypto_target})
264endif()
265
266set(target_libraries ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200267
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000268if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100269 string(APPEND mbedtls_static_target "_static")
270 string(APPEND mbedx509_static_target "_static")
271 string(APPEND mbedcrypto_static_target "_static")
272
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200273 list(APPEND target_libraries
Raef Coles995c66f2020-10-13 16:30:41 +0100274 ${mbedcrypto_static_target}
275 ${mbedx509_static_target}
276 ${mbedtls_static_target})
hasufell3c6409b2014-03-06 15:49:08 +0100277endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000278
David Horstmannde527fb2023-09-28 17:52:52 +0100279set(p256m_target "${MBEDTLS_TARGET_PREFIX}p256m")
280set(everest_target "${MBEDTLS_TARGET_PREFIX}everest")
281
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000282if(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200283 add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
284 set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
Raef Coles4762edd2020-10-13 16:31:41 +0100285 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${libs})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200286
David Horstmannde527fb2023-09-28 17:52:52 +0100287 if(TARGET ${everest_target})
288 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${everest_target})
Chris Kayd259e342021-03-25 16:03:25 +0000289 endif()
290
David Horstmannde527fb2023-09-28 17:52:52 +0100291 if(TARGET ${p256m_target})
292 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${p256m_target})
Aditya Deshpande7b9934d2023-04-18 17:00:17 +0100293 endif()
294
Gilles Peskine55d53532020-03-09 17:48:13 +0100295 add_library(${mbedx509_static_target} STATIC ${src_x509})
296 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
Raef Coles4762edd2020-10-13 16:31:41 +0100297 target_link_libraries(${mbedx509_static_target} PUBLIC ${libs} ${mbedcrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200298
Gilles Peskine55d53532020-03-09 17:48:13 +0100299 add_library(${mbedtls_static_target} STATIC ${src_tls})
300 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
Raef Coles4762edd2020-10-13 16:31:41 +0100301 target_link_libraries(${mbedtls_static_target} PUBLIC ${libs} ${mbedx509_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200302endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000303
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000304if(USE_SHARED_MBEDTLS_LIBRARY)
Ron Eldor183264c2017-10-09 19:07:26 +0300305 set(CMAKE_LIBRARY_PATH ${CMAKE_CURRENT_BINARY_DIR})
Raef Coles995c66f2020-10-13 16:30:41 +0100306 add_library(${mbedcrypto_target} SHARED ${src_crypto})
Minos Galanakis4492dbd2024-03-21 15:52:49 +0000307 set_target_properties(${mbedcrypto_target} PROPERTIES VERSION 3.6.0 SOVERSION 16)
Raef Coles4762edd2020-10-13 16:31:41 +0100308 target_link_libraries(${mbedcrypto_target} PUBLIC ${libs})
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000309
David Horstmannde527fb2023-09-28 17:52:52 +0100310 if(TARGET ${everest_target})
311 target_link_libraries(${mbedcrypto_target} PUBLIC ${everest_target})
Chris Kayd259e342021-03-25 16:03:25 +0000312 endif()
313
David Horstmannde527fb2023-09-28 17:52:52 +0100314 if(TARGET ${p256m_target})
315 target_link_libraries(${mbedcrypto_target} PUBLIC ${p256m_target})
Aditya Deshpande7b9934d2023-04-18 17:00:17 +0100316 endif()
317
Raef Coles995c66f2020-10-13 16:30:41 +0100318 add_library(${mbedx509_target} SHARED ${src_x509})
Minos Galanakis4492dbd2024-03-21 15:52:49 +0000319 set_target_properties(${mbedx509_target} PROPERTIES VERSION 3.6.0 SOVERSION 7)
Raef Coles4762edd2020-10-13 16:31:41 +0100320 target_link_libraries(${mbedx509_target} PUBLIC ${libs} ${mbedcrypto_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200321
Raef Coles995c66f2020-10-13 16:30:41 +0100322 add_library(${mbedtls_target} SHARED ${src_tls})
Minos Galanakis4492dbd2024-03-21 15:52:49 +0000323 set_target_properties(${mbedtls_target} PROPERTIES VERSION 3.6.0 SOVERSION 21)
Raef Coles4762edd2020-10-13 16:31:41 +0100324 target_link_libraries(${mbedtls_target} PUBLIC ${libs} ${mbedx509_target})
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000325endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200326
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200327foreach(target IN LISTS target_libraries)
Robert Shade591e7292022-05-12 14:40:16 -0400328 add_library(MbedTLS::${target} ALIAS ${target}) # add_subdirectory support
Ronald Cronaef8cf32024-07-01 18:33:24 +0200329 # Include public header files from /include, /tf-psa-crypto/include/ and
330 # tf-psa-crypto/drivers/builtin/include/. Include private header files
331 # from /library, tf-psa-crypto/core/ and tf-psa-crypto/drivers/builtin/src/.
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200332 target_include_directories(${target}
Chris Kayd259e342021-03-25 16:03:25 +0000333 PUBLIC $<BUILD_INTERFACE:${MBEDTLS_DIR}/include/>
Ronald Cronc7e9e362024-06-10 09:41:49 +0200334 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/include/>
Ronald Cron3d817ad2024-06-14 08:43:28 +0200335 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/include/>
Chris Kayd259e342021-03-25 16:03:25 +0000336 $<INSTALL_INTERFACE:include/>
David Horstmannb7b4f232023-09-27 13:57:11 +0100337 PRIVATE ${MBEDTLS_DIR}/library/
Ronald Cronc29afb62024-07-01 14:50:54 +0200338 ${MBEDTLS_DIR}/tf-psa-crypto/core
339 ${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/src
David Horstmannb7b4f232023-09-27 13:57:11 +0100340 # Needed to include psa_crypto_driver_wrappers.h
Ronald Cronc29afb62024-07-01 14:50:54 +0200341 ${CMAKE_CURRENT_BINARY_DIR}/../tf-psa-crypto/core)
David Horstmann82f11ff2023-01-09 12:41:58 +0000342 # Pass-through MBEDTLS_CONFIG_FILE and MBEDTLS_USER_CONFIG_FILE
David Horstmann0f1dd572023-02-15 14:44:25 +0000343 if(MBEDTLS_CONFIG_FILE)
David Horstmann82f11ff2023-01-09 12:41:58 +0000344 target_compile_definitions(${target}
345 PUBLIC MBEDTLS_CONFIG_FILE="${MBEDTLS_CONFIG_FILE}")
346 endif()
David Horstmann0f1dd572023-02-15 14:44:25 +0000347 if(MBEDTLS_USER_CONFIG_FILE)
David Horstmann82f11ff2023-01-09 12:41:58 +0000348 target_compile_definitions(${target}
349 PUBLIC MBEDTLS_USER_CONFIG_FILE="${MBEDTLS_USER_CONFIG_FILE}")
350 endif()
Chris Kayd259e342021-03-25 16:03:25 +0000351 install(
352 TARGETS ${target}
353 EXPORT MbedTLSTargets
Biswapriyo Nathd7e0ee42022-04-22 20:59:50 +0530354 ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
355 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
356 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
Chris Kayd259e342021-03-25 16:03:25 +0000357 PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200358endforeach(target)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200359
Raef Coles995c66f2020-10-13 16:30:41 +0100360set(lib_target "${MBEDTLS_TARGET_PREFIX}lib")
361
362add_custom_target(${lib_target} DEPENDS ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine55d53532020-03-09 17:48:13 +0100363if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100364 add_dependencies(${lib_target} ${mbedcrypto_static_target} ${mbedx509_static_target} ${mbedtls_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200365endif()