blob: 0053f09b080064cec93bce7c12d27cfe42117eaf [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
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020040 gcm.c
41 havege.c
Thomas Fossati656864b2016-07-17 08:51:22 +010042 hkdf.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020043 hmac_drbg.c
44 md.c
45 md2.c
46 md4.c
47 md5.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020048 memory_buffer_alloc.c
Ron Eldorcb349ac2018-07-15 09:29:47 +030049 nist_kw.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020050 oid.c
51 padlock.c
52 pem.c
53 pk.c
54 pk_wrap.c
55 pkcs12.c
56 pkcs5.c
57 pkparse.c
58 pkwrite.c
59 platform.c
Andres Amaya Garciabc7bdbf2018-04-24 08:29:20 -050060 platform_util.c
Daniel Kingadc32c02016-05-16 18:25:45 -030061 poly1305.c
Gilles Peskinee59236f2018-01-27 23:32:46 +010062 psa_crypto.c
Gilles Peskinea899a722019-06-24 14:06:43 +020063 psa_crypto_se.c
Gilles Peskine961849f2018-11-30 18:54:54 +010064 psa_crypto_slot_management.c
Darryl Greendb2b8db2018-06-15 13:06:04 +010065 psa_crypto_storage.c
Gilles Peskine6194dc22018-11-16 22:24:15 +010066 psa_its_file.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020067 ripemd160.c
68 rsa.c
Hanno Beckera565f542017-10-11 11:00:19 +010069 rsa_internal.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020070 sha1.c
71 sha256.c
72 sha512.c
73 threading.c
Manuel Pégourié-Gonnard21dcc1e2015-06-25 10:59:15 +020074 timing.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020075 xtea.c
76)
77
Jaeden Amero18d47892019-04-26 12:53:02 +010078# For files generated by the parent project (Mbed TLS) when building Mbed
79# Crypto as a submodule, ensure that the parent project instance is used.
80if(USE_CRYPTO_SUBMODULE)
81set(src_crypto
82 ${src_crypto}
Ashley Duncand85a7e92019-04-29 20:35:06 +120083 ${MBEDTLS_DIR}/library/version.c
84 ${MBEDTLS_DIR}/library/version_features.c
85 ${MBEDTLS_DIR}/library/error.c
Jaeden Amero18d47892019-04-26 12:53:02 +010086)
87else()
88set(src_crypto
89 ${src_crypto}
90 version.c
91 version_features.c
92 error.c
93)
94endif()
95
Christoph M. Wintersteiger6ea2dea12019-01-21 17:26:19 +000096list(APPEND src_crypto ${thirdparty_src})
97
Gilles Peskine722a7e62020-02-26 19:05:19 +010098set(src_x509
99 certs.c
100 pkcs11.c
101 x509.c
102 x509_create.c
103 x509_crl.c
104 x509_crt.c
105 x509_csr.c
106 x509write_crt.c
107 x509write_csr.c
108)
109
110set(src_tls
111 debug.c
112 net_sockets.c
113 ssl_cache.c
114 ssl_ciphersuites.c
115 ssl_cli.c
116 ssl_cookie.c
117 ssl_srv.c
118 ssl_ticket.c
119 ssl_tls.c
120)
121
Paul Bakker76f03112013-11-28 17:20:04 +0100122if(CMAKE_COMPILER_IS_GNUCC)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200123 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes")
Paul Bakker76f03112013-11-28 17:20:04 +0100124endif(CMAKE_COMPILER_IS_GNUCC)
125
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200126if(CMAKE_COMPILER_IS_CLANG)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200127 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 +0200128endif(CMAKE_COMPILER_IS_CLANG)
129
Gilles Peskine19275652019-01-06 19:48:30 +0000130if(UNSAFE_BUILD)
131 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-error")
132 set(CMAKE_C_FLAGS_ASAN "${CMAKE_C_FLAGS_ASAN} -Wno-error")
133 set(CMAKE_C_FLAGS_ASANDBG "${CMAKE_C_FLAGS_ASANDBG} -Wno-error")
134endif(UNSAFE_BUILD)
135
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200136if(WIN32)
137 set(libs ${libs} ws2_32)
138endif(WIN32)
139
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100140if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
TabascoEye7f3ef272018-04-27 13:14:59 +0200141 SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
142 SET(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
143 SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
144 SET(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100145endif()
TabascoEye7f3ef272018-04-27 13:14:59 +0200146
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400147if(HAIKU)
Simon Butcher6331cb02018-07-10 11:48:42 +0100148 set(libs ${libs} network)
Augustin Cavalier60bc47d2018-04-11 20:27:32 -0400149endif(HAIKU)
150
Gilles Peskine6bbe7832020-02-26 19:13:28 +0100151if(USE_PKCS11_HELPER_LIBRARY)
152 set(libs ${libs} pkcs11-helper)
153endif(USE_PKCS11_HELPER_LIBRARY)
154
Gilles Peskine5bb8bec2020-02-26 19:11:43 +0100155if(ENABLE_ZLIB_SUPPORT)
156 set(libs ${libs} ${ZLIB_LIBRARIES})
157endif(ENABLE_ZLIB_SUPPORT)
158
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200159if(LINK_WITH_PTHREAD)
160 set(libs ${libs} pthread)
161endif()
162
Moshe Shahar7e367652019-07-15 15:50:19 +0300163if(LINK_WITH_TRUSTED_STORAGE)
164 set(libs ${libs} trusted_storage)
165endif()
166
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000167if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200168 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000169endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000170
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000171if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Gilles Peskine722a7e62020-02-26 19:05:19 +0100172 set(mbedtls_static_target "mbedtls_static")
173 set(mbedx509_static_target "mbedx509_static")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200174 set(mbedcrypto_static_target "mbedcrypto_static")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000175elseif(USE_STATIC_MBEDTLS_LIBRARY)
Gilles Peskine722a7e62020-02-26 19:05:19 +0100176 set(mbedtls_static_target "mbedtls")
177 set(mbedx509_static_target "mbedx509")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200178 set(mbedcrypto_static_target "mbedcrypto")
hasufell3c6409b2014-03-06 15:49:08 +0100179endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000180
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000181if(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200182 add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
183 set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
184 target_link_libraries(${mbedcrypto_static_target} ${libs})
Jaeden Ameroc6e4ab02018-11-01 16:56:08 +0000185 target_include_directories(${mbedcrypto_static_target}
Ashley Duncand85a7e92019-04-29 20:35:06 +1200186 PUBLIC ${MBEDTLS_DIR}/include/
187 PUBLIC ${MBEDTLS_DIR}/crypto/include/)
Paul Bakker6c1f69b2014-03-17 15:11:13 +0100188
Gilles Peskine722a7e62020-02-26 19:05:19 +0100189 if(USE_CRYPTO_SUBMODULE)
190 install(TARGETS ${mbedcrypto_static_target}
191 DESTINATION ${LIB_INSTALL_DIR}
192 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
193 else()
194 add_library(${mbedx509_static_target} STATIC ${src_x509})
195 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
196 target_link_libraries(${mbedx509_static_target} ${libs} ${mbedcrypto_static_target})
197
198 add_library(${mbedtls_static_target} STATIC ${src_tls})
199 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
200 target_link_libraries(${mbedtls_static_target} ${libs} ${mbedx509_static_target})
201
202 install(TARGETS ${mbedtls_static_target} ${mbedx509_static_target} ${mbedcrypto_static_target}
203 DESTINATION ${LIB_INSTALL_DIR}
204 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
205 endif()
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200206endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000207
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000208if(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200209 add_library(mbedcrypto SHARED ${src_crypto})
Janos Follathbc7c2422020-02-19 11:51:13 +0000210 set_target_properties(mbedcrypto PROPERTIES VERSION 2.21.0 SOVERSION 4)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200211 target_link_libraries(mbedcrypto ${libs})
Jaeden Ameroc6e4ab02018-11-01 16:56:08 +0000212 target_include_directories(mbedcrypto
Ashley Duncand85a7e92019-04-29 20:35:06 +1200213 PUBLIC ${MBEDTLS_DIR}/include/
214 PUBLIC ${MBEDTLS_DIR}/crypto/include/)
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000215
Gilles Peskine722a7e62020-02-26 19:05:19 +0100216 if(USE_CRYPTO_SUBMODULE)
217 install(TARGETS mbedcrypto
218 DESTINATION ${LIB_INSTALL_DIR}
219 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
220 else()
221 add_library(mbedx509 SHARED ${src_x509})
222 set_target_properties(mbedx509 PROPERTIES VERSION 2.16.0 SOVERSION 0)
223 target_link_libraries(mbedx509 ${libs} mbedcrypto)
224
225 add_library(mbedtls SHARED ${src_tls})
226 set_target_properties(mbedtls PROPERTIES VERSION 2.16.0 SOVERSION 12)
227 target_link_libraries(mbedtls ${libs} mbedx509)
228
229 install(TARGETS mbedtls mbedx509 mbedcrypto
230 DESTINATION ${LIB_INSTALL_DIR}
231 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
232 endif()
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000233endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200234
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000235if(USE_CRYPTO_SUBMODULE)
236 add_custom_target(crypto_lib DEPENDS mbedcrypto)
237 if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
238 add_dependencies(crypto_lib mbedcrypto_static)
239 endif()
240else()
Gilles Peskine722a7e62020-02-26 19:05:19 +0100241 add_custom_target(lib DEPENDS mbedcrypto mbedx509 mbedtls)
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000242 if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Gilles Peskine722a7e62020-02-26 19:05:19 +0100243 add_dependencies(lib mbedcrypto_static mbedx509_static mbedtls_static)
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000244 endif()
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200245endif()