2020-05-20 13:34:47 +00:00
#
# CMake build system design considerations:
#
# - Include directories:
# + Do not define include directories globally using the include_directories
# command but rather at the target level using the
# target_include_directories command. That way, it is easier to guarantee
# that targets are built using the proper list of include directories.
2021-12-21 05:14:10 +00:00
# + Use the PUBLIC and PRIVATE keywords to specify the scope of include
2020-05-20 13:34:47 +00:00
# directories. That way, a target linking to a library (using the
2022-05-17 23:30:44 +00:00
# target_link_libraries command) inherits from the library PUBLIC include
2020-05-20 13:34:47 +00:00
# directories and not from the PRIVATE ones.
2020-10-13 15:30:41 +00:00
# - MBEDTLS_TARGET_PREFIX: CMake targets are designed to be alterable by calling
# CMake in order to avoid target name clashes, via the use of
# MBEDTLS_TARGET_PREFIX. The value of this variable is prefixed to the
2024-10-25 14:01:14 +00:00
# mbedtls, mbedx509, tfpsacrypto and mbedtls-apidoc targets.
2020-05-20 13:34:47 +00:00
#
2021-06-04 16:04:20 +00:00
# We specify a minimum requirement of 3.10.2, but for now use 3.5.1 here
# until our infrastructure catches up.
cmake_minimum_required ( VERSION 3.5.1 )
2020-09-18 17:15:07 +00:00
2021-03-25 16:03:25 +00:00
include ( CMakePackageConfigHelpers )
2024-07-11 06:47:53 +00:00
# Include convenience functions for printing properties and variables, like
# cmake_print_properties(), cmake_print_variables().
include ( CMakePrintHelpers )
2020-09-18 17:15:07 +00:00
# https://cmake.org/cmake/help/latest/policy/CMP0011.html
# Setting this policy is required in CMake >= 3.18.0, otherwise a warning is generated. The OLD
# policy setting is deprecated, and will be removed in future versions.
cmake_policy ( SET CMP0011 NEW )
# https://cmake.org/cmake/help/latest/policy/CMP0012.html
# Setting the CMP0012 policy to NEW is required for FindPython3 to work with CMake 3.18.2
# (there is a bug in this particular version), otherwise, setting the CMP0012 policy is required
# for CMake versions >= 3.18.3 otherwise a deprecated warning is generated. The OLD policy setting
# is deprecated and will be removed in future versions.
cmake_policy ( SET CMP0012 NEW )
2018-03-15 09:16:24 +00:00
if ( TEST_CPP )
2024-02-20 14:16:57 +00:00
project ( "Mbed TLS"
L A N G U A G E S C C X X
2024-09-03 16:36:30 +00:00
V E R S I O N 4 . 0 . 0
2024-02-20 14:16:57 +00:00
)
2018-03-15 09:16:24 +00:00
else ( )
2024-02-20 14:16:57 +00:00
project ( "Mbed TLS"
L A N G U A G E S C
2024-09-03 16:36:30 +00:00
V E R S I O N 4 . 0 . 0
2024-02-20 14:16:57 +00:00
)
2018-03-15 09:16:24 +00:00
endif ( )
2009-06-28 21:50:27 +00:00
2022-04-22 15:26:21 +00:00
include ( GNUInstallDirs )
2023-08-03 15:45:20 +00:00
# Determine if Mbed TLS is being built as a subproject using add_subdirectory()
2021-12-07 20:45:55 +00:00
if ( NOT DEFINED MBEDTLS_AS_SUBPROJECT )
set ( MBEDTLS_AS_SUBPROJECT ON )
if ( CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR )
set ( MBEDTLS_AS_SUBPROJECT OFF )
endif ( )
endif ( )
2024-07-25 12:52:19 +00:00
# Set the project and framework root directory.
2019-04-29 08:35:06 +00:00
set ( MBEDTLS_DIR ${ CMAKE_CURRENT_SOURCE_DIR } )
2024-07-25 12:52:19 +00:00
set ( MBEDTLS_FRAMEWORK_DIR ${ CMAKE_CURRENT_SOURCE_DIR } /framework )
2019-04-29 08:35:06 +00:00
2023-08-03 15:45:20 +00:00
option ( ENABLE_PROGRAMS "Build Mbed TLS programs." ON )
2015-07-09 08:19:47 +00:00
2020-04-03 07:42:37 +00:00
option ( MBEDTLS_FATAL_WARNINGS "Compiler warnings treated as errors" ON )
2022-04-14 14:22:11 +00:00
if ( CMAKE_HOST_WIN32 )
2023-09-09 20:54:26 +00:00
# N.B. The comment on the next line is significant! If you change it,
# edit the sed command in prepare_release.sh that modifies
# CMakeLists.txt.
2023-09-09 19:00:30 +00:00
option ( GEN_FILES "Generate the auto-generated files as needed" OFF ) # off in development
2021-10-21 18:45:52 +00:00
else ( )
2024-03-27 13:51:15 +00:00
option ( GEN_FILES "Generate the auto-generated files as needed" ON )
2021-10-21 18:45:52 +00:00
endif ( )
2015-07-09 08:19:47 +00:00
2021-12-07 20:45:55 +00:00
option ( DISABLE_PACKAGE_CONFIG_AND_INSTALL "Disable package configuration, target export and installation" ${ MBEDTLS_AS_SUBPROJECT } )
2023-10-18 14:15:58 +00:00
if ( CMAKE_C_SIMULATE_ID )
set ( COMPILER_ID ${ CMAKE_C_SIMULATE_ID } )
else ( )
set ( COMPILER_ID ${ CMAKE_C_COMPILER_ID } )
endif ( CMAKE_C_SIMULATE_ID )
string ( REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${COMPILER_ID}" )
string ( REGEX MATCH "GNU" CMAKE_COMPILER_IS_GNU "${COMPILER_ID}" )
string ( REGEX MATCH "IAR" CMAKE_COMPILER_IS_IAR "${COMPILER_ID}" )
string ( REGEX MATCH "MSVC" CMAKE_COMPILER_IS_MSVC "${COMPILER_ID}" )
2018-05-23 15:55:16 +00:00
2015-07-09 08:19:47 +00:00
# the test suites currently have compile errors with MSVC
2018-05-23 15:55:16 +00:00
if ( CMAKE_COMPILER_IS_MSVC )
2023-08-03 15:45:20 +00:00
option ( ENABLE_TESTING "Build Mbed TLS tests." OFF )
2015-07-09 08:19:47 +00:00
else ( )
2023-08-03 15:45:20 +00:00
option ( ENABLE_TESTING "Build Mbed TLS tests." ON )
2015-07-09 08:19:47 +00:00
endif ( )
2015-07-08 21:10:38 +00:00
2024-07-24 06:42:32 +00:00
option ( USE_STATIC_MBEDTLS_LIBRARY "Build Mbed TLS static library." ON )
option ( USE_SHARED_MBEDTLS_LIBRARY "Build Mbed TLS shared library." OFF )
option ( LINK_WITH_PTHREAD "Explicitly link Mbed TLS library to pthread." OFF )
option ( LINK_WITH_TRUSTED_STORAGE "Explicitly link Mbed TLS library to trusted_storage." OFF )
2016-06-21 13:47:11 +00:00
# Warning string - created as a list for compatibility with CMake 2.8
2018-08-29 07:20:12 +00:00
set ( CTR_DRBG_128_BIT_KEY_WARN_L1 "**** WARNING! MBEDTLS_CTR_DRBG_USE_128_BIT_KEY defined!\n" )
set ( CTR_DRBG_128_BIT_KEY_WARN_L2 "**** Using 128-bit keys for CTR_DRBG limits the security of generated\n" )
set ( CTR_DRBG_128_BIT_KEY_WARN_L3 "**** keys and operations that use random values generated to 128-bit security\n" )
set ( CTR_DRBG_128_BIT_KEY_WARNING "${WARNING_BORDER}"
" $ { C T R _ D R B G _ 1 2 8 _ B I T _ K E Y _ W A R N _ L 1 } "
" $ { C T R _ D R B G _ 1 2 8 _ B I T _ K E Y _ W A R N _ L 2 } "
" $ { C T R _ D R B G _ 1 2 8 _ B I T _ K E Y _ W A R N _ L 3 } "
" $ { W A R N I N G _ B O R D E R } " )
2019-09-04 20:10:34 +00:00
# Python 3 is only needed here to check for configuration warnings.
2020-03-25 11:55:32 +00:00
if ( NOT CMAKE_VERSION VERSION_LESS 3.15.0 )
set ( Python3_FIND_STRATEGY LOCATION )
find_package ( Python3 COMPONENTS Interpreter )
if ( Python3_Interpreter_FOUND )
set ( MBEDTLS_PYTHON_EXECUTABLE ${ Python3_EXECUTABLE } )
endif ( )
else ( )
find_package ( PythonInterp 3 )
if ( PYTHONINTERP_FOUND )
set ( MBEDTLS_PYTHON_EXECUTABLE ${ PYTHON_EXECUTABLE } )
endif ( )
endif ( )
if ( MBEDTLS_PYTHON_EXECUTABLE )
2016-06-21 09:14:00 +00:00
2018-08-29 07:20:12 +00:00
# If 128-bit keys are configured for CTR_DRBG, display an appropriate warning
2021-05-28 07:42:25 +00:00
execute_process ( COMMAND ${ MBEDTLS_PYTHON_EXECUTABLE } ${ CMAKE_CURRENT_SOURCE_DIR } /scripts/config.py -f ${ CMAKE_CURRENT_SOURCE_DIR } /include/mbedtls/mbedtls_config.h get MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
2018-08-29 07:20:12 +00:00
R E S U L T _ V A R I A B L E r e s u l t )
if ( ${ result } EQUAL 0 )
message ( WARNING ${ CTR_DRBG_128_BIT_KEY_WARNING } )
endif ( )
2016-06-21 09:14:00 +00:00
endif ( )
2024-01-24 18:05:53 +00:00
# We now potentially need to link all executables against PThreads, if available
set ( CMAKE_THREAD_PREFER_PTHREAD TRUE )
set ( THREADS_PREFER_PTHREAD_FLAG TRUE )
find_package ( Threads )
2020-10-14 15:19:02 +00:00
# If this is the root project add longer list of available CMAKE_BUILD_TYPE values
2024-10-07 09:38:17 +00:00
if ( NOT MBEDTLS_AS_SUBPROJECT )
2020-10-14 15:19:02 +00:00
set ( CMAKE_BUILD_TYPE ${ CMAKE_BUILD_TYPE }
2023-11-23 14:07:43 +00:00
C A C H E S T R I N G " C h o o s e t h e t y p e o f b u i l d : N o n e D e b u g R e l e a s e C o v e r a g e A S a n A S a n D b g M e m S a n M e m S a n D b g C h e c k C h e c k F u l l T S a n T S a n D b g "
2020-10-14 15:19:02 +00:00
F O R C E )
endif ( )
2015-07-08 21:10:38 +00:00
2023-02-15 14:44:25 +00:00
# Make MBEDTLS_CONFIG_FILE and MBEDTLS_USER_CONFIG_FILE into PATHs
set ( MBEDTLS_CONFIG_FILE "" CACHE FILEPATH "Mbed TLS config file (overrides default)." )
set ( MBEDTLS_USER_CONFIG_FILE "" CACHE FILEPATH "Mbed TLS user config file (appended to default)." )
2023-01-12 13:59:34 +00:00
2018-03-21 11:12:47 +00:00
# Create a symbolic link from ${base_name} in the binary directory
# to the corresponding path in the source directory.
2022-08-10 14:27:14 +00:00
# Note: Copies the file(s) on Windows.
2018-03-21 11:12:47 +00:00
function ( link_to_source base_name )
2022-08-10 14:27:14 +00:00
set ( link "${CMAKE_CURRENT_BINARY_DIR}/${base_name}" )
set ( target "${CMAKE_CURRENT_SOURCE_DIR}/${base_name}" )
2018-03-21 11:12:47 +00:00
2022-07-20 10:09:17 +00:00
# Linking to non-existent file is not desirable. At best you will have a
2022-07-12 13:55:01 +00:00
# dangling link, but when building in tree, this can create a symbolic link
# to itself.
if ( EXISTS ${ target } AND NOT EXISTS ${ link } )
2018-03-21 11:12:47 +00:00
if ( CMAKE_HOST_UNIX )
2022-08-10 14:27:14 +00:00
execute_process ( COMMAND ln -s ${ target } ${ link }
R E S U L T _ V A R I A B L E r e s u l t
E R R O R _ V A R I A B L E o u t p u t )
if ( NOT ${ result } EQUAL 0 )
message ( FATAL_ERROR "Could not create symbolic link for: ${target} --> ${output}" )
endif ( )
2018-03-21 11:12:47 +00:00
else ( )
2018-06-07 10:55:50 +00:00
if ( IS_DIRECTORY ${ target } )
2022-08-10 14:27:14 +00:00
file ( GLOB_RECURSE files FOLLOW_SYMLINKS LIST_DIRECTORIES false RELATIVE ${ target } "${target}/*" )
foreach ( file IN LISTS files )
configure_file ( "${target}/${file}" "${link}/${file}" COPYONLY )
endforeach ( file )
2018-06-07 10:55:50 +00:00
else ( )
2022-08-10 14:27:14 +00:00
configure_file ( ${ target } ${ link } COPYONLY )
2018-06-07 10:55:50 +00:00
endif ( )
2018-03-21 11:12:47 +00:00
endif ( )
endif ( )
endfunction ( link_to_source )
2021-10-19 17:37:04 +00:00
# Get the filename without the final extension (i.e. convert "a.b.c" to "a.b")
function ( get_name_without_last_ext dest_var full_name )
# Split into a list on '.' (but a cmake list is just a ';'-separated string)
string ( REPLACE "." ";" ext_parts "${full_name}" )
# Remove the last item if there are more than one
list ( LENGTH ext_parts ext_parts_len )
if ( ${ ext_parts_len } GREATER "1" )
math ( EXPR ext_parts_last_item "${ext_parts_len} - 1" )
list ( REMOVE_AT ext_parts ${ ext_parts_last_item } )
endif ( )
# Convert back to a string by replacing separators with '.'
string ( REPLACE ";" "." no_ext_name "${ext_parts}" )
# Copy into the desired variable
set ( ${ dest_var } ${ no_ext_name } PARENT_SCOPE )
endfunction ( get_name_without_last_ext )
2020-08-18 18:59:46 +00:00
include ( CheckCCompilerFlag )
2022-05-10 16:26:47 +00:00
set ( CMAKE_C_EXTENSIONS OFF )
2020-09-03 08:21:30 +00:00
set ( CMAKE_C_STANDARD 99 )
2024-10-07 14:17:07 +00:00
function ( set_base_compile_options target )
if ( CMAKE_COMPILER_IS_GNU )
set_gnu_base_compile_options ( ${ target } )
2024-10-09 08:01:46 +00:00
elseif ( CMAKE_COMPILER_IS_CLANG )
set_clang_base_compile_options ( ${ target } )
2024-10-09 12:54:43 +00:00
elseif ( CMAKE_COMPILER_IS_IAR )
set_iar_base_compile_options ( ${ target } )
elseif ( CMAKE_COMPILER_IS_MSVC )
set_msvc_base_compile_options ( ${ target } )
2024-10-07 14:17:07 +00:00
endif ( )
endfunction ( set_base_compile_options )
function ( set_gnu_base_compile_options target )
2015-07-19 14:00:04 +00:00
# some warnings we want are not available with old GCC versions
# note: starting with CMake 2.8 we could use CMAKE_C_COMPILER_VERSION
execute_process ( COMMAND ${ CMAKE_C_COMPILER } -dumpversion
O U T P U T _ V A R I A B L E G C C _ V E R S I O N )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wall -Wextra -Wwrite-strings -Wmissing-prototypes )
2020-12-09 14:34:47 +00:00
if ( GCC_VERSION VERSION_GREATER 3.0 OR GCC_VERSION VERSION_EQUAL 3.0 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wformat=2 -Wno-format-nonliteral )
2020-12-09 14:34:47 +00:00
endif ( )
2019-07-02 18:22:11 +00:00
if ( GCC_VERSION VERSION_GREATER 4.3 OR GCC_VERSION VERSION_EQUAL 4.3 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wvla )
2019-07-02 18:22:11 +00:00
endif ( )
2015-07-19 14:00:04 +00:00
if ( GCC_VERSION VERSION_GREATER 4.5 OR GCC_VERSION VERSION_EQUAL 4.5 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wlogical-op )
2015-07-19 14:00:04 +00:00
endif ( )
2015-08-27 21:00:49 +00:00
if ( GCC_VERSION VERSION_GREATER 4.8 OR GCC_VERSION VERSION_EQUAL 4.8 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wshadow )
2020-07-03 03:41:38 +00:00
endif ( )
if ( GCC_VERSION VERSION_GREATER 5.0 )
2020-08-18 18:59:46 +00:00
CHECK_C_COMPILER_FLAG ( "-Wformat-signedness" C_COMPILER_SUPPORTS_WFORMAT_SIGNEDNESS )
if ( C_COMPILER_SUPPORTS_WFORMAT_SIGNEDNESS )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wformat-signedness )
2020-08-18 18:59:46 +00:00
endif ( )
endif ( )
2020-12-09 14:34:47 +00:00
if ( GCC_VERSION VERSION_GREATER 7.0 OR GCC_VERSION VERSION_EQUAL 7.0 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Wformat-overflow=2 -Wformat-truncation )
2020-12-09 14:34:47 +00:00
endif ( )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Release > :-O2> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Debug > :-O0 -g3> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Coverage > :-O0 -g3 --coverage> )
2024-10-08 15:53:13 +00:00
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_COVERAGE "--coverage" )
2024-10-15 10:03:26 +00:00
# Old GCC versions hit a performance problem with test_suite_pkwrite
# "Private keey write check EC" tests when building with Asan+UBSan
# and -O3: those tests take more than 100x time than normal, with
# test_suite_pkwrite taking >3h on the CI. Observed with GCC 5.4 on
# Ubuntu 16.04 x86_64 and GCC 6.5 on Ubuntu 18.04 x86_64.
# GCC 7.5 and above on Ubuntu 18.04 appear fine.
2024-10-16 11:28:44 +00:00
# To avoid the performance problem, we use -O2 when GCC version is lower than 7.0.
# It doesn't slow down much even with modern compiler versions.
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASan > :-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all> )
2024-10-16 11:28:44 +00:00
if ( GCC_VERSION VERSION_LESS 7.0 )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASan > :-O2> )
2024-10-16 11:28:44 +00:00
else ( )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASan > :-O3> )
2024-10-16 11:28:44 +00:00
endif ( )
2024-10-08 15:53:13 +00:00
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_ASAN "-fsanitize=address -fsanitize=undefined" )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASanDbg > :-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls> )
2024-10-08 15:53:13 +00:00
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_ASANDBG "-fsanitize=address -fsanitize=undefined" )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:TSan > :-fsanitize=thread -O3> )
2024-10-08 15:53:13 +00:00
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_TSAN "-fsanitize=thread" )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:TSanDbg > :-fsanitize=thread -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls> )
2024-10-08 15:53:13 +00:00
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_TSANDBG "-fsanitize=thread" )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Check > :-Os> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:CheckFull > :-Os -Wcast-qual> )
2024-10-08 07:24:31 +00:00
if ( MBEDTLS_FATAL_WARNINGS )
2024-10-07 14:17:07 +00:00
target_compile_options ( ${ target } PRIVATE -Werror )
2024-10-08 07:24:31 +00:00
endif ( MBEDTLS_FATAL_WARNINGS )
2024-10-07 14:17:07 +00:00
endfunction ( set_gnu_base_compile_options )
2013-11-28 16:20:04 +00:00
2024-10-09 08:01:46 +00:00
function ( set_clang_base_compile_options target )
target_compile_options ( ${ target } PRIVATE -Wall -Wextra -Wwrite-strings -Wmissing-prototypes -Wpointer-arith -Wimplicit-fallthrough -Wshadow -Wvla -Wformat=2 -Wno-format-nonliteral )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Release > :-O2> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Debug > :-O0 -g3> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Coverage > :-O0 -g3 --coverage> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_COVERAGE "--coverage" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASan > :-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O3> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_ASAN "-fsanitize=address -fsanitize=undefined" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:ASanDbg > :-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_ASANDBG "-fsanitize=address -fsanitize=undefined" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:MemSan > :-fsanitize=memory> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_MEMSAN "-fsanitize=memory" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:MemSanDbg > :-fsanitize=memory -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls -fsanitize-memory-track-origins=2> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_MEMSANDBG "-fsanitize=memory" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:TSan > :-fsanitize=thread -O3> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_TSAN "-fsanitize=thread" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:TSanDbg > :-fsanitize=thread -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls> )
set_target_properties ( ${ target } PROPERTIES LINK_FLAGS_TSANDBG "-fsanitize=thread" )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Check > :-Os> )
2024-10-08 07:24:31 +00:00
if ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 08:01:46 +00:00
target_compile_options ( ${ target } PRIVATE -Werror )
2024-10-08 07:24:31 +00:00
endif ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 08:01:46 +00:00
endfunction ( set_clang_base_compile_options )
2013-12-30 16:56:23 +00:00
2024-10-09 12:54:43 +00:00
function ( set_iar_base_compile_options target )
target_compile_options ( ${ target } PRIVATE --warn_about_c_style_casts )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Release > :-Ohz> )
target_compile_options ( ${ target } PRIVATE $< $<CONFIG:Debug > :--debug -On> )
2024-10-08 07:24:31 +00:00
if ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 12:54:43 +00:00
target_compile_options ( ${ target } PRIVATE --warnings_are_errors )
2024-10-08 07:24:31 +00:00
endif ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 12:54:43 +00:00
endfunction ( set_iar_base_compile_options )
2018-05-23 15:55:16 +00:00
2024-10-09 12:54:43 +00:00
function ( set_msvc_base_compile_options target )
2021-12-27 21:41:21 +00:00
# Strictest warnings, UTF-8 source and execution charset
2024-10-09 12:54:43 +00:00
target_compile_options ( ${ target } PRIVATE /W3 /utf-8 )
2015-07-01 15:06:28 +00:00
2024-10-08 07:24:31 +00:00
if ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 12:54:43 +00:00
target_compile_options ( ${ target } PRIVATE /WX )
2024-10-08 07:24:31 +00:00
endif ( MBEDTLS_FATAL_WARNINGS )
2024-10-09 12:54:43 +00:00
endfunction ( set_msvc_base_compile_options )
2020-04-03 07:42:37 +00:00
2024-10-23 12:22:03 +00:00
function ( set_config_files_compile_definitions target )
# Pass-through MBEDTLS_CONFIG_FILE, MBEDTLS_USER_CONFIG_FILE,
2024-11-14 15:20:00 +00:00
# TF_PSA_CRYPTO_CONFIG_FILE and TF_PSA_CRYPTO_USER_CONFIG_FILE
2024-10-23 12:22:03 +00:00
if ( MBEDTLS_CONFIG_FILE )
target_compile_definitions ( ${ target }
P U B L I C M B E D T L S _ C O N F I G _ F I L E = " $ { M B E D T L S _ C O N F I G _ F I L E } " )
endif ( )
if ( MBEDTLS_USER_CONFIG_FILE )
target_compile_definitions ( ${ target }
P U B L I C M B E D T L S _ U S E R _ C O N F I G _ F I L E = " $ { M B E D T L S _ U S E R _ C O N F I G _ F I L E } " )
endif ( )
2024-11-14 15:20:00 +00:00
if ( TF_PSA_CRYPTO_CONFIG_FILE )
2024-10-23 12:22:03 +00:00
target_compile_definitions ( ${ target }
2024-11-14 14:56:47 +00:00
P U B L I C T F _ P S A _ C R Y P T O _ C O N F I G _ F I L E = " $ { T F _ P S A _ C R Y P T O _ C O N F I G _ F I L E } " )
2024-10-23 12:22:03 +00:00
endif ( )
2024-11-14 15:20:00 +00:00
if ( TF_PSA_CRYPTO_USER_CONFIG_FILE )
2024-10-23 12:22:03 +00:00
target_compile_definitions ( ${ target }
2024-11-14 14:56:47 +00:00
P U B L I C T F _ P S A _ C R Y P T O _ U S E R _ C O N F I G _ F I L E = " $ { T F _ P S A _ C R Y P T O _ U S E R _ C O N F I G _ F I L E } " )
2024-10-23 12:22:03 +00:00
endif ( )
endfunction ( set_config_files_compile_definitions )
2024-06-06 20:12:06 +00:00
if ( CMAKE_BUILD_TYPE STREQUAL "Check" AND TEST_CPP )
set ( CMAKE_CXX_STANDARD 11 )
set ( CMAKE_CXX_STANDARD_REQUIRED ON )
set ( CMAKE_CXX_EXTENSIONS OFF )
if ( CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU )
set ( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pedantic" )
endif ( )
endif ( )
2024-07-25 12:52:19 +00:00
if ( NOT EXISTS "${MBEDTLS_FRAMEWORK_DIR}/CMakeLists.txt" )
2024-10-28 14:05:23 +00:00
if ( EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/.git/" )
message ( FATAL_ERROR "${MBEDTLS_FRAMEWORK_DIR}/CMakeLists.txt not found (and does appear to be a git checkout). Run `git submodule update --init` from the source tree to fetch the submodule contents." )
2024-09-17 14:12:11 +00:00
else ( )
2024-10-28 14:05:23 +00:00
message ( FATAL_ERROR "${MBEDTLS_FRAMEWORK_DIR}/CMakeLists.txt not found (and does not appear to be a git checkout). Please ensure you have downloaded the right archive from the release page on GitHub." )
2024-09-17 14:12:11 +00:00
endif ( )
2024-03-04 15:25:14 +00:00
endif ( )
2024-02-29 17:19:56 +00:00
add_subdirectory ( framework )
2019-04-08 16:00:34 +00:00
add_subdirectory ( include )
2024-11-05 08:39:43 +00:00
set ( TF_PSA_CRYPTO_TARGET_PREFIX ${ MBEDTLS_TARGET_PREFIX } CACHE STRING "" )
set ( TF_PSA_CRYPTO_FATAL_WARNINGS ${ MBEDTLS_FATAL_WARNINGS } CACHE BOOL "" )
set ( USE_STATIC_TF_PSA_CRYPTO_LIBRARY ${ USE_STATIC_MBEDTLS_LIBRARY } CACHE BOOL "" )
set ( USE_SHARED_TF_PSA_CRYPTO_LIBRARY ${ USE_SHARED_MBEDTLS_LIBRARY } CACHE BOOL "" )
2024-07-01 16:33:24 +00:00
add_subdirectory ( tf-psa-crypto )
2019-01-21 17:26:19 +00:00
2024-11-15 14:05:34 +00:00
set ( tfpsacrypto_target "${TF_PSA_CRYPTO_TARGET_PREFIX}tfpsacrypto" )
if ( USE_STATIC_MBEDTLS_LIBRARY )
set ( tfpsacrypto_static_target ${ tfpsacrypto_target } )
endif ( )
if ( USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY )
string ( APPEND tfpsacrypto_static_target "_static" )
endif ( )
2024-11-05 11:21:26 +00:00
set ( tf_psa_crypto_library_targets
2024-11-15 14:05:34 +00:00
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } t f p s a c r y p t o
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } b u i l t i n
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } e v e r e s t
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } p 2 5 6 m )
2024-11-05 11:21:26 +00:00
if ( USE_STATIC_MBEDTLS_LIBRARY AND USE_SHARED_MBEDTLS_LIBRARY )
list ( APPEND tf_psa_crypto_library_targets
2024-11-15 14:05:34 +00:00
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } t f p s a c r y p t o _ s t a t i c
$ { T F _ P S A _ C R Y P T O _ T A R G E T _ P R E F I X } b u i l t i n _ s t a t i c )
2024-11-05 11:21:26 +00:00
endif ( )
foreach ( target IN LISTS tf_psa_crypto_library_targets )
if ( NOT TARGET ${ target } )
message ( FATAL_ERROR "TF-PSA-Crypto target ${target} does not exist." )
endif ( )
endforeach ( target )
2009-06-28 21:50:27 +00:00
add_subdirectory ( library )
2011-07-27 16:52:28 +00:00
2024-01-09 19:10:05 +00:00
add_subdirectory ( pkgconfig )
2020-06-26 14:37:02 +00:00
#
2024-10-31 15:36:05 +00:00
# The C files in framework/tests/src directory contain test code shared among test suites
2020-06-26 14:37:02 +00:00
# and programs. This shared test code is compiled and linked to test suites and
# programs objects as a set of compiled objects. The compiled objects are NOT
# built into a library that the test suite and program objects would link
2024-10-25 15:34:23 +00:00
# against as they link against the tfpsacrypto, mbedx509 and mbedtls libraries.
2020-06-26 14:37:02 +00:00
# The reason is that such library is expected to have mutual dependencies with
# the aforementioned libraries and that there is as of today no portable way of
# handling such dependencies (only toolchain specific solutions).
#
# Thus the below definition of the `mbedtls_test` CMake library of objects
# target. This library of objects is used by tests and programs CMake files
# to define the test executables.
#
2020-06-19 09:27:26 +00:00
if ( ENABLE_TESTING OR ENABLE_PROGRAMS )
2024-12-06 09:09:33 +00:00
file ( GLOB MBEDTLS_TEST_FILES
$ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / s r c / * . c
$ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / s r c / d r i v e r s / * . c )
add_library ( mbedtls_test OBJECT ${ MBEDTLS_TEST_FILES } )
set_base_compile_options ( mbedtls_test )
if ( GEN_FILES )
add_custom_command (
O U T P U T
$ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / s r c / t e s t _ k e y s . h
C O M M A N D
" $ { M B E D T L S _ P Y T H O N _ E X E C U T A B L E } "
" $ { M B E D T L S _ F R A M E W O R K _ D I R } / s c r i p t s / g e n e r a t e _ t e s t _ k e y s . p y "
" - - o u t p u t "
" $ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / s r c / t e s t _ k e y s . h "
D E P E N D S
$ { M B E D T L S _ F R A M E W O R K _ D I R } / s c r i p t s / g e n e r a t e _ t e s t _ k e y s . p y
)
add_custom_target ( mbedtls_test_keys_header
D E P E N D S $ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / s r c / t e s t _ k e y s . h )
add_dependencies ( mbedtls_test mbedtls_test_keys_header )
endif ( )
target_include_directories ( mbedtls_test
P R I V A T E $ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / i n c l u d e
P R I V A T E t e s t s / i n c l u d e
P R I V A T E i n c l u d e
P R I V A T E t f - p s a - c r y p t o / i n c l u d e
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / b u i l t i n / i n c l u d e
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / e v e r e s t / i n c l u d e
P R I V A T E l i b r a r y
P R I V A T E t f - p s a - c r y p t o / c o r e
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / b u i l t i n / s r c )
# Request C11, needed for memory poisoning tests
set_target_properties ( mbedtls_test PROPERTIES C_STANDARD 11 )
set_config_files_compile_definitions ( mbedtls_test )
2022-10-28 03:49:33 +00:00
file ( GLOB MBEDTLS_TEST_HELPER_FILES
2024-12-06 19:39:02 +00:00
t e s t s / s r c / * . c t e s t s / s r c / t e s t _ h e l p e r s / * . c )
2022-10-28 03:49:33 +00:00
add_library ( mbedtls_test_helpers OBJECT ${ MBEDTLS_TEST_HELPER_FILES } )
2024-10-07 14:17:07 +00:00
set_base_compile_options ( mbedtls_test_helpers )
2024-11-22 16:14:45 +00:00
if ( GEN_FILES )
add_custom_command (
O U T P U T
2024-12-06 19:39:02 +00:00
$ { C M A K E _ C U R R E N T _ S O U R C E _ D I R } / t e s t s / s r c / t e s t _ c e r t s . h
2024-11-22 16:14:45 +00:00
C O M M A N D
" $ { M B E D T L S _ P Y T H O N _ E X E C U T A B L E } "
" $ { M B E D T L S _ F R A M E W O R K _ D I R } / s c r i p t s / g e n e r a t e _ t e s t _ c e r t _ m a c r o s . p y "
" - - o u t p u t "
2024-12-06 19:39:02 +00:00
" $ { C M A K E _ C U R R E N T _ S O U R C E _ D I R } / t e s t s / s r c / t e s t _ c e r t s . h "
2024-11-22 16:14:45 +00:00
D E P E N D S
$ { M B E D T L S _ F R A M E W O R K _ D I R } / s c r i p t s / g e n e r a t e _ t e s t _ c e r t _ m a c r o s . p y
)
add_custom_target ( mbedtls_test_certs_header
2024-12-06 19:39:02 +00:00
D E P E N D S $ { C M A K E _ C U R R E N T _ S O U R C E _ D I R } / t e s t s / s r c / t e s t _ c e r t s . h )
2024-11-22 16:14:45 +00:00
add_dependencies ( mbedtls_test_helpers mbedtls_test_certs_header )
endif ( )
2022-10-28 03:49:33 +00:00
target_include_directories ( mbedtls_test_helpers
2024-12-06 19:39:02 +00:00
P R I V A T E $ { M B E D T L S _ F R A M E W O R K _ D I R } / t e s t s / i n c l u d e
P R I V A T E t e s t s / i n c l u d e
P R I V A T E i n c l u d e
P R I V A T E t f - p s a - c r y p t o / i n c l u d e
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / b u i l t i n / i n c l u d e
P R I V A T E l i b r a r y
P R I V A T E t f - p s a - c r y p t o / c o r e
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / b u i l t i n / s r c
P R I V A T E t f - p s a - c r y p t o / d r i v e r s / e v e r e s t / i n c l u d e )
2023-01-12 13:59:34 +00:00
2024-10-23 12:22:03 +00:00
set_config_files_compile_definitions ( mbedtls_test_helpers )
2020-06-19 09:27:26 +00:00
endif ( )
2014-03-26 12:27:51 +00:00
if ( ENABLE_PROGRAMS )
2024-09-24 17:09:57 +00:00
set ( ssl_opt_target "${MBEDTLS_TARGET_PREFIX}ssl-opt" )
add_custom_target ( ${ ssl_opt_target } )
2015-06-25 07:20:03 +00:00
add_subdirectory ( programs )
2014-03-26 12:27:51 +00:00
endif ( )
2011-01-05 15:30:32 +00:00
2024-10-23 07:23:46 +00:00
ADD_CUSTOM_TARGET ( ${ MBEDTLS_TARGET_PREFIX } mbedtls-apidoc
2018-01-19 15:21:11 +00:00
C O M M A N D d o x y g e n m b e d t l s . d o x y f i l e
W O R K I N G _ D I R E C T O R Y $ { C M A K E _ C U R R E N T _ S O U R C E _ D I R } / d o x y g e n )
2013-09-07 14:52:42 +00:00
2014-04-30 14:31:54 +00:00
if ( ENABLE_TESTING )
2015-07-01 14:59:56 +00:00
enable_testing ( )
add_subdirectory ( tests )
# additional convenience targets for Unix only
2024-10-07 10:34:42 +00:00
if ( UNIX AND ( NOT MBEDTLS_AS_SUBPROJECT ) )
2022-12-08 21:18:31 +00:00
# For coverage testing:
# 1. Build with:
# cmake -D CMAKE_BUILD_TYPE=Coverage /path/to/source && make
# 2. Run the relevant tests for the part of the code you're interested in.
# For the reference coverage measurement, see
# tests/scripts/basic-build-test.sh
# 3. Run scripts/lcov.sh to generate an HTML report.
2015-07-01 14:59:56 +00:00
ADD_CUSTOM_TARGET ( lcov
2022-11-30 16:52:01 +00:00
C O M M A N D s c r i p t s / l c o v . s h
2015-07-01 14:59:56 +00:00
)
ADD_CUSTOM_TARGET ( memcheck
C O M M A N D s e d - i . b a k s + / u s r / b i n / v a l g r i n d + ` w h i c h v a l g r i n d ` + D a r t C o n f i g u r a t i o n . t c l
C O M M A N D c t e s t - O m e m c h e c k . l o g - D E x p e r i m e n t a l M e m C h e c k
C O M M A N D t a i l - n 1 m e m c h e c k . l o g | g r e p ' M e m o r y c h e c k i n g r e s u l t s : ' > / d e v / n u l l
C O M M A N D r m - f m e m c h e c k . l o g
C O M M A N D m v D a r t C o n f i g u r a t i o n . t c l . b a k D a r t C o n f i g u r a t i o n . t c l
)
2024-10-07 10:34:42 +00:00
endif ( )
2018-03-21 11:12:47 +00:00
2019-04-28 05:51:37 +00:00
# Make scripts needed for testing available in an out-of-source build.
if ( NOT ${ CMAKE_CURRENT_BINARY_DIR } STREQUAL ${ CMAKE_CURRENT_SOURCE_DIR } )
link_to_source ( scripts )
# Copy (don't link) DartConfiguration.tcl, needed for memcheck, to
# keep things simple with the sed commands in the memcheck target.
configure_file ( ${ CMAKE_CURRENT_SOURCE_DIR } /DartConfiguration.tcl
$ { C M A K E _ C U R R E N T _ B I N A R Y _ D I R } / D a r t C o n f i g u r a t i o n . t c l C O P Y O N L Y )
endif ( )
2018-03-21 11:12:47 +00:00
endif ( )
2021-03-25 16:03:25 +00:00
2021-12-07 20:45:55 +00:00
if ( NOT DISABLE_PACKAGE_CONFIG_AND_INSTALL )
configure_package_config_file (
" c m a k e / M b e d T L S C o n f i g . c m a k e . i n "
" c m a k e / M b e d T L S C o n f i g . c m a k e "
I N S T A L L _ D E S T I N A T I O N " c m a k e " )
write_basic_package_version_file (
" c m a k e / M b e d T L S C o n f i g V e r s i o n . c m a k e "
C O M P A T I B I L I T Y S a m e M a j o r V e r s i o n
2024-09-03 16:36:30 +00:00
V E R S I O N 4 . 0 . 0 )
2021-12-07 20:45:55 +00:00
install (
F I L E S " $ { C M A K E _ C U R R E N T _ B I N A R Y _ D I R } / c m a k e / M b e d T L S C o n f i g . c m a k e "
" $ { C M A K E _ C U R R E N T _ B I N A R Y _ D I R } / c m a k e / M b e d T L S C o n f i g V e r s i o n . c m a k e "
2022-11-19 18:34:01 +00:00
D E S T I N A T I O N " $ { C M A K E _ I N S T A L L _ L I B D I R } / c m a k e / M b e d T L S " )
2021-12-07 20:45:55 +00:00
export (
E X P O R T M b e d T L S T a r g e t s
N A M E S P A C E M b e d T L S : :
F I L E " c m a k e / M b e d T L S T a r g e t s . c m a k e " )
install (
E X P O R T M b e d T L S T a r g e t s
N A M E S P A C E M b e d T L S : :
2022-11-19 18:34:01 +00:00
D E S T I N A T I O N " $ { C M A K E _ I N S T A L L _ L I B D I R } / c m a k e / M b e d T L S "
2021-12-07 20:45:55 +00:00
F I L E " M b e d T L S T a r g e t s . c m a k e " )
if ( CMAKE_VERSION VERSION_GREATER 3.15 OR CMAKE_VERSION VERSION_EQUAL 3.15 )
# Do not export the package by default
cmake_policy ( SET CMP0090 NEW )
# Make this package visible to the system
export ( PACKAGE MbedTLS )
endif ( )
2021-03-25 16:03:25 +00:00
endif ( )