2015-01-27 16:44:46 +01:00
|
|
|
option(USE_STATIC_MBEDTLS_LIBRARY "Build mbed TLS static library." ON)
|
|
|
|
option(USE_SHARED_MBEDTLS_LIBRARY "Build mbed TLS shared library." OFF)
|
2015-01-23 14:33:31 +01:00
|
|
|
option(LINK_WITH_PTHREAD "Explicitly link mbed TLS library to pthread." OFF)
|
2019-07-24 13:19:35 +02:00
|
|
|
option(LINK_WITH_TRUSTED_STORAGE "Explicitly link mbed TLS library to trusted_storage." OFF)
|
2011-01-05 16:24:43 +01:00
|
|
|
|
2019-04-29 10:35:06 +02:00
|
|
|
# Set the project root directory if it's not already defined, as may happen if
|
|
|
|
# the library folder is included directly by a parent project, without
|
|
|
|
# including the top level CMakeLists.txt.
|
|
|
|
if(NOT DEFINED MBEDTLS_DIR)
|
|
|
|
set(MBEDTLS_DIR ${CMAKE_SOURCE_DIR})
|
|
|
|
endif()
|
2011-01-05 16:24:43 +01:00
|
|
|
|
2015-06-24 11:54:19 +02:00
|
|
|
set(src_crypto
|
|
|
|
aes.c
|
|
|
|
aesni.c
|
|
|
|
arc4.c
|
2017-11-30 17:00:34 +01:00
|
|
|
aria.c
|
2015-06-24 11:54:19 +02:00
|
|
|
asn1parse.c
|
|
|
|
asn1write.c
|
|
|
|
base64.c
|
|
|
|
bignum.c
|
|
|
|
blowfish.c
|
|
|
|
camellia.c
|
|
|
|
ccm.c
|
2016-05-15 22:28:08 +02:00
|
|
|
chacha20.c
|
2018-05-07 10:43:27 +02:00
|
|
|
chachapoly.c
|
2015-06-24 11:54:19 +02:00
|
|
|
cipher.c
|
|
|
|
cipher_wrap.c
|
2015-12-11 16:49:45 +01:00
|
|
|
cmac.c
|
2015-06-24 11:54:19 +02:00
|
|
|
ctr_drbg.c
|
|
|
|
des.c
|
|
|
|
dhm.c
|
|
|
|
ecdh.c
|
|
|
|
ecdsa.c
|
2015-08-05 15:44:42 +02:00
|
|
|
ecjpake.c
|
2015-06-24 11:54:19 +02:00
|
|
|
ecp.c
|
|
|
|
ecp_curves.c
|
|
|
|
entropy.c
|
|
|
|
entropy_poll.c
|
|
|
|
error.c
|
|
|
|
gcm.c
|
|
|
|
havege.c
|
2016-07-17 09:51:22 +02:00
|
|
|
hkdf.c
|
2015-06-24 11:54:19 +02:00
|
|
|
hmac_drbg.c
|
|
|
|
md.c
|
|
|
|
md2.c
|
|
|
|
md4.c
|
|
|
|
md5.c
|
|
|
|
memory_buffer_alloc.c
|
2018-07-15 08:29:47 +02:00
|
|
|
nist_kw.c
|
2015-06-24 11:54:19 +02:00
|
|
|
oid.c
|
|
|
|
padlock.c
|
|
|
|
pem.c
|
|
|
|
pk.c
|
|
|
|
pk_wrap.c
|
|
|
|
pkcs12.c
|
|
|
|
pkcs5.c
|
|
|
|
pkparse.c
|
|
|
|
pkwrite.c
|
|
|
|
platform.c
|
2018-04-24 15:29:20 +02:00
|
|
|
platform_util.c
|
2016-05-16 23:25:45 +02:00
|
|
|
poly1305.c
|
2018-01-27 23:32:46 +01:00
|
|
|
psa_crypto.c
|
2019-06-24 14:06:43 +02:00
|
|
|
psa_crypto_se.c
|
2018-11-30 18:54:54 +01:00
|
|
|
psa_crypto_slot_management.c
|
2018-06-15 14:06:04 +02:00
|
|
|
psa_crypto_storage.c
|
2018-11-16 22:24:15 +01:00
|
|
|
psa_its_file.c
|
2015-06-24 11:54:19 +02:00
|
|
|
ripemd160.c
|
|
|
|
rsa.c
|
2017-10-11 12:00:19 +02:00
|
|
|
rsa_internal.c
|
2015-06-24 11:54:19 +02:00
|
|
|
sha1.c
|
|
|
|
sha256.c
|
|
|
|
sha512.c
|
|
|
|
threading.c
|
2015-06-25 10:59:15 +02:00
|
|
|
timing.c
|
2015-06-24 11:54:19 +02:00
|
|
|
version.c
|
|
|
|
version_features.c
|
|
|
|
xtea.c
|
|
|
|
)
|
|
|
|
|
2019-01-21 18:26:19 +01:00
|
|
|
list(APPEND src_crypto ${thirdparty_src})
|
|
|
|
|
2015-06-24 11:54:19 +02:00
|
|
|
set(src_x509
|
|
|
|
certs.c
|
|
|
|
pkcs11.c
|
|
|
|
x509.c
|
|
|
|
x509_create.c
|
|
|
|
x509_crl.c
|
|
|
|
x509_crt.c
|
|
|
|
x509_csr.c
|
|
|
|
x509write_crt.c
|
|
|
|
x509write_csr.c
|
|
|
|
)
|
|
|
|
|
|
|
|
set(src_tls
|
|
|
|
debug.c
|
2016-09-14 15:32:09 +02:00
|
|
|
net_sockets.c
|
2015-06-24 11:54:19 +02:00
|
|
|
ssl_cache.c
|
|
|
|
ssl_ciphersuites.c
|
|
|
|
ssl_cli.c
|
|
|
|
ssl_cookie.c
|
2020-02-05 12:33:54 +01:00
|
|
|
ssl_msg.c
|
2015-06-24 11:54:19 +02:00
|
|
|
ssl_srv.c
|
|
|
|
ssl_ticket.c
|
2020-02-05 12:32:03 +01:00
|
|
|
ssl_tls.c
|
2015-06-24 11:54:19 +02:00
|
|
|
)
|
|
|
|
|
2013-11-28 17:20:04 +01:00
|
|
|
if(CMAKE_COMPILER_IS_GNUCC)
|
2015-06-25 09:20:03 +02:00
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes")
|
2013-11-28 17:20:04 +01:00
|
|
|
endif(CMAKE_COMPILER_IS_GNUCC)
|
|
|
|
|
2014-06-25 15:59:50 +02:00
|
|
|
if(CMAKE_COMPILER_IS_CLANG)
|
2015-06-25 09:20:03 +02:00
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wmissing-declarations -Wmissing-prototypes -Wdocumentation -Wno-documentation-deprecated-sync -Wunreachable-code")
|
2014-06-25 15:59:50 +02:00
|
|
|
endif(CMAKE_COMPILER_IS_CLANG)
|
|
|
|
|
2019-01-06 20:48:30 +01:00
|
|
|
if(UNSAFE_BUILD)
|
|
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-error")
|
|
|
|
set(CMAKE_C_FLAGS_ASAN "${CMAKE_C_FLAGS_ASAN} -Wno-error")
|
|
|
|
set(CMAKE_C_FLAGS_ASANDBG "${CMAKE_C_FLAGS_ASANDBG} -Wno-error")
|
|
|
|
endif(UNSAFE_BUILD)
|
|
|
|
|
2015-06-25 09:35:46 +02:00
|
|
|
if(WIN32)
|
|
|
|
set(libs ${libs} ws2_32)
|
|
|
|
endif(WIN32)
|
|
|
|
|
2018-06-21 21:21:38 +02:00
|
|
|
if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
2018-04-27 13:14:59 +02:00
|
|
|
SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
|
|
|
SET(CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Scr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
|
|
|
SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
|
|
|
|
SET(CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -no_warning_for_no_symbols -c <TARGET>")
|
2018-06-21 21:21:38 +02:00
|
|
|
endif()
|
2018-04-27 13:14:59 +02:00
|
|
|
|
2018-04-12 02:27:32 +02:00
|
|
|
if(HAIKU)
|
2018-07-10 12:48:42 +02:00
|
|
|
set(libs ${libs} network)
|
2018-04-12 02:27:32 +02:00
|
|
|
endif(HAIKU)
|
|
|
|
|
2015-06-25 09:35:46 +02:00
|
|
|
if(USE_PKCS11_HELPER_LIBRARY)
|
|
|
|
set(libs ${libs} pkcs11-helper)
|
|
|
|
endif(USE_PKCS11_HELPER_LIBRARY)
|
|
|
|
|
|
|
|
if(ENABLE_ZLIB_SUPPORT)
|
|
|
|
set(libs ${libs} ${ZLIB_LIBRARIES})
|
|
|
|
endif(ENABLE_ZLIB_SUPPORT)
|
|
|
|
|
|
|
|
if(LINK_WITH_PTHREAD)
|
|
|
|
set(libs ${libs} pthread)
|
|
|
|
endif()
|
|
|
|
|
2019-07-15 14:50:19 +02:00
|
|
|
if(LINK_WITH_TRUSTED_STORAGE)
|
|
|
|
set(libs ${libs} trusted_storage)
|
|
|
|
endif()
|
|
|
|
|
2015-01-27 16:44:46 +01:00
|
|
|
if (NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
|
2015-06-25 09:20:03 +02:00
|
|
|
message(FATAL_ERROR "Need to choose static or shared mbedtls build!")
|
2015-01-27 16:44:46 +01:00
|
|
|
endif(NOT USE_STATIC_MBEDTLS_LIBRARY AND NOT USE_SHARED_MBEDTLS_LIBRARY)
|
2011-01-05 16:24:43 +01:00
|
|
|
|
2015-01-27 16:44:46 +01:00
|
|
|
if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
|
2015-06-25 09:20:03 +02:00
|
|
|
set(mbedtls_static_target "mbedtls_static")
|
2015-06-25 09:49:02 +02:00
|
|
|
set(mbedx509_static_target "mbedx509_static")
|
|
|
|
set(mbedcrypto_static_target "mbedcrypto_static")
|
2015-01-27 16:44:46 +01:00
|
|
|
elseif(USE_STATIC_MBEDTLS_LIBRARY)
|
2015-06-25 09:20:03 +02:00
|
|
|
set(mbedtls_static_target "mbedtls")
|
2015-06-25 09:49:02 +02:00
|
|
|
set(mbedx509_static_target "mbedx509")
|
|
|
|
set(mbedcrypto_static_target "mbedcrypto")
|
2014-03-06 15:49:08 +01:00
|
|
|
endif()
|
2011-01-05 16:24:43 +01:00
|
|
|
|
2015-01-27 16:44:46 +01:00
|
|
|
if(USE_STATIC_MBEDTLS_LIBRARY)
|
2015-06-25 09:49:02 +02:00
|
|
|
add_library(${mbedcrypto_static_target} STATIC ${src_crypto})
|
|
|
|
set_target_properties(${mbedcrypto_static_target} PROPERTIES OUTPUT_NAME mbedcrypto)
|
|
|
|
target_link_libraries(${mbedcrypto_static_target} ${libs})
|
2018-11-01 17:56:08 +01:00
|
|
|
target_include_directories(${mbedcrypto_static_target}
|
2020-03-09 17:30:32 +01:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/include/)
|
2015-06-25 09:49:02 +02:00
|
|
|
|
2020-02-26 19:05:19 +01:00
|
|
|
if(USE_CRYPTO_SUBMODULE)
|
|
|
|
install(TARGETS ${mbedcrypto_static_target}
|
|
|
|
DESTINATION ${LIB_INSTALL_DIR}
|
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
|
|
|
|
else()
|
|
|
|
add_library(${mbedx509_static_target} STATIC ${src_x509})
|
|
|
|
set_target_properties(${mbedx509_static_target} PROPERTIES OUTPUT_NAME mbedx509)
|
|
|
|
target_link_libraries(${mbedx509_static_target} ${libs} ${mbedcrypto_static_target})
|
|
|
|
|
|
|
|
add_library(${mbedtls_static_target} STATIC ${src_tls})
|
|
|
|
set_target_properties(${mbedtls_static_target} PROPERTIES OUTPUT_NAME mbedtls)
|
|
|
|
target_link_libraries(${mbedtls_static_target} ${libs} ${mbedx509_static_target})
|
|
|
|
|
|
|
|
install(TARGETS ${mbedtls_static_target} ${mbedx509_static_target} ${mbedcrypto_static_target}
|
|
|
|
DESTINATION ${LIB_INSTALL_DIR}
|
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
|
|
|
|
endif()
|
2015-06-25 14:53:13 +02:00
|
|
|
endif(USE_STATIC_MBEDTLS_LIBRARY)
|
2011-01-05 16:24:43 +01:00
|
|
|
|
2015-01-27 16:44:46 +01:00
|
|
|
if(USE_SHARED_MBEDTLS_LIBRARY)
|
2015-06-25 09:49:02 +02:00
|
|
|
|
|
|
|
add_library(mbedcrypto SHARED ${src_crypto})
|
2020-02-19 12:51:13 +01:00
|
|
|
set_target_properties(mbedcrypto PROPERTIES VERSION 2.21.0 SOVERSION 4)
|
2015-06-25 09:49:02 +02:00
|
|
|
target_link_libraries(mbedcrypto ${libs})
|
2018-11-01 17:56:08 +01:00
|
|
|
target_include_directories(mbedcrypto
|
2020-03-09 17:30:32 +01:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/include/)
|
2015-06-25 09:49:02 +02:00
|
|
|
|
|
|
|
add_library(mbedx509 SHARED ${src_x509})
|
2020-02-19 15:34:30 +01:00
|
|
|
set_target_properties(mbedx509 PROPERTIES VERSION 2.21.0 SOVERSION 1)
|
2015-06-25 09:49:02 +02:00
|
|
|
target_link_libraries(mbedx509 ${libs} mbedcrypto)
|
2018-10-25 18:37:00 +02:00
|
|
|
target_include_directories(mbedx509
|
2020-03-09 17:30:32 +01:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/include/)
|
2015-06-25 09:49:02 +02:00
|
|
|
|
|
|
|
add_library(mbedtls SHARED ${src_tls})
|
2020-02-19 15:34:30 +01:00
|
|
|
set_target_properties(mbedtls PROPERTIES VERSION 2.21.0 SOVERSION 13)
|
2015-06-25 09:49:02 +02:00
|
|
|
target_link_libraries(mbedtls ${libs} mbedx509)
|
2018-10-25 18:37:00 +02:00
|
|
|
target_include_directories(mbedtls
|
2020-03-09 17:30:32 +01:00
|
|
|
PUBLIC ${MBEDTLS_DIR}/include/)
|
2018-10-25 18:37:00 +02:00
|
|
|
|
2020-02-26 19:05:19 +01:00
|
|
|
if(USE_CRYPTO_SUBMODULE)
|
|
|
|
install(TARGETS mbedcrypto
|
|
|
|
DESTINATION ${LIB_INSTALL_DIR}
|
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
|
|
|
|
else()
|
|
|
|
add_library(mbedx509 SHARED ${src_x509})
|
|
|
|
set_target_properties(mbedx509 PROPERTIES VERSION 2.16.0 SOVERSION 0)
|
|
|
|
target_link_libraries(mbedx509 ${libs} mbedcrypto)
|
|
|
|
|
|
|
|
add_library(mbedtls SHARED ${src_tls})
|
|
|
|
set_target_properties(mbedtls PROPERTIES VERSION 2.16.0 SOVERSION 12)
|
|
|
|
target_link_libraries(mbedtls ${libs} mbedx509)
|
|
|
|
|
|
|
|
install(TARGETS mbedtls mbedx509 mbedcrypto
|
|
|
|
DESTINATION ${LIB_INSTALL_DIR}
|
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE)
|
|
|
|
endif()
|
2015-01-27 16:44:46 +01:00
|
|
|
endif(USE_SHARED_MBEDTLS_LIBRARY)
|
2015-06-25 14:53:13 +02:00
|
|
|
|
2018-10-29 18:40:05 +01:00
|
|
|
if(USE_CRYPTO_SUBMODULE)
|
|
|
|
add_custom_target(crypto_lib DEPENDS mbedcrypto)
|
|
|
|
if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
|
|
|
|
add_dependencies(crypto_lib mbedcrypto_static)
|
|
|
|
endif()
|
|
|
|
else()
|
2020-02-26 19:05:19 +01:00
|
|
|
add_custom_target(lib DEPENDS mbedcrypto mbedx509 mbedtls)
|
2018-10-29 18:40:05 +01:00
|
|
|
if(USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY)
|
2020-02-26 19:05:19 +01:00
|
|
|
add_dependencies(lib mbedcrypto_static mbedx509_static mbedtls_static)
|
2018-10-29 18:40:05 +01:00
|
|
|
endif()
|
2015-06-25 14:53:13 +02:00
|
|
|
endif()
|