blob: 9c3c86ce139a34007f0d2cbf8927fb2c2624661e [file] [log] [blame]
Paul Bakker367dae42009-06-28 21:50:27 +00001cmake_minimum_required(VERSION 2.6)
Andrzej Kurek0211c322018-03-15 05:16:24 -04002if(TEST_CPP)
Andrzej Kurek037ec4b2018-06-26 06:57:55 -04003 project("mbed TLS" C CXX)
Andrzej Kurek0211c322018-03-15 05:16:24 -04004else()
Andrzej Kurek037ec4b2018-06-26 06:57:55 -04005 project("mbed TLS" C)
Andrzej Kurek0211c322018-03-15 05:16:24 -04006endif()
Paul Bakker367dae42009-06-28 21:50:27 +00007
Ashley Duncand85a7e92019-04-29 20:35:06 +12008# Set the project root directory.
9set(MBEDTLS_DIR ${CMAKE_CURRENT_SOURCE_DIR})
10
Gilles Peskine6bbe7832020-02-26 19:13:28 +010011option(USE_PKCS11_HELPER_LIBRARY "Build mbed TLS with the pkcs11-helper library." OFF)
Gilles Peskine5bb8bec2020-02-26 19:11:43 +010012option(ENABLE_ZLIB_SUPPORT "Build mbed TLS with zlib library." OFF)
13
Manuel Pégourié-Gonnard0b4e2ac2015-07-08 22:10:38 +010014option(ENABLE_PROGRAMS "Build mbed TLS programs." ON)
Manuel Pégourié-Gonnard58719102015-07-09 09:19:47 +010015
Simon Butcher1ceab6e2016-06-21 10:14:00 +010016option(UNSAFE_BUILD "Allow unsafe builds. These builds ARE NOT SECURE." OFF)
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +020017option(MBEDTLS_FATAL_WARNINGS "Compiler warnings treated as errors" ON)
Manuel Pégourié-Gonnard58719102015-07-09 09:19:47 +010018
Azim Khan45b79cf2018-05-23 16:55:16 +010019string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
20string(REGEX MATCH "GNU" CMAKE_COMPILER_IS_GNU "${CMAKE_C_COMPILER_ID}")
21string(REGEX MATCH "IAR" CMAKE_COMPILER_IS_IAR "${CMAKE_C_COMPILER_ID}")
22string(REGEX MATCH "MSVC" CMAKE_COMPILER_IS_MSVC "${CMAKE_C_COMPILER_ID}")
23
Manuel Pégourié-Gonnard58719102015-07-09 09:19:47 +010024# the test suites currently have compile errors with MSVC
Azim Khan45b79cf2018-05-23 16:55:16 +010025if(CMAKE_COMPILER_IS_MSVC)
Manuel Pégourié-Gonnard58719102015-07-09 09:19:47 +010026 option(ENABLE_TESTING "Build mbed TLS tests." OFF)
27else()
28 option(ENABLE_TESTING "Build mbed TLS tests." ON)
29endif()
Manuel Pégourié-Gonnard0b4e2ac2015-07-08 22:10:38 +010030
Simon Butcher45103f32016-06-21 14:47:11 +010031# Warning string - created as a list for compatibility with CMake 2.8
32set(WARNING_BORDER "*******************************************************\n")
33set(NULL_ENTROPY_WARN_L1 "**** WARNING! MBEDTLS_TEST_NULL_ENTROPY defined!\n")
34set(NULL_ENTROPY_WARN_L2 "**** THIS BUILD HAS NO DEFINED ENTROPY SOURCES\n")
35set(NULL_ENTROPY_WARN_L3 "**** AND IS *NOT* SUITABLE FOR PRODUCTION USE\n")
36
37set(NULL_ENTROPY_WARNING "${WARNING_BORDER}"
38 "${NULL_ENTROPY_WARN_L1}"
39 "${NULL_ENTROPY_WARN_L2}"
40 "${NULL_ENTROPY_WARN_L3}"
41 "${WARNING_BORDER}")
42
Nir Sonnenscheinb7ebbca2018-08-29 10:20:12 +030043set(CTR_DRBG_128_BIT_KEY_WARN_L1 "**** WARNING! MBEDTLS_CTR_DRBG_USE_128_BIT_KEY defined!\n")
44set(CTR_DRBG_128_BIT_KEY_WARN_L2 "**** Using 128-bit keys for CTR_DRBG limits the security of generated\n")
45set(CTR_DRBG_128_BIT_KEY_WARN_L3 "**** keys and operations that use random values generated to 128-bit security\n")
46
47set(CTR_DRBG_128_BIT_KEY_WARNING "${WARNING_BORDER}"
48 "${CTR_DRBG_128_BIT_KEY_WARN_L1}"
49 "${CTR_DRBG_128_BIT_KEY_WARN_L2}"
50 "${CTR_DRBG_128_BIT_KEY_WARN_L3}"
51 "${WARNING_BORDER}")
52
Gilles Peskine97409292019-09-04 22:10:34 +020053# Python 3 is only needed here to check for configuration warnings.
okhowang(王沛文)3c1b0902020-03-25 19:55:32 +080054if(NOT CMAKE_VERSION VERSION_LESS 3.15.0)
55 set(Python3_FIND_STRATEGY LOCATION)
56 find_package(Python3 COMPONENTS Interpreter)
57 if(Python3_Interpreter_FOUND)
58 set(MBEDTLS_PYTHON_EXECUTABLE ${Python3_EXECUTABLE})
59 endif()
60else()
61 find_package(PythonInterp 3)
62 if(PYTHONINTERP_FOUND)
63 set(MBEDTLS_PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE})
64 endif()
65endif()
66if(MBEDTLS_PYTHON_EXECUTABLE)
Simon Butcher1ceab6e2016-06-21 10:14:00 +010067
Nir Sonnenscheinb7ebbca2018-08-29 10:20:12 +030068 # If 128-bit keys are configured for CTR_DRBG, display an appropriate warning
okhowang(王沛文)3c1b0902020-03-25 19:55:32 +080069 execute_process(COMMAND ${MBEDTLS_PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/scripts/config.py -f ${CMAKE_CURRENT_SOURCE_DIR}/include/mbedtls/config.h get MBEDTLS_CTR_DRBG_USE_128_BIT_KEY
Nir Sonnenscheinb7ebbca2018-08-29 10:20:12 +030070 RESULT_VARIABLE result)
71 if(${result} EQUAL 0)
72 message(WARNING ${CTR_DRBG_128_BIT_KEY_WARNING})
73 endif()
74
Simon Butcher1ceab6e2016-06-21 10:14:00 +010075 # If NULL Entropy is configured, display an appropriate warning
okhowang(王沛文)3c1b0902020-03-25 19:55:32 +080076 execute_process(COMMAND ${MBEDTLS_PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/scripts/config.py -f ${CMAKE_CURRENT_SOURCE_DIR}/include/mbedtls/config.h get MBEDTLS_TEST_NULL_ENTROPY
Simon Butcher1ceab6e2016-06-21 10:14:00 +010077 RESULT_VARIABLE result)
78 if(${result} EQUAL 0)
Simon Butcher45103f32016-06-21 14:47:11 +010079 message(WARNING ${NULL_ENTROPY_WARNING})
80
Simon Butcher1ceab6e2016-06-21 10:14:00 +010081 if(NOT UNSAFE_BUILD)
82 message(FATAL_ERROR "\
83\n\
84Warning! You have enabled MBEDTLS_TEST_NULL_ENTROPY. \
85This option is not safe for production use and negates all security \
86It is intended for development use only. \
87\n\
88To confirm you want to build with this option, re-run cmake with the \
89option: \n\
90 cmake -DUNSAFE_BUILD=ON ")
91
92 return()
93 endif()
94 endif()
95endif()
96
Manuel Pégourié-Gonnard0b4e2ac2015-07-08 22:10:38 +010097set(CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE}
98 CACHE STRING "Choose the type of build: None Debug Release Coverage ASan ASanDbg MemSan MemSanDbg Check CheckFull"
99 FORCE)
100
Gilles Peskine84052572018-03-21 12:12:47 +0100101# Create a symbolic link from ${base_name} in the binary directory
102# to the corresponding path in the source directory.
103function(link_to_source base_name)
104 # Get OS dependent path to use in `execute_process`
Qixiang Xu7346b312019-02-21 14:55:13 +0800105 if (CMAKE_HOST_WIN32)
106 #mklink is an internal command of cmd.exe it can only work with \
107 string(REPLACE "/" "\\" link "${CMAKE_CURRENT_BINARY_DIR}/${base_name}")
108 string(REPLACE "/" "\\" target "${CMAKE_CURRENT_SOURCE_DIR}/${base_name}")
109 else()
110 set(link "${CMAKE_CURRENT_BINARY_DIR}/${base_name}")
111 set(target "${CMAKE_CURRENT_SOURCE_DIR}/${base_name}")
112 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100113
114 if (NOT EXISTS ${link})
115 if (CMAKE_HOST_UNIX)
116 set(command ln -s ${target} ${link})
117 else()
Darryl Greend75ee642018-06-07 11:55:50 +0100118 if (IS_DIRECTORY ${target})
119 set(command cmd.exe /c mklink /j ${link} ${target})
120 else()
Darryl Green2a1edac2018-06-08 10:07:32 +0100121 set(command cmd.exe /c mklink /h ${link} ${target})
Darryl Greend75ee642018-06-07 11:55:50 +0100122 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100123 endif()
124
125 execute_process(COMMAND ${command}
126 RESULT_VARIABLE result
127 ERROR_VARIABLE output)
128
129 if (NOT ${result} EQUAL 0)
130 message(FATAL_ERROR "Could not create symbolic link for: ${target} --> ${output}")
131 endif()
132 endif()
133endfunction(link_to_source)
134
Barry K. Nathancf975f52014-04-23 17:40:25 -0700135string(REGEX MATCH "Clang" CMAKE_COMPILER_IS_CLANG "${CMAKE_C_COMPILER_ID}")
Paul Bakker92bc8752013-12-30 17:56:23 +0100136
Azim Khan45b79cf2018-05-23 16:55:16 +0100137if(CMAKE_COMPILER_IS_GNU)
Manuel Pégourié-Gonnardbcb04602015-07-19 16:00:04 +0200138 # some warnings we want are not available with old GCC versions
139 # note: starting with CMake 2.8 we could use CMAKE_C_COMPILER_VERSION
140 execute_process(COMMAND ${CMAKE_C_COMPILER} -dumpversion
141 OUTPUT_VARIABLE GCC_VERSION)
Gilles Peskine85aba472019-07-02 20:03:01 +0200142 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wextra -Wwrite-strings")
Gilles Peskinebe517162019-07-02 20:22:11 +0200143 if (GCC_VERSION VERSION_GREATER 4.3 OR GCC_VERSION VERSION_EQUAL 4.3)
144 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wvla")
145 endif()
Manuel Pégourié-Gonnardbcb04602015-07-19 16:00:04 +0200146 if (GCC_VERSION VERSION_GREATER 4.5 OR GCC_VERSION VERSION_EQUAL 4.5)
147 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wlogical-op")
148 endif()
Manuel Pégourié-Gonnard824ba722015-08-27 23:00:49 +0200149 if (GCC_VERSION VERSION_GREATER 4.8 OR GCC_VERSION VERSION_EQUAL 4.8)
Kenneth Soerensen518d4352020-04-01 17:22:45 +0200150 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wshadow -Wformat-signedness")
Manuel Pégourié-Gonnard824ba722015-08-27 23:00:49 +0200151 endif()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200152 set(CMAKE_C_FLAGS_RELEASE "-O2")
153 set(CMAKE_C_FLAGS_DEBUG "-O0 -g3")
154 set(CMAKE_C_FLAGS_COVERAGE "-O0 -g3 --coverage")
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +0200155 set(CMAKE_C_FLAGS_ASAN "-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O3")
156 set(CMAKE_C_FLAGS_ASANDBG "-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls")
157 set(CMAKE_C_FLAGS_CHECK "-Os")
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200158 set(CMAKE_C_FLAGS_CHECKFULL "${CMAKE_C_FLAGS_CHECK} -Wcast-qual")
Azim Khan45b79cf2018-05-23 16:55:16 +0100159endif(CMAKE_COMPILER_IS_GNU)
Paul Bakker76f03112013-11-28 17:20:04 +0100160
Paul Bakker92bc8752013-12-30 17:56:23 +0100161if(CMAKE_COMPILER_IS_CLANG)
Gilles Peskinebe517162019-07-02 20:22:11 +0200162 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -Wextra -Wwrite-strings -Wpointer-arith -Wimplicit-fallthrough -Wshadow -Wvla")
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200163 set(CMAKE_C_FLAGS_RELEASE "-O2")
164 set(CMAKE_C_FLAGS_DEBUG "-O0 -g3")
165 set(CMAKE_C_FLAGS_COVERAGE "-O0 -g3 --coverage")
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +0200166 set(CMAKE_C_FLAGS_ASAN "-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O3")
167 set(CMAKE_C_FLAGS_ASANDBG "-fsanitize=address -fno-common -fsanitize=undefined -fno-sanitize-recover=all -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls")
168 set(CMAKE_C_FLAGS_MEMSAN "-fsanitize=memory -O3")
169 set(CMAKE_C_FLAGS_MEMSANDBG "-fsanitize=memory -O1 -g3 -fno-omit-frame-pointer -fno-optimize-sibling-calls -fsanitize-memory-track-origins=2")
170 set(CMAKE_C_FLAGS_CHECK "-Os")
Paul Bakker92bc8752013-12-30 17:56:23 +0100171endif(CMAKE_COMPILER_IS_CLANG)
172
Azim Khan45b79cf2018-05-23 16:55:16 +0100173if(CMAKE_COMPILER_IS_IAR)
174 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --warn_about_c_style_casts --warnings_are_errors -Ohz")
175endif(CMAKE_COMPILER_IS_IAR)
176
177if(CMAKE_COMPILER_IS_MSVC)
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +0200178 # Strictest warnings
Simon B9b3e3c42016-11-03 01:12:50 +0000179 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /W3")
Azim Khan45b79cf2018-05-23 16:55:16 +0100180endif(CMAKE_COMPILER_IS_MSVC)
Manuel Pégourié-Gonnard30830532015-07-01 17:06:28 +0200181
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +0200182if(MBEDTLS_FATAL_WARNINGS)
183 if(CMAKE_COMPILER_IS_MSVC)
184 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /WX")
185 endif(CMAKE_COMPILER_IS_MSVC)
186
187 if(CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU)
188 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror")
Carlos Gomes Martinhoe150c772020-04-21 22:15:01 +0200189 if(UNSAFE_BUILD)
190 set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wno-error=cpp")
191 set(CMAKE_C_FLAGS_ASAN "${CMAKE_C_FLAGS_ASAN} -Wno-error=cpp")
192 set(CMAKE_C_FLAGS_ASANDBG "${CMAKE_C_FLAGS_ASANDBG} -Wno-error=cpp")
193 endif(UNSAFE_BUILD)
Carlos Gomes Martinhoa5f0bd32020-04-03 09:42:37 +0200194 endif(CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNU)
195endif(MBEDTLS_FATAL_WARNINGS)
196
Paul Bakker396c52f2009-07-11 19:54:40 +0000197if(CMAKE_BUILD_TYPE STREQUAL "Coverage")
Azim Khan45b79cf2018-05-23 16:55:16 +0100198 if(CMAKE_COMPILER_IS_GNU OR CMAKE_COMPILER_IS_CLANG)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200199 set(CMAKE_SHARED_LINKER_FLAGS "--coverage")
Azim Khan45b79cf2018-05-23 16:55:16 +0100200 endif(CMAKE_COMPILER_IS_GNU OR CMAKE_COMPILER_IS_CLANG)
Paul Bakker396c52f2009-07-11 19:54:40 +0000201endif(CMAKE_BUILD_TYPE STREQUAL "Coverage")
Paul Bakker367dae42009-06-28 21:50:27 +0000202
Paul Bakker091e2872011-07-13 11:45:58 +0000203if(LIB_INSTALL_DIR)
204else()
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200205 set(LIB_INSTALL_DIR lib)
Paul Bakker091e2872011-07-13 11:45:58 +0000206endif()
207
Christoph M. Wintersteiger6ea2dea12019-01-21 17:26:19 +0000208include_directories(include/)
Darryl Greend9eee3b2018-11-02 10:45:36 +0000209include_directories(library/)
Paul Bakker367dae42009-06-28 21:50:27 +0000210
Gilles Peskine5bb8bec2020-02-26 19:11:43 +0100211if(ENABLE_ZLIB_SUPPORT)
212 find_package(ZLIB)
213
214 if(ZLIB_FOUND)
215 include_directories(${ZLIB_INCLUDE_DIR})
216 endif(ZLIB_FOUND)
217endif(ENABLE_ZLIB_SUPPORT)
218
Christoph M. Wintersteiger7b747fc2019-04-08 17:00:34 +0100219add_subdirectory(include)
220
Christoph M. Wintersteiger62dddd02018-12-14 13:07:50 +0000221add_subdirectory(3rdparty)
Ronald Cronf19f3122020-05-25 10:26:37 +0200222include_directories(${thirdparty_inc_public})
Christoph M. Wintersteiger6ea2dea12019-01-21 17:26:19 +0000223include_directories(${thirdparty_inc})
224list(APPEND libs ${thirdparty_lib})
225add_definitions(${thirdparty_def})
226
Paul Bakker367dae42009-06-28 21:50:27 +0000227add_subdirectory(library)
Paul Bakker2015eac2011-07-27 16:52:28 +0000228
Paul Bakkerdf5024c2014-03-26 13:27:51 +0100229if(ENABLE_PROGRAMS)
Manuel Pégourié-Gonnard216a1832015-06-25 09:20:03 +0200230 add_subdirectory(programs)
Paul Bakkerdf5024c2014-03-26 13:27:51 +0100231endif()
Paul Bakkerccba9bc2011-01-05 15:30:32 +0000232
Manuel Pégourié-Gonnardc9901892016-01-12 13:59:39 +0000233ADD_CUSTOM_TARGET(apidoc
Krzysztof Stachowiaka0188d62018-01-19 16:21:11 +0100234 COMMAND doxygen mbedtls.doxyfile
235 WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/doxygen)
Manuel Pégourié-Gonnard7669f282013-09-07 16:52:42 +0200236
Paul Bakker27f1cae2014-04-30 16:31:54 +0200237if(ENABLE_TESTING)
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200238 enable_testing()
Manuel Pégourié-Gonnardc8293b22015-06-25 09:22:25 +0200239
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200240 add_subdirectory(tests)
Manuel Pégourié-Gonnard61137df2014-02-24 11:57:36 +0100241
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200242 # additional convenience targets for Unix only
243 if(UNIX)
Manuel Pégourié-Gonnard546d86c2014-01-31 16:19:43 +0100244
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200245 ADD_CUSTOM_TARGET(covtest
246 COMMAND make test
247 COMMAND programs/test/selftest
Gilles Peskine7dc97042020-02-26 19:48:43 +0100248 COMMAND tests/compat.sh
249 COMMAND tests/ssl-opt.sh
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200250 )
Manuel Pégourié-Gonnardd3a91662015-07-01 10:06:27 +0200251
Manuel Pégourié-Gonnard5fe51d72015-07-01 16:59:56 +0200252 ADD_CUSTOM_TARGET(lcov
253 COMMAND rm -rf Coverage
254 COMMAND lcov --capture --initial --directory library/CMakeFiles/mbedtls.dir -o files.info
255 COMMAND lcov --capture --directory library/CMakeFiles/mbedtls.dir -o tests.info
256 COMMAND lcov --add-tracefile files.info --add-tracefile tests.info -o all.info
257 COMMAND lcov --remove all.info -o final.info '*.h'
258 COMMAND gendesc tests/Descriptions.txt -o descriptions
259 COMMAND genhtml --title "mbed TLS" --description-file descriptions --keep-descriptions --legend --no-branch-coverage -o Coverage final.info
260 COMMAND rm -f files.info tests.info all.info final.info descriptions
261 )
262
263 ADD_CUSTOM_TARGET(memcheck
264 COMMAND sed -i.bak s+/usr/bin/valgrind+`which valgrind`+ DartConfiguration.tcl
265 COMMAND ctest -O memcheck.log -D ExperimentalMemCheck
266 COMMAND tail -n1 memcheck.log | grep 'Memory checking results:' > /dev/null
267 COMMAND rm -f memcheck.log
268 COMMAND mv DartConfiguration.tcl.bak DartConfiguration.tcl
269 )
270 endif(UNIX)
Gilles Peskine84052572018-03-21 12:12:47 +0100271
Renz Christian Bagaporod8a40b52019-04-28 13:51:37 +0800272 # Make scripts needed for testing available in an out-of-source build.
273 if (NOT ${CMAKE_CURRENT_BINARY_DIR} STREQUAL ${CMAKE_CURRENT_SOURCE_DIR})
274 link_to_source(scripts)
275 # Copy (don't link) DartConfiguration.tcl, needed for memcheck, to
276 # keep things simple with the sed commands in the memcheck target.
277 configure_file(${CMAKE_CURRENT_SOURCE_DIR}/DartConfiguration.tcl
278 ${CMAKE_CURRENT_BINARY_DIR}/DartConfiguration.tcl COPYONLY)
279 endif()
Gilles Peskine84052572018-03-21 12:12:47 +0100280endif()