-
Notifications
You must be signed in to change notification settings - Fork 78
/
Copy pathCMakeLists.txt
163 lines (132 loc) · 6.16 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
cmake_minimum_required(VERSION 3.13.0)
find_package(Python3 REQUIRED COMPONENTS Interpreter)
message("Python 3 path: ${Python3_EXECUTABLE}")
if(WIN32)
# Require Windows 10 SDK version 18362 for BCRYPT_TLS_CBC_HMAC_VERIFY_FLAG
# Must be done before the "project" directive
set(CMAKE_SYSTEM_VERSION 10.0.18362)
endif()
set(SYMCRYPT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
# Set version number using helper script
execute_process(
COMMAND ${Python3_EXECUTABLE} ${SYMCRYPT_SOURCE_DIR}/scripts/version.py --build-info
OUTPUT_VARIABLE SYMCRYPT_VERSION
RESULT_VARIABLE SYMCRYPT_VERSION_RESULT
)
if(NOT SYMCRYPT_VERSION_RESULT EQUAL 0)
message(FATAL_ERROR "Failed to determine SymCrypt version: ${SYMCRYPT_VERSION_RESULT}")
endif()
string(STRIP ${SYMCRYPT_VERSION} SYMCRYPT_VERSION)
string(REGEX MATCH "([0-9]+).([0-9]+).([0-9]+)" _ ${SYMCRYPT_VERSION})
set(SYMCRYPT_CODE_VERSION_API ${CMAKE_MATCH_1})
set(SYMCRYPT_CODE_VERSION_MINOR ${CMAKE_MATCH_2})
set(SYMCRYPT_CODE_VERSION_PATCH ${CMAKE_MATCH_3})
message(STATUS "SymCrypt version ${SYMCRYPT_CODE_VERSION_API}.${SYMCRYPT_CODE_VERSION_MINOR}.${SYMCRYPT_CODE_VERSION_PATCH}")
project(SymCrypt
VERSION ${SYMCRYPT_VERSION}
DESCRIPTION "Cryptographic library"
HOMEPAGE_URL "https://github.com/microsoft/SymCrypt")
option(
SYMCRYPT_USE_ASM
"When enabled, SymCrypt will use ASM implementations of performance-critical functions where available.
Not supported on all platforms/architectures."
ON)
if(NOT SYMCRYPT_USE_ASM)
add_compile_definitions(SYMCRYPT_IGNORE_PLATFORM)
endif()
option(
SYMCRYPT_FIPS_BUILD
"When enabled, SymCrypt will build FIPS-compliant modules with self-tests enabled. Not supported on all platforms/architectures.
On Windows, this option is ignored, as self-tests are performed at a higher layer."
ON)
if(SYMCRYPT_FIPS_BUILD)
add_compile_definitions(SYMCRYPT_DO_FIPS_SELFTESTS=1)
endif()
option(
SYMCRYPT_STRIP_BINARY
"When enabled, SymCrypt will strip the binary in release mode."
ON
)
option(
SYMCRYPT_FIPS_POSTPROCESS
"When enabled, SymCrypt will do postprocessing the binary for FIPS integrity verification."
ON
)
option(
SYMCRYPT_TEST_LEGACY_IMPL
"When enabled, the SymCrypt unit tests will be linked against and configured to run compatibility and performance tests on the legacy
RSA32 and msbignum cryptographic implementations. This requires access to private static libraries which are not licensed
for use outside of Windows, and thus can only be used by Microsoft employees building internally. It only affects the unit tests,
and does not change the functionality of the SymCrypt library itself."
OFF)
option(
SYMCRYPT_STACK_PROTECTION
"When enabled, SymCrypt will enable various stack protection mechanisms to protect against buffer overruns and the like. Only
applicable to non-Windows systems. Defaults to ON, but may need to be disabled for specialized targets such as embedded systems."
ON)
option(
SYMCRYPT_PIC
"When enabled, SymCrypt will be compiled as position-independent code (PIC). Only applicable to non-Windows systems. Defaults to
ON, but may need to be disabled for specialized targets such as embedded systems."
ON)
option(
SYMCRYPT_TEST_WITH_OPENSSL
"When enabled, the SymCrypt unit tests will be linked against and configured to run performance comparisons against OpenSSL
implementations of certain algorithms."
OFF)
option(
SYMCRYPT_TEST_LIBCRUX
"When enabled, the SymCrypt unit tests will be linked against and configured to run performance comparisons against libcrux
implementations of certain algorithms."
OFF)
include(${SYMCRYPT_SOURCE_DIR}/cmake-configs/SymCrypt-Platforms.cmake)
if(NOT DEFINED CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE Debug)
endif()
set(CMAKE_C_STANDARD 11)
set(CMAKE_C_STANDARD_REQUIRED ON)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
message(STATUS "Host: ${CMAKE_HOST_SYSTEM_NAME} ${CMAKE_HOST_SYSTEM_PROCESSOR}")
message(STATUS "Target: ${CMAKE_SYSTEM_NAME} ${SYMCRYPT_TARGET_ARCH} ${SYMCRYPT_TARGET_ENV}")
message(STATUS "ASM optimizations: ${SYMCRYPT_USE_ASM}")
message(STATUS "FIPS build: ${SYMCRYPT_FIPS_BUILD}")
message(STATUS "Strip binary: ${SYMCRYPT_STRIP_BINARY}")
message(STATUS "FIPS postprocess: ${SYMCRYPT_FIPS_POSTPROCESS}")
# Validate compiler versions
if("${CMAKE_CXX_COMPILER_ID}" MATCHES "GNU")
if (CMAKE_CXX_COMPILER_VERSION VERSION_LESS 9.4)
message(FATAL_ERROR "GCC version must be at least 9.4!")
endif()
elseif ("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang|AppleClang")
if (CMAKE_CXX_COMPILER_VERSION VERSION_LESS 10.0)
message(FATAL_ERROR "Clang version must be at least 10.0!")
endif()
elseif ("${CMAKE_CXX_COMPILER_ID}" MATCHES "MSVC")
if (CMAKE_CXX_COMPILER_VERSION VERSION_LESS 19.16)
message(FATAL_ERROR "MSVC version must be at least 19.16!")
endif()
else()
message(WARNING "Compiler ${CMAKE_CXX_COMPILER_ID} is not officially supported; compilation may fail.")
endif()
# Set output directories binaries
# Note: we use a generator expression because "Multi-configuration generators [e.g. Visual Studio]
# append a per-configuration subdirectory to the specified directory unless a generator expression
# is used." We don't want this, because we want the output directories to be consistent between different
# platforms/generators so that we can more easily automate the build and packaging process.
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY $<1:${CMAKE_BINARY_DIR}/lib>)
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY $<1:${CMAKE_BINARY_DIR}/module>)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY $<1:${CMAKE_BINARY_DIR}/exe>)
if(CMAKE_BUILD_TYPE MATCHES "Release|RelWithDebInfo")
message(STATUS "Release mode")
else()
message(STATUS "Debug mode")
add_compile_definitions(DBG=1)
endif()
include_directories(inc)
include_directories(${CMAKE_BINARY_DIR}/inc)
# Process pkg-config file
configure_file(conf/symcrypt.pc.in symcrypt.pc @ONLY)
add_subdirectory(lib)
add_subdirectory(modules)
add_subdirectory(unittest)