forked from openenclave/openenclave
-
Notifications
You must be signed in to change notification settings - Fork 0
/
CMakeLists.txt
64 lines (53 loc) · 2.11 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
# Copyright (c) Open Enclave SDK contributors.
# Licensed under the MIT License.
cmake_minimum_required(VERSION 3.11)
if (LVI_MITIGATION MATCHES ControlFlow)
# Configure the cmake to use customized compilation toolchain.
# This package has to be added before `project()`.
find_package(OpenEnclave-LVI-Mitigation CONFIG REQUIRED)
else ()
# Setting the cmake compiler when LVI mitigation is not enabled. If the CC
# environment variable has been specified or the if CMAKE_C_COMPILER cmake
# variable has been passed to cmake, use the C compiler that has been specified.
# Otherwise, prefer clang. Same for C++ compiler. This must be done before
# the `project` command.
if (UNIX)
if (NOT DEFINED ENV{CC} AND NOT DEFINED CMAKE_C_COMPILER)
find_program(CMAKE_C_COMPILER clang-11 clang-10 clang)
endif ()
if (NOT DEFINED ENV{CXX} AND NOT DEFINED CMAKE_CXX_COMPILER)
find_program(CMAKE_CXX_COMPILER clang++-11 clang++-10 clang++)
endif ()
endif ()
endif ()
project("Hello World Sample" LANGUAGES C CXX)
# Currently the `OpenEnclave` package depends on `project()`.
find_package(OpenEnclave CONFIG REQUIRED)
set(CMAKE_CXX_STANDARD 11)
set(OE_CRYPTO_LIB
mbedtls
CACHE STRING "Crypto library used by enclaves.")
add_subdirectory(enclave)
add_subdirectory(host)
# Generate key
add_custom_command(
OUTPUT private.pem public.pem
COMMAND openssl genrsa -out private.pem -3 3072
COMMAND openssl rsa -in private.pem -pubout -out public.pem)
# Sign enclave
add_custom_command(
OUTPUT enclave/enclave.signed
DEPENDS enclave enclave/helloworld.conf private.pem
COMMAND openenclave::oesign sign -e $<TARGET_FILE:enclave> -c
${CMAKE_SOURCE_DIR}/enclave/helloworld.conf -k private.pem)
add_custom_target(sign ALL DEPENDS enclave/enclave.signed)
if ((NOT DEFINED ENV{OE_SIMULATION}) OR (NOT $ENV{OE_SIMULATION}))
add_custom_target(
run
DEPENDS helloworld_host sign
COMMAND helloworld_host ${CMAKE_BINARY_DIR}/enclave/enclave.signed)
endif ()
add_custom_target(
simulate
DEPENDS helloworld_host sign
COMMAND helloworld_host ${CMAKE_BINARY_DIR}/enclave/enclave.signed --simulate)