blob: da635db8326928867a091f2477d67b8df20adc93 [file] [log] [blame]
Ashley Duncand85a7e92019-04-29 20:35:06 +12001# Set the project root directory if it's not already defined, as may happen if
2# the library folder is included directly by a parent project, without
3# including the top level CMakeLists.txt.
4if(NOT DEFINED MBEDTLS_DIR)
5 set(MBEDTLS_DIR ${CMAKE_SOURCE_DIR})
6endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +00007
Ronald Cronc29afb62024-07-01 14:50:54 +02008set(TF_PSA_CRYPTO_CORE_DIR ../tf-psa-crypto/core)
Ronald Cronc29afb62024-07-01 14:50:54 +02009
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020010set(src_crypto
Ronald Cronc29afb62024-07-01 14:50:54 +020011 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto.c
12 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_aead.c
13 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_cipher.c
14 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_client.c
15 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c
16 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_ecp.c
17 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_ffdh.c
18 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_hash.c
19 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_mac.c
20 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_pake.c
21 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_rsa.c
22 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_se.c
23 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_slot_management.c
24 ${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_storage.c
25 ${TF_PSA_CRYPTO_CORE_DIR}/psa_its_file.c
26 ${TF_PSA_CRYPTO_CORE_DIR}/psa_util.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020027)
28
29set(src_x509
Daniel Axtensaa91d4e2020-05-29 00:23:21 +100030 pkcs7.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020031 x509.c
32 x509_create.c
33 x509_crl.c
34 x509_crt.c
35 x509_csr.c
Andrzej Kurekc508dc22023-07-07 08:20:02 -040036 x509write.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020037 x509write_crt.c
38 x509write_csr.c
39)
40
41set(src_tls
42 debug.c
Gilles Peskine89e31ad2022-11-26 14:18:45 +010043 mps_reader.c
44 mps_trace.c
Andres AG788aa4a2016-09-14 14:32:09 +010045 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020046 ssl_cache.c
47 ssl_ciphersuites.c
Ronald Cron3d580bf2022-02-18 17:24:56 +010048 ssl_client.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020049 ssl_cookie.c
Gilles Peskine898db6b2022-11-26 14:15:32 +010050 ssl_debug_helpers_generated.c
Hanno Becker6e7051a2020-02-05 11:33:54 +000051 ssl_msg.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020052 ssl_ticket.c
Hanno Becker471c0c92020-02-05 11:32:03 +000053 ssl_tls.c
Ronald Cronde1adee2022-03-07 16:20:30 +010054 ssl_tls12_client.c
55 ssl_tls12_server.c
Hanno Beckerbe9d6642020-08-21 13:20:06 +010056 ssl_tls13_keys.c
Jerry Yu3cc4c2a2021-08-06 16:29:08 +080057 ssl_tls13_server.c
58 ssl_tls13_client.c
Jerry Yu65dd2cc2021-08-18 16:38:40 +080059 ssl_tls13_generic.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020060)
61
David Horstmanna8d14062021-10-20 17:14:23 +010062if(GEN_FILES)
Jerry Yueb96fb52021-12-02 11:03:59 +080063 add_custom_command(
64 OUTPUT
65 ${CMAKE_CURRENT_BINARY_DIR}/ssl_debug_helpers_generated.c
66 COMMAND
67 ${MBEDTLS_PYTHON_EXECUTABLE}
68 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
Jerry Yue6369b02021-12-02 13:51:26 +080069 --mbedtls-root ${CMAKE_CURRENT_SOURCE_DIR}/..
70 ${CMAKE_CURRENT_BINARY_DIR}
Jerry Yueb96fb52021-12-02 11:03:59 +080071 DEPENDS
72 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
Ronald Cron3d817ad2024-06-14 08:43:28 +020073 ${tls_error_headers}
Jerry Yueb96fb52021-12-02 11:03:59 +080074 )
Archana6f21e452021-11-23 14:46:51 +053075
76 add_custom_command(
77 OUTPUT
Ronald Cronc29afb62024-07-01 14:50:54 +020078 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers.h
79 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c
Archana6f21e452021-11-23 14:46:51 +053080 COMMAND
81 ${MBEDTLS_PYTHON_EXECUTABLE}
82 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Ronald Cronc29afb62024-07-01 14:50:54 +020083 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_CORE_DIR}
Archana6f21e452021-11-23 14:46:51 +053084 DEPENDS
85 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Xiaokang Qianfe9666b2023-09-11 10:36:20 +000086 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/driver_templates/psa_crypto_driver_wrappers.h.jinja
87 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/driver_templates/psa_crypto_driver_wrappers_no_static.c.jinja
Archana6f21e452021-11-23 14:46:51 +053088 )
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020089else()
Jerry Yueb96fb52021-12-02 11:03:59 +080090 link_to_source(ssl_debug_helpers_generated.c)
Ronald Cronc29afb62024-07-01 14:50:54 +020091 link_to_source(${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers.h)
92 link_to_source(${TF_PSA_CRYPTO_CORE_DIR}/psa_crypto_driver_wrappers_no_static.c)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +020093endif()
Manuel Pégourié-Gonnard65a72032021-05-11 13:02:44 +020094
Paul Bakker76f03112013-11-28 17:20:04 +010095if(CMAKE_COMPILER_IS_GNUCC)
Michael Schuster1da4ed12024-06-05 01:45:54 +020096 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations")
Paul Bakker76f03112013-11-28 17:20:04 +010097endif(CMAKE_COMPILER_IS_GNUCC)
98
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +020099if(CMAKE_COMPILER_IS_CLANG)
Michael Schuster1da4ed12024-06-05 01:45:54 +0200100 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 +0200101endif(CMAKE_COMPILER_IS_CLANG)
102
Krzysztof Stachowiakde6effa2018-10-31 12:46:37 +0100103if(CMAKE_COMPILER_IS_MSVC)
104 option(MSVC_STATIC_RUNTIME "Build the libraries with /MT compiler flag" OFF)
105 if(MSVC_STATIC_RUNTIME)
106 foreach(flag_var
107 CMAKE_C_FLAGS CMAKE_C_FLAGS_DEBUG CMAKE_C_FLAGS_RELEASE
108 CMAKE_C_FLAGS_MINSIZEREL CMAKE_C_FLAGS_RELWITHDEBINFO
109 CMAKE_C_FLAGS_CHECK)
110 string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
111 endforeach(flag_var)
112 endif()
113endif()
114
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100115if(CMAKE_C_COMPILER_ID MATCHES "AppleClang")
116 set(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100117 set(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Steven WdV9f0858d2024-03-19 11:39:22 +0100118endif()
119if(CMAKE_CXX_COMPILER_ID MATCHES "AppleClang")
120 set(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100121 set(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100122endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200123
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400124if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100125 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400126endif(HAIKU)
127
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200128if(LINK_WITH_PTHREAD)
Paul Elliott7fd162e2024-01-24 18:05:53 +0000129 set(libs ${libs} ${CMAKE_THREAD_LIBS_INIT})
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200130endif()
131
Moshe Shahar7e367652019-07-15 15:50:19 +0300132if(LINK_WITH_TRUSTED_STORAGE)
133 set(libs ${libs} trusted_storage)
134endif()
135
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000136if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200137 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000138endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000139
Raef Coles995c66f2020-10-13 16:30:41 +0100140set(mbedtls_target "${MBEDTLS_TARGET_PREFIX}mbedtls")
141set(mbedx509_target "${MBEDTLS_TARGET_PREFIX}mbedx509")
Raef Coles995c66f2020-10-13 16:30:41 +0100142
143set(mbedtls_target ${mbedtls_target} PARENT_SCOPE)
144set(mbedx509_target ${mbedx509_target} PARENT_SCOPE)
Raef Coles995c66f2020-10-13 16:30:41 +0100145
146if (USE_STATIC_MBEDTLS_LIBRARY)
Ronald Cronf8a3f282024-07-24 08:42:32 +0200147 set(mbedtls_static_target ${mbedtls_target})
148 set(mbedx509_static_target ${mbedx509_target})
Raef Coles995c66f2020-10-13 16:30:41 +0100149endif()
150
151set(target_libraries ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200152
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000153if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100154 string(APPEND mbedtls_static_target "_static")
155 string(APPEND mbedx509_static_target "_static")
Raef Coles995c66f2020-10-13 16:30:41 +0100156
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200157 list(APPEND target_libraries
Raef Coles995c66f2020-10-13 16:30:41 +0100158 ${mbedcrypto_static_target}
159 ${mbedx509_static_target}
160 ${mbedtls_static_target})
hasufell3c6409b2014-03-06 15:49:08 +0100161endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000162
David Horstmannde527fb2023-09-28 17:52:52 +0100163set(p256m_target "${MBEDTLS_TARGET_PREFIX}p256m")
164set(everest_target "${MBEDTLS_TARGET_PREFIX}everest")
165
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000166if(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200167 add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
168 set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
Raef Coles4762edd2020-10-13 16:31:41 +0100169 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${libs})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200170
Ronald Cronac01d6e2024-07-18 11:34:55 +0200171 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${builtin_static_target})
172
David Horstmannde527fb2023-09-28 17:52:52 +0100173 if(TARGET ${everest_target})
174 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${everest_target})
Chris Kayd259e342021-03-25 16:03:25 +0000175 endif()
176
David Horstmannde527fb2023-09-28 17:52:52 +0100177 if(TARGET ${p256m_target})
178 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${p256m_target})
Aditya Deshpande7b9934d2023-04-18 17:00:17 +0100179 endif()
180
Gilles Peskine55d53532020-03-09 17:48:13 +0100181 add_library(${mbedx509_static_target} STATIC ${src_x509})
182 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
Raef Coles4762edd2020-10-13 16:31:41 +0100183 target_link_libraries(${mbedx509_static_target} PUBLIC ${libs} ${mbedcrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200184
Gilles Peskine55d53532020-03-09 17:48:13 +0100185 add_library(${mbedtls_static_target} STATIC ${src_tls})
186 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
Raef Coles4762edd2020-10-13 16:31:41 +0100187 target_link_libraries(${mbedtls_static_target} PUBLIC ${libs} ${mbedx509_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200188endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000189
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000190if(USE_SHARED_MBEDTLS_LIBRARY)
Ron Eldor183264c2017-10-09 19:07:26 +0300191 set(CMAKE_LIBRARY_PATH ${CMAKE_CURRENT_BINARY_DIR})
Raef Coles995c66f2020-10-13 16:30:41 +0100192 add_library(${mbedcrypto_target} SHARED ${src_crypto})
David Horstmann7ba04a22024-09-03 17:36:30 +0100193 set_target_properties(${mbedcrypto_target} PROPERTIES VERSION 4.0.0 SOVERSION 16)
Raef Coles4762edd2020-10-13 16:31:41 +0100194 target_link_libraries(${mbedcrypto_target} PUBLIC ${libs})
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000195
Ronald Cronac01d6e2024-07-18 11:34:55 +0200196 target_link_libraries(${mbedcrypto_target} PUBLIC ${builtin_target})
197
David Horstmannde527fb2023-09-28 17:52:52 +0100198 if(TARGET ${everest_target})
199 target_link_libraries(${mbedcrypto_target} PUBLIC ${everest_target})
Chris Kayd259e342021-03-25 16:03:25 +0000200 endif()
201
David Horstmannde527fb2023-09-28 17:52:52 +0100202 if(TARGET ${p256m_target})
203 target_link_libraries(${mbedcrypto_target} PUBLIC ${p256m_target})
Aditya Deshpande7b9934d2023-04-18 17:00:17 +0100204 endif()
205
Raef Coles995c66f2020-10-13 16:30:41 +0100206 add_library(${mbedx509_target} SHARED ${src_x509})
David Horstmann7ba04a22024-09-03 17:36:30 +0100207 set_target_properties(${mbedx509_target} PROPERTIES VERSION 4.0.0 SOVERSION 7)
Raef Coles4762edd2020-10-13 16:31:41 +0100208 target_link_libraries(${mbedx509_target} PUBLIC ${libs} ${mbedcrypto_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200209
Raef Coles995c66f2020-10-13 16:30:41 +0100210 add_library(${mbedtls_target} SHARED ${src_tls})
David Horstmann7ba04a22024-09-03 17:36:30 +0100211 set_target_properties(${mbedtls_target} PROPERTIES VERSION 4.0.0 SOVERSION 21)
Raef Coles4762edd2020-10-13 16:31:41 +0100212 target_link_libraries(${mbedtls_target} PUBLIC ${libs} ${mbedx509_target})
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000213endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200214
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200215foreach(target IN LISTS target_libraries)
Robert Shade591e7292022-05-12 14:40:16 -0400216 add_library(MbedTLS::${target} ALIAS ${target}) # add_subdirectory support
Ronald Cronaef8cf32024-07-01 18:33:24 +0200217 # Include public header files from /include, /tf-psa-crypto/include/ and
218 # tf-psa-crypto/drivers/builtin/include/. Include private header files
219 # from /library, tf-psa-crypto/core/ and tf-psa-crypto/drivers/builtin/src/.
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200220 target_include_directories(${target}
Chris Kayd259e342021-03-25 16:03:25 +0000221 PUBLIC $<BUILD_INTERFACE:${MBEDTLS_DIR}/include/>
Ronald Cronc7e9e362024-06-10 09:41:49 +0200222 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/include/>
Ronald Cron3d817ad2024-06-14 08:43:28 +0200223 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/include/>
Chris Kayd259e342021-03-25 16:03:25 +0000224 $<INSTALL_INTERFACE:include/>
David Horstmannb7b4f232023-09-27 13:57:11 +0100225 PRIVATE ${MBEDTLS_DIR}/library/
Ronald Cronc29afb62024-07-01 14:50:54 +0200226 ${MBEDTLS_DIR}/tf-psa-crypto/core
227 ${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/src
David Horstmannb7b4f232023-09-27 13:57:11 +0100228 # Needed to include psa_crypto_driver_wrappers.h
Ronald Cronc29afb62024-07-01 14:50:54 +0200229 ${CMAKE_CURRENT_BINARY_DIR}/../tf-psa-crypto/core)
David Horstmann82f11ff2023-01-09 12:41:58 +0000230 # Pass-through MBEDTLS_CONFIG_FILE and MBEDTLS_USER_CONFIG_FILE
David Horstmann0f1dd572023-02-15 14:44:25 +0000231 if(MBEDTLS_CONFIG_FILE)
David Horstmann82f11ff2023-01-09 12:41:58 +0000232 target_compile_definitions(${target}
233 PUBLIC MBEDTLS_CONFIG_FILE="${MBEDTLS_CONFIG_FILE}")
234 endif()
David Horstmann0f1dd572023-02-15 14:44:25 +0000235 if(MBEDTLS_USER_CONFIG_FILE)
David Horstmann82f11ff2023-01-09 12:41:58 +0000236 target_compile_definitions(${target}
237 PUBLIC MBEDTLS_USER_CONFIG_FILE="${MBEDTLS_USER_CONFIG_FILE}")
238 endif()
Chris Kayd259e342021-03-25 16:03:25 +0000239 install(
240 TARGETS ${target}
241 EXPORT MbedTLSTargets
Biswapriyo Nathd7e0ee42022-04-22 20:59:50 +0530242 ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
243 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
244 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
Chris Kayd259e342021-03-25 16:03:25 +0000245 PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200246endforeach(target)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200247
Raef Coles995c66f2020-10-13 16:30:41 +0100248set(lib_target "${MBEDTLS_TARGET_PREFIX}lib")
249
250add_custom_target(${lib_target} DEPENDS ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine55d53532020-03-09 17:48:13 +0100251if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100252 add_dependencies(${lib_target} ${mbedcrypto_static_target} ${mbedx509_static_target} ${mbedtls_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200253endif()