blob: 244dc34bbeff2be7f9ad410ef1a0a59f0643fc1b [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)
Paul Bakker9d3a7e42011-01-05 15:24:43 +00004
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +02005set(src_crypto
6 aes.c
7 aesni.c
8 arc4.c
Markku-Juhani O. Saarinen3c0b53b2017-11-30 16:00:34 +00009 aria.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020010 asn1parse.c
11 asn1write.c
12 base64.c
13 bignum.c
14 blowfish.c
15 camellia.c
16 ccm.c
Daniel King34b822c2016-05-15 17:28:08 -030017 chacha20.c
Manuel Pégourié-Gonnarddca3a5d2018-05-07 10:43:27 +020018 chachapoly.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020019 cipher.c
20 cipher_wrap.c
Robert Cragiedc5c7b92015-12-11 15:49:45 +000021 cmac.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020022 ctr_drbg.c
23 des.c
24 dhm.c
25 ecdh.c
26 ecdsa.c
Manuel Pégourié-Gonnard4d8685b2015-08-05 15:44:42 +020027 ecjpake.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020028 ecp.c
29 ecp_curves.c
30 entropy.c
31 entropy_poll.c
32 error.c
33 gcm.c
34 havege.c
Thomas Fossati656864b2016-07-17 08:51:22 +010035 hkdf.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020036 hmac_drbg.c
37 md.c
38 md2.c
39 md4.c
40 md5.c
41 md_wrap.c
42 memory_buffer_alloc.c
Ron Eldorcb349ac2018-07-15 09:29:47 +030043 nist_kw.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020044 oid.c
45 padlock.c
46 pem.c
47 pk.c
48 pk_wrap.c
49 pkcs12.c
50 pkcs5.c
51 pkparse.c
52 pkwrite.c
53 platform.c
Andres Amaya Garciabc7bdbf2018-04-24 08:29:20 -050054 platform_util.c
Daniel Kingadc32c02016-05-16 18:25:45 -030055 poly1305.c
Gilles Peskinee59236f2018-01-27 23:32:46 +010056 psa_crypto.c
Gilles Peskine961849f2018-11-30 18:54:54 +010057 psa_crypto_slot_management.c
Darryl Greendb2b8db2018-06-15 13:06:04 +010058 psa_crypto_storage.c
59 psa_crypto_storage_file.c
Moran Pekera26d7642018-11-20 18:33:41 +020060 psa_crypto_storage_its.c
Gilles Peskine6194dc22018-11-16 22:24:15 +010061 psa_its_file.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020062 ripemd160.c
63 rsa.c
Hanno Beckera565f542017-10-11 11:00:19 +010064 rsa_internal.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020065 sha1.c
66 sha256.c
67 sha512.c
68 threading.c
Manuel Pégourié-Gonnard21dcc1e2015-06-25 10:59:15 +020069 timing.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020070 version.c
71 version_features.c
72 xtea.c
73)
74
75set(src_x509
76 certs.c
77 pkcs11.c
78 x509.c
79 x509_create.c
80 x509_crl.c
81 x509_crt.c
82 x509_csr.c
83 x509write_crt.c
84 x509write_csr.c
85)
86
87set(src_tls
88 debug.c
Andres AG788aa4a2016-09-14 14:32:09 +010089 net_sockets.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020090 ssl_cache.c
91 ssl_ciphersuites.c
92 ssl_cli.c
93 ssl_cookie.c
94 ssl_srv.c
95 ssl_ticket.c
96 ssl_tls.c
Manuel Pégourié-Gonnard463e09d2015-06-24 11:54:19 +020097)
98
Paul Bakker76f03112013-11-28 17:20:04 +010099if(CMAKE_COMPILER_IS_GNUCC)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200100 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes")
Paul Bakker76f03112013-11-28 17:20:04 +0100101endif(CMAKE_COMPILER_IS_GNUCC)
102
Manuel Pégourié-Gonnard31855452014-06-25 15:59:50 +0200103if(CMAKE_COMPILER_IS_CLANG)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200104 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 +0200105endif(CMAKE_COMPILER_IS_CLANG)
106
Gilles Peskine19275652019-01-06 19:48:30 +0000107if(UNSAFE_BUILD)
108 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-error")
109 set(CMAKE_C_FLAGS_ASAN "${CMAKE_C_FLAGS_ASAN} -Wno-error")
110 set(CMAKE_C_FLAGS_ASANDBG "${CMAKE_C_FLAGS_ASANDBG} -Wno-error")
111endif(UNSAFE_BUILD)
112
Manuel Pégourié-Gonnardba2c8762015-06-25 09:35:46 +0200113if(WIN32)
114 set(libs ${libs} ws2_32)
115endif(WIN32)
116
Andres Amaya Garciabf7fe4f2018-06-21 20:21:38 +0100117if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
TabascoEye7f3ef272018-04-27 13:14:59 +0200118 SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
119 SET(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
120 SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
121 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(USE_PKCS11_HELPER_LIBRARY)
129 set(libs ${libs} pkcs11-helper)
130endif(USE_PKCS11_HELPER_LIBRARY)
131
132if(ENABLE_ZLIB_SUPPORT)
133 set(libs ${libs} ${ZLIB_LIBRARIES})
134endif(ENABLE_ZLIB_SUPPORT)
135
136if(LINK_WITH_PTHREAD)
137 set(libs ${libs} pthread)
138endif()
139
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000140if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200141 message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000142endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000143
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000144if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200145 set(mbedtls_static_target "mbedtls_static")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200146 set(mbedx509_static_target "mbedx509_static")
147 set(mbedcrypto_static_target "mbedcrypto_static")
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000148elseif(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200149 set(mbedtls_static_target "mbedtls")
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200150 set(mbedx509_static_target "mbedx509")
151 set(mbedcrypto_static_target "mbedcrypto")
hasufell3c6409b2014-03-06 15:49:08 +0100152endif()
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000153
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000154if(USE_STATIC_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200155 add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
156 set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
157 target_link_libraries(${mbedcrypto_static_target} ${libs})
Jaeden Ameroc6e4ab02018-11-01 16:56:08 +0000158 target_include_directories(${mbedcrypto_static_target}
159 PUBLIC ${CMAKE_SOURCE_DIR}/include/
160 PUBLIC ${CMAKE_SOURCE_DIR}/crypto/include/)
Paul Bakker6c1f69b2014-03-17 15:11:13 +0100161
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000162 if(USE_CRYPTO_SUBMODULE)
163 install(TARGETS ${mbedcrypto_static_target}
164 DESTINATION ${LIB_INSTALL_DIR}
165 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
166 else()
167 add_library(${mbedx509_static_target} STATIC ${src_x509})
168 set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
169 target_link_libraries(${mbedx509_static_target} ${libs} ${mbedcrypto_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200170
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000171 add_library(${mbedtls_static_target} STATIC ${src_tls})
172 set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
173 target_link_libraries(${mbedtls_static_target} ${libs} ${mbedx509_static_target})
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200174
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000175 install(TARGETS ${mbedtls_static_target} ${mbedx509_static_target} ${mbedcrypto_static_target}
176 DESTINATION ${LIB_INSTALL_DIR}
177 PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
178 endif()
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200179endif(USE_STATIC_MBEDTLS_LIBRARY)
Paul Bakker9d3a7e42011-01-05 15:24:43 +0000180
Manuel Pégourié-Gonnard9014b6f2015-01-27 15:44:46 +0000181if(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200182 add_library(mbedcrypto SHARED ${src_crypto})
Jaeden Amero67ea2c52019-02-11 12:05:54 +0000183 set_target_properties(mbedcrypto PROPERTIES VERSION 2.16.0 SOVERSION 3)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200184 target_link_libraries(mbedcrypto ${libs})
Jaeden Ameroc6e4ab02018-11-01 16:56:08 +0000185 target_include_directories(mbedcrypto
186 PUBLIC ${CMAKE_SOURCE_DIR}/include/
187 PUBLIC ${CMAKE_SOURCE_DIR}/crypto/include/)
Paul Bakker2a5c7a82012-05-10 21:54:28 +0000188
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000189 if(USE_CRYPTO_SUBMODULE)
190 install(TARGETS mbedcrypto
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 SHARED ${src_x509})
Jaeden Amero67ea2c52019-02-11 12:05:54 +0000195 set_target_properties(mbedx509 PROPERTIES VERSION 2.16.0 SOVERSION 0)
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000196 target_link_libraries(mbedx509 ${libs} mbedcrypto)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200197
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000198 add_library(mbedtls SHARED ${src_tls})
Jaeden Amero67ea2c52019-02-11 12:05:54 +0000199 set_target_properties(mbedtls PROPERTIES VERSION 2.16.0 SOVERSION 12)
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000200 target_link_libraries(mbedtls ${libs} mbedx509)
Manuel Pégourié-Gonnardc7781ad2015-06-25 09:49:02 +0200201
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000202 install(TARGETS mbedtls mbedx509 mbedcrypto
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é-Gonnard9014b6f2015-01-27 15:44:46 +0000206endif(USE_SHARED_MBEDTLS_LIBRARY)
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200207
Jaeden Amero5ae1fb62018-10-29 17:40:05 +0000208if(USE_CRYPTO_SUBMODULE)
209 add_custom_target(crypto_lib DEPENDS mbedcrypto)
210 if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
211 add_dependencies(crypto_lib mbedcrypto_static)
212 endif()
213else()
214 add_custom_target(lib DEPENDS mbedcrypto mbedx509 mbedtls)
215 if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
216 add_dependencies(lib mbedcrypto_static mbedx509_static mbedtls_static)
217 endif()
Manuel Pégourié-Gonnarde1d34d12015-06-25 14:53:13 +0200218endif()