blob: 91ac8bc7e00b08d6fddae84449d793d1313563a7 [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
16 arc4.c
Markku-Juhani O. Saarinen3c0b53b2017-11-30 16:00:34 +000017 aria.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020018 asn1parse.c
19 asn1write.c
20 base64.c
21 bignum.c
22 blowfish.c
23 camellia.c
24 ccm.c
Daniel King34b822c2016-05-15 17:28:08 -030025 chacha20.c
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020026 chachapoly.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020027 cipher.c
28 cipher_wrap.c
Robert Cragiedc5c7b92015-12-11 15:49:45 +000029 cmac.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020030 ctr_drbg.c
31 des.c
32 dhm.c
33 ecdh.c
34 ecdsa.c
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +020035 ecjpake.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020036 ecp.c
37 ecp_curves.c
38 entropy.c
39 entropy_poll.c
40 error.c
41 gcm.c
42 havege.c
Thomas Fossati656864b2016-07-17 08:51:22 +010043 hkdf.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020044 hmac_drbg.c
45 md.c
46 md2.c
47 md4.c
48 md5.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020049 memory_buffer_alloc.c
Ron Eldorcb349ac2018-07-15 09:29:47 +030050 nist_kw.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020051 oid.c
52 padlock.c
53 pem.c
54 pk.c
55 pk_wrap.c
56 pkcs12.c
57 pkcs5.c
58 pkparse.c
59 pkwrite.c
60 platform.c
Andres Amaya Garciabc7bdbf2018-04-24 08:29:20 -050061 platform_util.c
Daniel Kingadc32c02016-05-16 18:25:45 -030062 poly1305.c
Gilles Peskinee59236f2018-01-27 23:32:46 +010063 psa_crypto.c
Steven Cooremancd84cb42020-07-16 20:28:36 +020064 psa_crypto_driver_wrappers.c
Gilles Peskinea899a722019-06-24 14:06:43 +020065 psa_crypto_se.c
Gilles Peskine961849f2018-11-30 18:54:54 +010066 psa_crypto_slot_management.c
Darryl Greendb2b8db2018-06-15 13:06:04 +010067 psa_crypto_storage.c
Gilles Peskine6194dc22018-11-16 22:24:15 +010068 psa_its_file.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020069 ripemd160.c
70 rsa.c
Hanno Beckera565f542017-10-11 11:00:19 +010071 rsa_internal.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020072 sha1.c
73 sha256.c
74 sha512.c
75 threading.c
Manuel Pégourié-Gonnard21dcc1e2015-06-25 10:59:15 +020076 timing.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020077 version.c
78 version_features.c
79 xtea.c
80)
81
Christoph M. Wintersteiger655ddab2019-01-21 17:26:19 +000082list(APPEND src_crypto ${thirdparty_src})
83
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020084set(src_x509
85 certs.c
86 pkcs11.c
87 x509.c
88 x509_create.c
89 x509_crl.c
90 x509_crt.c
91 x509_csr.c
92 x509write_crt.c
93 x509write_csr.c
94)
95
96set(src_tls
97 debug.c
Andres AG788aa4a2016-09-14 14:32:09 +010098 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020099 ssl_cache.c
100 ssl_ciphersuites.c
101 ssl_cli.c
102 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_srv.c
105 ssl_ticket.c
Hanno Becker471c0c92020-02-05 11:32:03 +0000106 ssl_tls.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +0200107)
108
Paul Bakker76f03112013-11-28 17:20:04 +0100109if(CMAKE_COMPILER_IS_GNUCC)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200110 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes")
Paul Bakker76f03112013-11-28 17:20:04 +0100111endif(CMAKE_COMPILER_IS_GNUCC)
112
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200113if(CMAKE_COMPILER_IS_CLANG)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200114 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 +0200115endif(CMAKE_COMPILER_IS_CLANG)
116
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200117if(WIN32)
118 set(libs ${libs} ws2_32)
119endif(WIN32)
120
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100121if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
TabascoEye7f3ef272018-04-27 13:14:59 +0200122 SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
123 SET(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
124 SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
125 SET(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100126endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200127
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400128if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100129 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400130endif(HAIKU)
131
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200132if(USE_PKCS11_HELPER_LIBRARY)
133 set(libs ${libs} pkcs11-helper)
134endif(USE_PKCS11_HELPER_LIBRARY)
135
136if(ENABLE_ZLIB_SUPPORT)
137 set(libs ${libs} ${ZLIB_LIBRARIES})
138endif(ENABLE_ZLIB_SUPPORT)
139
140if(LINK_WITH_PTHREAD)
141 set(libs ${libs} pthread)
142endif()
143
Moshe Shahar7e367652019-07-15 15:50:19 +0300144if(LINK_WITH_TRUSTED_STORAGE)
145 set(libs ${libs} trusted_storage)
146endif()
147
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000148if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200149 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000150endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000151
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200152set(target_libraries "mbedcrypto" "mbedx509" "mbedtls")
153
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000154if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200155 set(mbedtls_static_target "mbedtls_static")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200156 set(mbedx509_static_target "mbedx509_static")
157 set(mbedcrypto_static_target "mbedcrypto_static")
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200158 list(APPEND target_libraries
159 "mbedcrypto_static" "mbedx509_static" "mbedtls_static")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000160elseif(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200161 set(mbedtls_static_target "mbedtls")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200162 set(mbedx509_static_target "mbedx509")
163 set(mbedcrypto_static_target "mbedcrypto")
hasufell3c6409b2014-03-06 15:49:08 +0100164endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000165
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)
169 target_link_libraries(${mbedcrypto_static_target} ${libs})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200170
Gilles Peskine55d53532020-03-09 17:48:13 +0100171 add_library(${mbedx509_static_target} STATIC ${src_x509})
172 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
173 target_link_libraries(${mbedx509_static_target} ${libs} ${mbedcrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200174
Gilles Peskine55d53532020-03-09 17:48:13 +0100175 add_library(${mbedtls_static_target} STATIC ${src_tls})
176 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
177 target_link_libraries(${mbedtls_static_target} ${libs} ${mbedx509_static_target})
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200178endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000179
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000180if(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200181 add_library(mbedcrypto SHARED ${src_crypto})
Janos Follath17ffc5d2020-08-26 15:22:45 +0100182 set_target_properties(mbedcrypto PROPERTIES VERSION 2.24.0 SOVERSION 5)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200183 target_link_libraries(mbedcrypto ${libs})
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000184
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200185 add_library(mbedx509 SHARED ${src_x509})
Janos Follath17ffc5d2020-08-26 15:22:45 +0100186 set_target_properties(mbedx509 PROPERTIES VERSION 2.24.0 SOVERSION 1)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200187 target_link_libraries(mbedx509 ${libs} mbedcrypto)
188
189 add_library(mbedtls SHARED ${src_tls})
Janos Follath17ffc5d2020-08-26 15:22:45 +0100190 set_target_properties(mbedtls PROPERTIES VERSION 2.24.0 SOVERSION 13)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200191 target_link_libraries(mbedtls ${libs} mbedx509)
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000192endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200193
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200194foreach(target IN LISTS target_libraries)
Gilles Peskine76dd3aa2020-07-02 15:58:37 +0200195 # Include public header files from /include and other directories
196 # declared by /3rdparty/**/CMakeLists.txt. Include private header files
197 # from /library and others declared by /3rdparty/**/CMakeLists.txt.
198 # /library needs to be listed explicitly when building .c files outside
199 # of /library (which currently means: under /3rdparty).
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200200 target_include_directories(${target}
201 PUBLIC ${MBEDTLS_DIR}/include/
202 PUBLIC ${thirdparty_inc_public}
Gilles Peskinededff7a2020-07-02 13:13:27 +0200203 PRIVATE ${MBEDTLS_DIR}/library/
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200204 PRIVATE ${thirdparty_inc})
205 target_compile_definitions(${target}
206 PRIVATE ${thirdparty_def})
207 install(TARGETS ${target}
hasufell3c6409b2014-03-06 15:49:08 +0100208 DESTINATION ${LIB_INSTALL_DIR}
Gilles Peskine280165c2020-07-02 13:19:17 +0200209 PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ WORLD_READ)
Gilles Peskine3ca8a922020-07-02 13:07:37 +0200210endforeach(target)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200211
Gilles Peskine55d53532020-03-09 17:48:13 +0100212add_custom_target(lib DEPENDS mbedcrypto mbedx509 mbedtls)
213if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
214 add_dependencies(lib mbedcrypto_static mbedx509_static mbedtls_static)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200215endif()