blob: 6c3d7fdb49dc63276499bd9c4648463c4c6839a7 [file] [log] [blame]
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +00001option(USE_STATIC_MBEDTLS_LIBRARY "Build mbed TLS static library." ON)
2option(USE_SHARED_MBEDTLS_LIBRARY "Build mbed TLS shared library." OFF)
Manuel Pégourié-Gonnardcfa9a452015-01-23 13:33:31 +00003option(LINK_WITH_PTHREAD "Explicitly link mbed TLS library to pthread." OFF)
Moshe Shahar6763fe42019-07-24 14:19:35 +03004option(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
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020013set(src_crypto
14 aes.c
15 aesni.c
Markku-Juhani O. Saarinen3c0b53b2017-11-30 16:00:34 +000016 aria.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020017 asn1parse.c
18 asn1write.c
19 base64.c
20 bignum.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020021 camellia.c
22 ccm.c
Daniel King34b822c2016-05-15 17:28:08 -030023 chacha20.c
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020024 chachapoly.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020025 cipher.c
26 cipher_wrap.c
gabor-mezei-armd1125342021-07-12 16:31:22 +020027 constant_time.c
Robert Cragiedc5c7b92015-12-11 15:49:45 +000028 cmac.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020029 ctr_drbg.c
30 des.c
31 dhm.c
32 ecdh.c
33 ecdsa.c
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +020034 ecjpake.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020035 ecp.c
36 ecp_curves.c
37 entropy.c
38 entropy_poll.c
39 error.c
40 gcm.c
Thomas Fossati656864b2016-07-17 08:51:22 +010041 hkdf.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020042 hmac_drbg.c
43 md.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020044 md5.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020045 memory_buffer_alloc.c
Hanno Beckerc518c3b2021-01-28 07:08:08 +000046 mps_reader.c
47 mps_trace.c
Ron Eldorcb349ac2018-07-15 09:29:47 +030048 nist_kw.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020049 oid.c
50 padlock.c
51 pem.c
52 pk.c
53 pk_wrap.c
54 pkcs12.c
55 pkcs5.c
56 pkparse.c
57 pkwrite.c
58 platform.c
Andres Amaya Garciabc7bdbf2018-04-24 08:29:20 -050059 platform_util.c
Daniel Kingadc32c02016-05-16 18:25:45 -030060 poly1305.c
Gilles Peskinee59236f2018-01-27 23:32:46 +010061 psa_crypto.c
Ronald Cron7ceee8d2021-03-17 16:55:43 +010062 psa_crypto_aead.c
Ronald Cron0ff57952021-03-08 16:46:35 +010063 psa_crypto_cipher.c
Ronald Crond7906322021-01-28 16:07:56 +010064 psa_crypto_client.c
Steven Cooremancd84cb42020-07-16 20:28:36 +020065 psa_crypto_driver_wrappers.c
Ronald Cron00b7bfc2020-11-25 15:25:26 +010066 psa_crypto_ecp.c
Steven Cooreman0e307642021-02-18 16:18:32 +010067 psa_crypto_hash.c
Steven Cooremand13a70f2021-03-19 15:24:23 +010068 psa_crypto_mac.c
Ronald Cron00b7bfc2020-11-25 15:25:26 +010069 psa_crypto_rsa.c
Gilles Peskinea899a722019-06-24 14:06:43 +020070 psa_crypto_se.c
Gilles Peskine961849f2018-11-30 18:54:54 +010071 psa_crypto_slot_management.c
Darryl Greendb2b8db2018-06-15 13:06:04 +010072 psa_crypto_storage.c
Gilles Peskine6194dc22018-11-16 22:24:15 +010073 psa_its_file.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020074 ripemd160.c
75 rsa.c
Chris Jones66a4cd42021-03-09 16:04:12 +000076 rsa_alt_helpers.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020077 sha1.c
78 sha256.c
79 sha512.c
Jerry Yue78ee992021-09-22 15:42:14 +080080 ssl_debug_helpers_generated.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020081 threading.c
Manuel Pégourié-Gonnard21dcc1e2015-06-25 10:59:15 +020082 timing.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020083 version.c
84 version_features.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020085)
86
87set(src_x509
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020088 x509.c
89 x509_create.c
90 x509_crl.c
91 x509_crt.c
92 x509_csr.c
93 x509write_crt.c
94 x509write_csr.c
95)
96
97set(src_tls
98 debug.c
Andres AG788aa4a2016-09-14 14:32:09 +010099 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200100 ssl_cache.c
101 ssl_ciphersuites.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200102 ssl_cookie.c
Hanno Becker6e7051a2020-02-05 11:33:54 +0000103 ssl_msg.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200104 ssl_ticket.c
Hanno Becker471c0c92020-02-05 11:32:03 +0000105 ssl_tls.c
Ronald Cronde1adee2022-03-07 16:20:30 +0100106 ssl_tls12_client.c
107 ssl_tls12_server.c
Hanno Beckerbe9d6642020-08-21 13:20:06 +0100108 ssl_tls13_keys.c
Jerry Yu3cc4c2a2021-08-06 16:29:08 +0800109 ssl_tls13_server.c
110 ssl_tls13_client.c
Jerry Yu65dd2cc2021-08-18 16:38:40 +0800111 ssl_tls13_generic.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200112)
113
David Horstmanna8d14062021-10-20 17:14:23 +0100114if(GEN_FILES)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200115 find_package(Perl REQUIRED)
Manuel Pégourié-Gonnardcbdedc52021-05-11 12:47:30 +0200116
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200117 file(GLOB error_headers ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls/*.h)
118 add_custom_command(
119 OUTPUT
Manuel Pégourié-Gonnardcbdedc52021-05-11 12:47:30 +0200120 ${CMAKE_CURRENT_BINARY_DIR}/error.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200121 COMMAND
122 ${PERL_EXECUTABLE}
123 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_errors.pl
124 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
125 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
126 ${CMAKE_CURRENT_BINARY_DIR}/error.c
127 DEPENDS
128 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_errors.pl
129 ${error_headers}
130 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/error.fmt
131 )
Manuel Pégourié-Gonnardcbdedc52021-05-11 12:47:30 +0200132
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200133 add_custom_command(
134 OUTPUT
Manuel Pégourié-Gonnard65a72032021-05-11 13:02:44 +0200135 ${CMAKE_CURRENT_BINARY_DIR}/version_features.c
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200136 COMMAND
137 ${PERL_EXECUTABLE}
138 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
139 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls
140 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files
141 ${CMAKE_CURRENT_BINARY_DIR}/version_features.c
142 DEPENDS
143 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_features.pl
144 ${CMAKE_CURRENT_SOURCE_DIR}/../include/mbedtls/mbedtls_config.h
145 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/version_features.fmt
146 )
Jerry Yueb96fb52021-12-02 11:03:59 +0800147
148 add_custom_command(
149 OUTPUT
150 ${CMAKE_CURRENT_BINARY_DIR}/ssl_debug_helpers_generated.c
151 COMMAND
152 ${MBEDTLS_PYTHON_EXECUTABLE}
153 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
Jerry Yue6369b02021-12-02 13:51:26 +0800154 --mbedtls-root ${CMAKE_CURRENT_SOURCE_DIR}/..
155 ${CMAKE_CURRENT_BINARY_DIR}
Jerry Yueb96fb52021-12-02 11:03:59 +0800156 DEPENDS
157 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_ssl_debug_helpers.py
158 ${error_headers}
159 )
Archana6f21e452021-11-23 14:46:51 +0530160
161 add_custom_command(
162 OUTPUT
163 ${CMAKE_CURRENT_BINARY_DIR}/psa_crypto_driver_wrappers.c
164 COMMAND
165 ${MBEDTLS_PYTHON_EXECUTABLE}
166 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Archanae03960e2021-12-19 09:17:04 +0530167 ${CMAKE_CURRENT_BINARY_DIR}
Archana6f21e452021-11-23 14:46:51 +0530168 DEPENDS
169 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/generate_driver_wrappers.py
Archanac08248d2021-12-19 09:28:39 +0530170 ${CMAKE_CURRENT_SOURCE_DIR}/../scripts/data_files/driver_templates/psa_crypto_driver_wrappers.c.jinja
Archana6f21e452021-11-23 14:46:51 +0530171 )
172
173
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200174else()
175 link_to_source(error.c)
176 link_to_source(version_features.c)
Jerry Yueb96fb52021-12-02 11:03:59 +0800177 link_to_source(ssl_debug_helpers_generated.c)
Archana6f21e452021-11-23 14:46:51 +0530178 link_to_source(psa_crypto_driver_wrappers.c)
Manuel Pégourié-Gonnarde90e4052021-09-08 13:27:09 +0200179endif()
Manuel Pégourié-Gonnard65a72032021-05-11 13:02:44 +0200180
Paul Bakker76f03112013-11-28 17:20:04 +0100181if(CMAKE_COMPILER_IS_GNUCC)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200182 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes")
Paul Bakker76f03112013-11-28 17:20:04 +0100183endif(CMAKE_COMPILER_IS_GNUCC)
184
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200185if(CMAKE_COMPILER_IS_CLANG)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200186 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200187endif(CMAKE_COMPILER_IS_CLANG)
188
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200189if(WIN32)
190 set(libs ${libs} ws2_32)
191endif(WIN32)
192
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100193if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
TabascoEye7f3ef272018-04-27 13:14:59 +0200194 SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
195 SET(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
196 SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
197 SET(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100198endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200199
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400200if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100201 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400202endif(HAIKU)
203
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200204if(LINK_WITH_PTHREAD)
205 set(libs ${libs} pthread)
206endif()
207
Moshe Shahar7e367652019-07-15 15:50:19 +0300208if(LINK_WITH_TRUSTED_STORAGE)
209 set(libs ${libs} trusted_storage)
210endif()
211
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000212if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200213 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000214endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000215
Raef Coles995c66f2020-10-13 16:30:41 +0100216set(mbedtls_target "${MBEDTLS_TARGET_PREFIX}mbedtls")
217set(mbedx509_target "${MBEDTLS_TARGET_PREFIX}mbedx509")
218set(mbedcrypto_target "${MBEDTLS_TARGET_PREFIX}mbedcrypto")
219
220set(mbedtls_target ${mbedtls_target} PARENT_SCOPE)
221set(mbedx509_target ${mbedx509_target} PARENT_SCOPE)
222set(mbedcrypto_target ${mbedcrypto_target} PARENT_SCOPE)
223
224if (USE_STATIC_MBEDTLS_LIBRARY)
225 set(mbedtls_static_target ${mbedtls_target})
226 set(mbedx509_static_target ${mbedx509_target})
227 set(mbedcrypto_static_target ${mbedcrypto_target})
228endif()
229
230set(target_libraries ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200231
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000232if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100233 string(APPEND mbedtls_static_target "_static")
234 string(APPEND mbedx509_static_target "_static")
235 string(APPEND mbedcrypto_static_target "_static")
236
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200237 list(APPEND target_libraries
Raef Coles995c66f2020-10-13 16:30:41 +0100238 ${mbedcrypto_static_target}
239 ${mbedx509_static_target}
240 ${mbedtls_static_target})
hasufell3c6409b2014-03-06 15:49:08 +0100241endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000242
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000243if(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200244 add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
245 set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
Raef Coles4762edd2020-10-13 16:31:41 +0100246 target_link_libraries(${mbedcrypto_static_target} PUBLIC ${libs})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200247
Chris Kayd259e342021-03-25 16:03:25 +0000248 if(TARGET everest)
249 target_link_libraries(${mbedcrypto_static_target} PUBLIC everest)
250 endif()
251
Gilles Peskine55d53532020-03-09 17:48:13 +0100252 add_library(${mbedx509_static_target} STATIC ${src_x509})
253 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
Raef Coles4762edd2020-10-13 16:31:41 +0100254 target_link_libraries(${mbedx509_static_target} PUBLIC ${libs} ${mbedcrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200255
Gilles Peskine55d53532020-03-09 17:48:13 +0100256 add_library(${mbedtls_static_target} STATIC ${src_tls})
257 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
Raef Coles4762edd2020-10-13 16:31:41 +0100258 target_link_libraries(${mbedtls_static_target} PUBLIC ${libs} ${mbedx509_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200259endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000260
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000261if(USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100262 add_library(${mbedcrypto_target} SHARED ${src_crypto})
Ronald Cron17b1e2f2021-12-14 16:16:59 +0100263 set_target_properties(${mbedcrypto_target} PROPERTIES VERSION 3.1.0 SOVERSION 11)
Raef Coles4762edd2020-10-13 16:31:41 +0100264 target_link_libraries(${mbedcrypto_target} PUBLIC ${libs})
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000265
Chris Kayd259e342021-03-25 16:03:25 +0000266 if(TARGET everest)
267 target_link_libraries(${mbedcrypto_target} PUBLIC everest)
268 endif()
269
Raef Coles995c66f2020-10-13 16:30:41 +0100270 add_library(${mbedx509_target} SHARED ${src_x509})
Ronald Cron17b1e2f2021-12-14 16:16:59 +0100271 set_target_properties(${mbedx509_target} PROPERTIES VERSION 3.1.0 SOVERSION 4)
Raef Coles4762edd2020-10-13 16:31:41 +0100272 target_link_libraries(${mbedx509_target} PUBLIC ${libs} ${mbedcrypto_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200273
Raef Coles995c66f2020-10-13 16:30:41 +0100274 add_library(${mbedtls_target} SHARED ${src_tls})
Ronald Cron17b1e2f2021-12-14 16:16:59 +0100275 set_target_properties(${mbedtls_target} PROPERTIES VERSION 3.1.0 SOVERSION 17)
Raef Coles4762edd2020-10-13 16:31:41 +0100276 target_link_libraries(${mbedtls_target} PUBLIC ${libs} ${mbedx509_target})
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000277endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200278
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200279foreach(target IN LISTS target_libraries)
Gilles Peskine76dd3aa2020-07-02 15:58:37 +0200280 # Include public header files from /include and other directories
281 # declared by /3rdparty/**/CMakeLists.txt. Include private header files
282 # from /library and others declared by /3rdparty/**/CMakeLists.txt.
283 # /library needs to be listed explicitly when building .c files outside
284 # of /library (which currently means: under /3rdparty).
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200285 target_include_directories(${target}
Chris Kayd259e342021-03-25 16:03:25 +0000286 PUBLIC $<BUILD_INTERFACE:${MBEDTLS_DIR}/include/>
287 $<INSTALL_INTERFACE:include/>
288 PRIVATE ${MBEDTLS_DIR}/library/)
289 install(
290 TARGETS ${target}
291 EXPORT MbedTLSTargets
292 DESTINATION ${LIB_INSTALL_DIR}
293 PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200294endforeach(target)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200295
Raef Coles995c66f2020-10-13 16:30:41 +0100296set(lib_target "${MBEDTLS_TARGET_PREFIX}lib")
297
298add_custom_target(${lib_target} DEPENDS ${mbedcrypto_target} ${mbedx509_target} ${mbedtls_target})
Gilles Peskine55d53532020-03-09 17:48:13 +0100299if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Raef Coles995c66f2020-10-13 16:30:41 +0100300 add_dependencies(${lib_target} ${mbedcrypto_static_target} ${mbedx509_static_target} ${mbedtls_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200301endif()