blob: 063703bfe8c96add225c8248e82b98f1ed362509 [file] [log] [blame]
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +02001set(src_x509
Harry Ramsey798d8b62024-10-11 17:09:18 +01002 error.c
Gilles Peskine018e0982025-07-09 16:16:45 +02003 mbedtls_config.c
Daniel Axtensaa91d4e2020-05-29 00:23:21 +10004 pkcs7.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +02005 x509.c
6 x509_create.c
7 x509_crl.c
8 x509_crt.c
9 x509_csr.c
Gilles Peskined2fe51c2025-05-07 20:36:20 +020010 x509_oid.c
Andrzej Kurekc508dc22023-07-07 08:20:02 -040011 x509write.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020012 x509write_crt.c
13 x509write_csr.c
14)
15
16set(src_tls
17 debug.c
Gilles Peskine89e31ad2022-11-26 14:18:45 +010018 mps_reader.c
19 mps_trace.c
Andres AG788aa4a2016-09-14 14:32:09 +010020 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020021 ssl_cache.c
22 ssl_ciphersuites.c
Ronald Cron3d580bf2022-02-18 17:24:56 +010023 ssl_client.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020024 ssl_cookie.c
Gilles Peskine898db6b2022-11-26 14:15:32 +010025 ssl_debug_helpers_generated.c
Hanno Becker6e7051a2020-02-05 11:33:54 +000026 ssl_msg.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020027 ssl_ticket.c
Hanno Becker471c0c92020-02-05 11:32:03 +000028 ssl_tls.c
Ronald Cronde1adee2022-03-07 16:20:30 +010029 ssl_tls12_client.c
30 ssl_tls12_server.c
Hanno Beckerbe9d6642020-08-21 13:20:06 +010031 ssl_tls13_keys.c
Jerry Yu3cc4c2a2021-08-06 16:29:08 +080032 ssl_tls13_server.c
33 ssl_tls13_client.c
Jerry Yu65dd2cc2021-08-18 16:38:40 +080034 ssl_tls13_generic.c
Ronald Cron69245642024-11-12 18:14:23 +010035 timing.c
Harry Ramsey468c0ae2024-09-27 14:38:53 +010036 version.c
37 version_features.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020038)
39
David Horstmanna8d14062021-10-20 17:14:23 +010040if(GEN_FILES)
Harry Ramsey798d8b62024-10-11 17:09:18 +010041 find_package(Perl REQUIRED)
42
43 file(GLOB crypto_error_headers ${CMAKE_CURRENT_SOURCE_DIR}/include/mbedtls/*.h)
44 file(GLOB tls_error_headers ${MBEDTLS_DIR}/include/mbedtls/*.h)
45 add_custom_command(
46 OUTPUT
47 ${CMAKE_CURRENT_BINARY_DIR}/error.c
48 COMMAND
49 ${PERL_EXECUTABLE}
50 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_errors.pl
51 ${CMAKE_CURRENT_SOURCE_DIR}/../tf-psa-crypto/drivers/builtin/include/mbedtls
52 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
53 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
54 ${CMAKE_CURRENT_BINARY_DIR}/${TF_PSA_CRYPTO_DRIVERS_BUILTIN_SRC_DIR}/error.c
55 DEPENDS
56 ${MBEDTLS_DIR}/scripts/generate_errors.pl
57 ${crypto_error_headers}
58 ${tls_error_headers}
59 ${MBEDTLS_DIR}/scripts/data_files/error.fmt
60 )
Jerry Yueb96fb52021-12-02 11:03:59 +080061 add_custom_command(
62 OUTPUT
Harry Ramsey468c0ae2024-09-27 14:38:53 +010063 ${CMAKE_CURRENT_BINARY_DIR}/version_features.c
64 COMMAND
65 ${PERL_EXECUTABLE}
66 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
67 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
68 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
69 ${CMAKE_CURRENT_BINARY_DIR}/version_features.c
70 DEPENDS
71 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
72 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls/mbedtls_config.h
73 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/version_features.fmt
74 )
75
Gilles Peskineb53b4432025-07-31 21:50:35 +020076 execute_process(
77 COMMAND
78 ${MBEDTLS_PYTHON_EXECUTABLE}
79 ${MBEDTLS_DIR}/scripts/generate_config_checks.py
Gilles Peskine6712f1b2025-09-15 20:09:37 +020080 --list-for-cmake "${CMAKE_CURRENT_BINARY_DIR}"
Gilles Peskineb53b4432025-07-31 21:50:35 +020081 WORKING_DIRECTORY
82 ${CMAKE_CURRENT_SOURCE_DIR}/..
83 OUTPUT_VARIABLE
84 MBEDTLS_GENERATED_CONFIG_CHECKS_HEADERS)
Gilles Peskineb53b4432025-07-31 21:50:35 +020085
86 add_custom_command(
87 OUTPUT ${MBEDTLS_GENERATED_CONFIG_CHECKS_HEADERS}
88 COMMAND
89 ${MBEDTLS_PYTHON_EXECUTABLE}
90 ${MBEDTLS_DIR}/scripts/generate_config_checks.py
91 ${CMAKE_CURRENT_BINARY_DIR}
92 DEPENDS
93 ${MBEDTLS_DIR}/scripts/generate_config_checks.py
94 ${MBEDTLS_FRAMEWORK_DIR}/scripts/mbedtls_framework/config_checks_generator.py
95 )
96
Harry Ramsey468c0ae2024-09-27 14:38:53 +010097 add_custom_command(
98 OUTPUT
Jerry Yueb96fb52021-12-02 11:03:59 +080099 ${CMAKE_CURRENT_BINARY_DIR}/ssl_debug_helpers_generated.c
100 COMMAND
101 ${MBEDTLS_PYTHON_EXECUTABLE}
Elena Uziunaite09fee362024-10-07 17:40:21 +0100102 ${CMAKE_CURRENT_SOURCE_DIR}/../framework/scripts/generate_ssl_debug_helpers.py
Jerry Yue6369b02021-12-02 13:51:26 +0800103 --mbedtls-root ${CMAKE_CURRENT_SOURCE_DIR}/..
104 ${CMAKE_CURRENT_BINARY_DIR}
Jerry Yueb96fb52021-12-02 11:03:59 +0800105 DEPENDS
Elena Uziunaite09fee362024-10-07 17:40:21 +0100106 ${CMAKE_CURRENT_SOURCE_DIR}/../framework/scripts/generate_ssl_debug_helpers.py
Ronald Cron3d817ad2024-06-14 08:43:28 +0200107 ${tls_error_headers}
Jerry Yueb96fb52021-12-02 11:03:59 +0800108 )
Ronald Crona2c37b32025-05-14 09:41:04 +0200109
110 add_custom_target(${MBEDTLS_TARGET_PREFIX}mbedx509_generated_files_target
111 DEPENDS
112 ${CMAKE_CURRENT_BINARY_DIR}/error.c
Gilles Peskineb53b4432025-07-31 21:50:35 +0200113 ${MBEDTLS_GENERATED_CONFIG_CHECKS_HEADERS}
Ronald Crona2c37b32025-05-14 09:41:04 +0200114 )
115
116 add_custom_target(${MBEDTLS_TARGET_PREFIX}mbedtls_generated_files_target
117 DEPENDS
118 ${CMAKE_CURRENT_BINARY_DIR}/ssl_debug_helpers_generated.c
119 ${CMAKE_CURRENT_BINARY_DIR}/version_features.c
120 )
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200121endif()
Manuel Pégourié-Gonnard65a72032021-05-11 13:02:44 +0200122
Paul Bakker76f03112013-11-28 17:20:04 +0100123if(CMAKE_COMPILER_IS_GNUCC)
Ronald Cron50bd4f82024-10-10 12:17:59 +0200124 set(LIBS_C_FLAGS -Wmissing-declarations)
Paul Bakker76f03112013-11-28 17:20:04 +0100125endif(CMAKE_COMPILER_IS_GNUCC)
126
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200127if(CMAKE_COMPILER_IS_CLANG)
Ronald Cron50bd4f82024-10-10 12:17:59 +0200128 set(LIBS_C_FLAGS -Wmissing-declarations -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code)
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200129endif(CMAKE_COMPILER_IS_CLANG)
130
Krzysztof Stachowiakde6effa2018-10-31 12:46:37 +0100131if(CMAKE_COMPILER_IS_MSVC)
132 option(MSVC_STATIC_RUNTIME "Build the libraries with /MT compiler flag" OFF)
133 if(MSVC_STATIC_RUNTIME)
134 foreach(flag_var
135 CMAKE_C_FLAGS CMAKE_C_FLAGS_DEBUG CMAKE_C_FLAGS_RELEASE
136 CMAKE_C_FLAGS_MINSIZEREL CMAKE_C_FLAGS_RELWITHDEBINFO
137 CMAKE_C_FLAGS_CHECK)
138 string(REGEX REPLACE "/MD" "/MT" ${flag_var} "${${flag_var}}")
139 endforeach(flag_var)
140 endif()
141endif()
142
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100143if(CMAKE_C_COMPILER_ID MATCHES "AppleClang")
144 set(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100145 set(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Steven WdV9f0858d2024-03-19 11:39:22 +0100146endif()
147if(CMAKE_CXX_COMPILER_ID MATCHES "AppleClang")
148 set(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
Signed-off-by: Steven WdVbcfed502024-02-29 15:12:36 +0100149 set(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100150endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200151
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400152if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100153 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400154endif(HAIKU)
155
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200156if(LINK_WITH_PTHREAD)
Paul Elliott7fd162e2024-01-24 18:05:53 +0000157 set(libs ${libs} ${CMAKE_THREAD_LIBS_INIT})
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200158endif()
159
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000160if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200161 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000162endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000163
Raef Coles995c66f2020-10-13 16:30:41 +0100164set(mbedtls_target "${MBEDTLS_TARGET_PREFIX}mbedtls")
165set(mbedx509_target "${MBEDTLS_TARGET_PREFIX}mbedx509")
Raef Coles995c66f2020-10-13 16:30:41 +0100166
167set(mbedtls_target ${mbedtls_target} PARENT_SCOPE)
168set(mbedx509_target ${mbedx509_target} PARENT_SCOPE)
Raef Coles995c66f2020-10-13 16:30:41 +0100169
170if (USE_STATIC_MBEDTLS_LIBRARY)
Ronald Cronf8a3f282024-07-24 08:42:32 +0200171 set(mbedtls_static_target ${mbedtls_target})
172 set(mbedx509_static_target ${mbedx509_target})
Raef Coles995c66f2020-10-13 16:30:41 +0100173endif()
174
Ronald Crone82ad152024-07-19 12:01:43 +0200175set(target_libraries ${mbedx509_target} ${mbedtls_target})
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200176
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000177if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100178 string(APPEND mbedtls_static_target "_static")
179 string(APPEND mbedx509_static_target "_static")
Raef Coles995c66f2020-10-13 16:30:41 +0100180
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200181 list(APPEND target_libraries
Raef Coles995c66f2020-10-13 16:30:41 +0100182 ${mbedx509_static_target}
183 ${mbedtls_static_target})
hasufell3c6409b2014-03-06 15:49:08 +0100184endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000185
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000186if(USE_STATIC_MBEDTLS_LIBRARY)
Gilles Peskine55d53532020-03-09 17:48:13 +0100187 add_library(${mbedx509_static_target} STATIC ${src_x509})
Ronald Cronb2478982024-10-07 16:17:07 +0200188 set_base_compile_options(${mbedx509_static_target})
Ronald Cron50bd4f82024-10-10 12:17:59 +0200189 target_compile_options(${mbedx509_static_target} PRIVATE ${LIBS_C_FLAGS})
Gilles Peskine55d53532020-03-09 17:48:13 +0100190 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
Ronald Cronb7d0e522024-10-25 16:01:14 +0200191 target_link_libraries(${mbedx509_static_target} PUBLIC ${libs} ${tfpsacrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200192
Gilles Peskine55d53532020-03-09 17:48:13 +0100193 add_library(${mbedtls_static_target} STATIC ${src_tls})
Ronald Cronb2478982024-10-07 16:17:07 +0200194 set_base_compile_options(${mbedtls_static_target})
Ronald Cron50bd4f82024-10-10 12:17:59 +0200195 target_compile_options(${mbedtls_static_target} PRIVATE ${LIBS_C_FLAGS})
Gilles Peskine55d53532020-03-09 17:48:13 +0100196 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
Raef Coles4762edd2020-10-13 16:31:41 +0100197 target_link_libraries(${mbedtls_static_target} PUBLIC ${libs} ${mbedx509_static_target})
Ronald Crona2c37b32025-05-14 09:41:04 +0200198
199 if(GEN_FILES)
200 add_dependencies(${mbedx509_static_target}
201 ${MBEDTLS_TARGET_PREFIX}mbedx509_generated_files_target)
202 add_dependencies(${mbedtls_static_target}
203 ${MBEDTLS_TARGET_PREFIX}mbedtls_generated_files_target)
204 endif()
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200205endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000206
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000207if(USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100208 add_library(${mbedx509_target} SHARED ${src_x509})
Ronald Cronb2478982024-10-07 16:17:07 +0200209 set_base_compile_options(${mbedx509_target})
Ronald Cron50bd4f82024-10-10 12:17:59 +0200210 target_compile_options(${mbedx509_target} PRIVATE ${LIBS_C_FLAGS})
Minos Galanakis09dc57d2025-06-27 09:29:32 +0100211 set_target_properties(${mbedx509_target} PROPERTIES VERSION 4.0.0 SOVERSION 8)
Ronald Cronb7d0e522024-10-25 16:01:14 +0200212 target_link_libraries(${mbedx509_target} PUBLIC ${libs} ${tfpsacrypto_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200213
Raef Coles995c66f2020-10-13 16:30:41 +0100214 add_library(${mbedtls_target} SHARED ${src_tls})
Ronald Cronb2478982024-10-07 16:17:07 +0200215 set_base_compile_options(${mbedtls_target})
Ronald Cron50bd4f82024-10-10 12:17:59 +0200216 target_compile_options(${mbedtls_target} PRIVATE ${LIBS_C_FLAGS})
David Horstmann7ba04a22024-09-03 17:36:30 +0100217 set_target_properties(${mbedtls_target} PROPERTIES VERSION 4.0.0 SOVERSION 21)
Raef Coles4762edd2020-10-13 16:31:41 +0100218 target_link_libraries(${mbedtls_target} PUBLIC ${libs} ${mbedx509_target})
Ronald Crona2c37b32025-05-14 09:41:04 +0200219
220 if(GEN_FILES)
221 add_dependencies(${mbedx509_target}
222 ${MBEDTLS_TARGET_PREFIX}mbedx509_generated_files_target)
223 add_dependencies(${mbedtls_target}
224 ${MBEDTLS_TARGET_PREFIX}mbedtls_generated_files_target)
225 endif()
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000226endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200227
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200228foreach(target IN LISTS target_libraries)
Robert Shade591e7292022-05-12 14:40:16 -0400229 add_library(MbedTLS::${target} ALIAS ${target}) # add_subdirectory support
Ronald Cronaef8cf32024-07-01 18:33:24 +0200230 # Include public header files from /include, /tf-psa-crypto/include/ and
231 # tf-psa-crypto/drivers/builtin/include/. Include private header files
232 # from /library, tf-psa-crypto/core/ and tf-psa-crypto/drivers/builtin/src/.
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200233 target_include_directories(${target}
Chris Kayd259e342021-03-25 16:03:25 +0000234 PUBLIC $<BUILD_INTERFACE:${MBEDTLS_DIR}/include/>
Ronald Cronc7e9e362024-06-10 09:41:49 +0200235 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/include/>
Ronald Cron3d817ad2024-06-14 08:43:28 +0200236 $<BUILD_INTERFACE:${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/include/>
Chris Kayd259e342021-03-25 16:03:25 +0000237 $<INSTALL_INTERFACE:include/>
David Horstmannb7b4f232023-09-27 13:57:11 +0100238 PRIVATE ${MBEDTLS_DIR}/library/
Ronald Cronc29afb62024-07-01 14:50:54 +0200239 ${MBEDTLS_DIR}/tf-psa-crypto/core
Ronald Crone82ad152024-07-19 12:01:43 +0200240 ${MBEDTLS_DIR}/tf-psa-crypto/drivers/builtin/src)
Ronald Cron211bf6d2024-10-23 14:22:03 +0200241 set_config_files_compile_definitions(${target})
Chris Kayd259e342021-03-25 16:03:25 +0000242 install(
243 TARGETS ${target}
244 EXPORT MbedTLSTargets
Biswapriyo Nathd7e0ee42022-04-22 20:59:50 +0530245 ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
246 LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
247 RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
Chris Kayd259e342021-03-25 16:03:25 +0000248 PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200249endforeach(target)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200250
Raef Coles995c66f2020-10-13 16:30:41 +0100251set(lib_target "${MBEDTLS_TARGET_PREFIX}lib")
252
Ronald Crone82ad152024-07-19 12:01:43 +0200253add_custom_target(${lib_target} DEPENDS ${mbedx509_target} ${mbedtls_target})
Gilles Peskine55d53532020-03-09 17:48:13 +0100254if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Ronald Crone82ad152024-07-19 12:01:43 +0200255 add_dependencies(${lib_target} ${mbedx509_static_target} ${mbedtls_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200256endif()
Ronald Cron0381a982024-11-05 12:21:26 +0100257
258foreach(target IN LISTS tf_psa_crypto_library_targets)
259 get_target_property(target_type ${target} TYPE)
260 if (target_type STREQUAL STATIC_LIBRARY)
261 add_custom_command(
262 TARGET ${mbedtls_target}
263 POST_BUILD
264 COMMAND ${CMAKE_COMMAND}
265 ARGS -E copy $<TARGET_FILE:${target}> ${CMAKE_BINARY_DIR}/library)
266 else()
267 add_custom_command(
268 TARGET ${mbedtls_target}
269 POST_BUILD
270 COMMAND ${CMAKE_COMMAND}
271 ARGS -E copy $<TARGET_FILE:${target}>
272 ${CMAKE_BINARY_DIR}/library/$<TARGET_FILE_NAME:${target}>)
273 add_custom_command(
274 TARGET ${mbedtls_target}
275 POST_BUILD
276 COMMAND ${CMAKE_COMMAND}
277 ARGS -E copy $<TARGET_LINKER_FILE:${target}>
278 ${CMAKE_BINARY_DIR}/library/$<TARGET_LINKER_FILE_NAME:${target}>)
279 endif()
280endforeach(target)