-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathCMakeLists.txt
228 lines (193 loc) · 9.64 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
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
cmake_minimum_required(VERSION 3.13)
project(oberon-psa-crypto
LANGUAGES C ASM)
set(PLATFORM demo CACHE STRING "Default generic 'demo' platform.")
option(CONFIG_PSA_API_TESTS "Build PSA Certified APIs Architecture Test Suite" ON)
option(CONFIG_MBEDTLS_PSA_TESTS "Build Mbed TLS tests" ON)
option(CONFIG_MBEDTLS_THREADING "Build for multi-threading" ON)
if(MSVC)
set(CONFIG_PSA_API_TESTS OFF)
add_compile_options(/std:c11)
elseif(CMAKE_C_COMPILER_ID MATCHES Clang)
add_compile_options(-Wno-logical-op-parentheses)
add_compile_options(-Wno-bitwise-op-parentheses)
add_compile_options(-Wno-tautological-constant-out-of-range-compare)
elseif(UNIX)
add_compile_options(-O2 -Wall -Wextra -Werror)
endif()
# Expand the ocrypto root directory, if provided, or set to default
if(DEFINED OCRYPTO_ROOT)
get_filename_component(OCRYPTO_ROOT "${OCRYPTO_ROOT}" REALPATH)
else()
set(OCRYPTO_ROOT oberon/drivers/ocrypto)
endif()
if(NOT EXISTS "${OCRYPTO_ROOT}/include/ocrypto_types.h")
message(FATAL_ERROR
"Path ${OCRYPTO_ROOT} does not contain valid ocrypto sources. \
Please provide -DOCRYPTO_ROOT=path/to/ocrypto/sources or copy \
ocrypto sources to the following path: \
${CMAKE_CURRENT_LIST_DIR}/oberon/ocrypto")
endif()
# build ocrypto sources as object library
add_subdirectory(oberon/drivers/ocrypto)
# demo library
add_library(${PROJECT_NAME} OBJECT)
target_link_libraries(${PROJECT_NAME} PRIVATE ocrypto)
# define sources originating from Mbed TLS, modified and unmodified
set(MBED_SOURCES
${CMAKE_SOURCE_DIR}/library/check_crypto_config.h # modified
${CMAKE_SOURCE_DIR}/library/common.h
${CMAKE_SOURCE_DIR}/library/constant_time.c
${CMAKE_SOURCE_DIR}/library/platform.c
${CMAKE_SOURCE_DIR}/library/platform_util.c # modified
${CMAKE_SOURCE_DIR}/library/psa_crypto.c # modified
${CMAKE_SOURCE_DIR}/library/psa_crypto_client.c # modified
${CMAKE_SOURCE_DIR}/library/psa_crypto_core.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_driver_wrappers.h
# ${CMAKE_SOURCE_DIR}/library/psa_crypto_driver_wrappers.c # platform-specific
${CMAKE_SOURCE_DIR}/library/psa_crypto_invasive.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_its.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_random_impl.h # modified
${CMAKE_SOURCE_DIR}/library/psa_crypto_se.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_slot_management.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_slot_management.c
${CMAKE_SOURCE_DIR}/library/psa_crypto_storage.h
${CMAKE_SOURCE_DIR}/library/psa_crypto_storage.c
${CMAKE_SOURCE_DIR}/library/psa_its_file.c
${CMAKE_SOURCE_DIR}/library/threading.c
)
# common sources and includes
target_sources(${PROJECT_NAME} PRIVATE ${MBED_SOURCES})
# default driver wrapper supporting Oberon and demo drivers
target_sources(${PROJECT_NAME} PRIVATE library/psa_crypto_driver_wrappers.c)
# default MBed TLS includes
target_include_directories(${PROJECT_NAME} PRIVATE library)
# includes psa/crypto_config.h with demo entropy driver and opaque drivers
target_include_directories(${PROJECT_NAME} PUBLIC
$<BUILD_INTERFACE:${CMAKE_CURRENT_LIST_DIR}/include>
$<INSTALL_INTERFACE:include>)
# add Oberon drivers
add_subdirectory(oberon/drivers)
# add demo driver sources and includes
add_subdirectory(oberon/platforms/demo/drivers)
target_include_directories(${PROJECT_NAME} PRIVATE oberon/platforms/demo/drivers)
# Set testing options
message(STATUS "PLATFORM: ${PLATFORM}")
message(STATUS "Options:")
if(EXISTS ${CMAKE_SOURCE_DIR}/oberon/platforms/${PLATFORM}/CMakeLists.txt)
message(STATUS " - CONFIG_MBEDTLS_PSA_TESTS: ${CONFIG_MBEDTLS_PSA_TESTS}")
message(STATUS " - CONFIG_PSA_API_TESTS: ${CONFIG_PSA_API_TESTS}")
message(STATUS " - CONFIG_MBEDTLS_THREADING: ${CONFIG_MBEDTLS_THREADING}")
else()
set(CONFIG_MBEDTLS_PSA_TESTS OFF)
message(STATUS " - CONFIG_MBEDTLS_PSA_TESTS: SKIPPED, not available for ${PLATFORM}")
set(CONFIG_PSA_API_TESTS OFF)
message(STATUS " - CONFIG_PSA_API_TESTS: SKIPPED, not available for ${PLATFORM}")
endif()
# Testing
if (CONFIG_MBEDTLS_PSA_TESTS OR CONFIG_PSA_API_TESTS)
include(CTest)
# MBed TLS tests for PSA Certified Crypto API
if (CONFIG_MBEDTLS_PSA_TESTS)
# test suites relevant for PSA Crypto
set(MBEDTEST_SUITES
test_suite_psa_crypto
test_suite_psa_crypto_attributes
test_suite_psa_crypto_driver_wrappers
# test_suite_psa_crypto_entropy # n.a. - tests Mbed TLS entropy /* !!OM */
test_suite_psa_crypto_generate_key.generated
test_suite_psa_crypto_hash
# test_suite_psa_crypto_init # n.a. - tests Mbed TLS entropy initialization only /* !!OM */
test_suite_psa_crypto_memory
test_suite_psa_crypto_metadata
test_suite_psa_crypto_not_supported.generated
test_suite_psa_crypto_not_supported.misc
# test_suite_psa_crypto_op_fail.generated # n.a. - does not work with drivers /* !!OM */
test_suite_psa_crypto_op_fail.misc
test_suite_psa_crypto_pake
test_suite_psa_crypto_persistent_key
# test_suite_psa_crypto_se_driver_hal # n.a. - SE drivers are not supported /* !!OM */
# test_suite_psa_crypto_se_driver_hal_mocks # n.a.
test_suite_psa_crypto_slot_management
test_suite_psa_crypto_storage_format.current
test_suite_psa_crypto_storage_format.misc
test_suite_psa_crypto_storage_format.v0
# test_suite_psa_crypto_util # n.a. - tests Mbed TLS specific funtions
test_suite_psa_its
)
# test suites added by Oberon
set(OBERON_TEST_SUITES
pake_test
kdf_test
)
# define Mbed TLS helper sources originating from Mbed TLS test, modified and unmodified
set(MBEDTEST_SOURCES
${CMAKE_SOURCE_DIR}/tests/src/asn1_helpers.c
${CMAKE_SOURCE_DIR}/tests/src/asn1parse_min.c # forked from asn1parse.c
${CMAKE_SOURCE_DIR}/tests/src/asn1write_min.c # forked from asn1write.c
${CMAKE_SOURCE_DIR}/tests/src/psa_crypto_helpers.c
${CMAKE_SOURCE_DIR}/tests/src/psa_exercise_key.c
${CMAKE_SOURCE_DIR}/tests/src/helpers.c
)
endif()
# add tests for selected platform
add_subdirectory(oberon/platforms/${PLATFORM})
endif()
# PSA Certified APIs Architecture Test Suite; uses demo drivers for entropy and opaque
if (CONFIG_PSA_API_TESTS AND "${PLATFORM}" STREQUAL "demo")
message(STATUS "CONFIG_PSA_API_TESTS: Building for ${PLATFORM}")
# cmake ../ -G"Unix Makefiles" -DTARGET=tgt_dev_apis_linux \
# -DTOOLCHAIN=INHERIT -DSUITE=CRYPTO -DPSA_INCLUDE_PATHS="..."
set(TARGET tgt_dev_apis_linux)
set(TOOLCHAIN INHERIT)
set(SUITE CRYPTO)
set(PSA_INCLUDE_PATHS_RELATIVE
library
oberon/drivers
include # use default crypto_config that uses Oberon software drivers only
oberon/platforms/demo/drivers # required for entropy and opaque drivers
oberon/platforms/demo/include
)
set(PSA_INCLUDE_PATHS "")
foreach(PSA_INCLUDE_PATH ${PSA_INCLUDE_PATHS_RELATIVE})
get_filename_component(PSA_INCLUDE_PATH "${PSA_INCLUDE_PATH}" REALPATH)
list(APPEND PSA_INCLUDE_PATHS ${PSA_INCLUDE_PATH})
endforeach()
project("${TARGET}" LANGUAGES C ASM)
add_subdirectory(api-tests)
add_executable(${PROJECT_NAME} api-tests/platform/targets/${PROJECT_NAME}/nspe/main.c)
if(CONFIG_MBEDTLS_THREADING)
target_compile_definitions(${PROJECT_NAME} PRIVATE MBEDTLS_THREADING_C)
target_compile_definitions(${PROJECT_NAME} PRIVATE MBEDTLS_THREADING_PTHREAD)
target_sources(${PROJECT_NAME} PRIVATE "${CMAKE_SOURCE_DIR}/library/threading.c")
endif()
target_link_libraries(${PROJECT_NAME} PUBLIC ocrypto)
add_subdirectory(oberon/drivers oberon/drivers/${TARGET})
add_subdirectory(oberon/platforms/demo/drivers oberon/platforms/demo/drivers/${TARGET})
target_sources(${PROJECT_NAME} PRIVATE ${MBED_SOURCES})
target_sources(${PROJECT_NAME} PRIVATE library/psa_crypto_driver_wrappers.c)
target_include_directories(${PROJECT_NAME} PRIVATE "tests/api-tests")
# use config and other headers from default locations
target_include_directories(${PROJECT_NAME} PRIVATE "library")
target_include_directories(${PROJECT_NAME} PRIVATE "include")
target_link_libraries(${TARGET} PRIVATE val_nspe)
target_link_libraries(${TARGET} PRIVATE pal_nspe)
target_link_libraries(${TARGET} PRIVATE test_combine)
set_target_properties(${PROJECT_NAME} PROPERTIES
RUNTIME_OUTPUT_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/${TARGET}")
add_test(NAME ${PROJECT_NAME} COMMAND "${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}/${PROJECT_NAME}")
set_property(TEST ${PROJECT_NAME} PROPERTY LABELS CONFIG_PSA_API_TESTS)
endif()
# Build TLS protocol samples from Mbed TLS if MBEDTLS_ROOT defined
if(DEFINED MBEDTLS_ROOT)
include(CTest)
get_filename_component(MBEDTLS_ROOT "${MBEDTLS_ROOT}" REALPATH)
message(STATUS "Mbed TLS: ${MBEDTLS_ROOT}")
if(EXISTS "${MBEDTLS_ROOT}/programs/ssl/ssl_client2.c")
add_subdirectory(programs/ssl)
else()
message(FATAL_ERROR
"Path ${MBEDTLS_ROOT} does not contain valid Mbed TLS sources. \
Please provide -DMBEDTLS_ROOT=path/to/mbedtls.")
endif()
endif()