2021-02-10 00:21:31 +00:00
|
|
|
cmake_minimum_required(VERSION 3.13)
|
2021-04-14 08:04:14 +01:00
|
|
|
project(cryptocore VERSION 0.0.1 LANGUAGES C)
|
2021-05-26 08:01:47 +01:00
|
|
|
include(FetchContent)
|
2021-06-19 01:11:49 +01:00
|
|
|
include(ExternalProject)
|
2021-02-10 00:21:31 +00:00
|
|
|
|
2021-06-14 21:11:07 +01:00
|
|
|
set(CMAKE_CXX_STANDARD 20)
|
|
|
|
set(CMAKE_C_STANDARD 99)
|
2021-06-14 21:16:14 +01:00
|
|
|
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
2021-06-14 21:11:07 +01:00
|
|
|
|
2021-02-10 00:21:31 +00:00
|
|
|
enable_language(C)
|
|
|
|
enable_language(CXX)
|
|
|
|
enable_language(ASM)
|
|
|
|
|
2021-06-19 01:11:49 +01:00
|
|
|
if(MEMSAN)
|
|
|
|
# PQC_MEMSAN enables usage of some internals from clang
|
|
|
|
if (NOT CMAKE_C_COMPILER_ID MATCHES "Clang")
|
|
|
|
message(FATAL_ERROR "Must use clang if compiled with memory sanitizer.")
|
|
|
|
endif()
|
|
|
|
if(ADDRSAN)
|
|
|
|
message(FATAL_ERROR "Can't use MSAN and ASAN")
|
|
|
|
endif()
|
2021-06-22 01:10:08 +01:00
|
|
|
include(.cmake/libstd-memory_sanitizer.mk)
|
2021-06-19 01:11:49 +01:00
|
|
|
|
|
|
|
# LLVM project location
|
|
|
|
set(LLVM_PRJ ${CMAKE_CURRENT_BINARY_DIR}/3rd/llvm-project)
|
|
|
|
set(LLVM_PRJ_LIB ${LLVM_PRJ}/usr/local/lib)
|
|
|
|
set(LLVM_PRJ_INC ${LLVM_PRJ}/usr/local/include)
|
|
|
|
|
|
|
|
# Add memory sanitizer instrumented libraries
|
2021-06-22 01:10:08 +01:00
|
|
|
set(CMAKE_ARGS_MEMCHECK_LIB "-stdlib=libc++")
|
2021-06-19 01:11:49 +01:00
|
|
|
set(CMAKE_ARGS_MEMCHECK_INC "-isystem -I${LLVM_PRJ_INC} -I${LLVM_PRJ_INC}/c++/v1")
|
|
|
|
set(CMAKE_ARGS_MEMCHECK_FLAGS "-fsanitize=memory -fsanitize-memory-track-origins=2 -fno-omit-frame-pointer -Wno-unused-command-line-argument")
|
2021-06-21 09:20:48 +01:00
|
|
|
set(EXTRA_CXX_FLAGS "${CMAKE_ARGS_MEMCHECK_FLAGS} ${CMAKE_ARGS_MEMCHECK_LIB} ${CMAKE_ARGS_MEMCHECK_INC} -DPQC_MEMSAN_BUILD")
|
2021-06-22 01:14:17 +01:00
|
|
|
set(CXXLIBS_FOR_MEMORY_SANITIZER cxx cxxabi)
|
2021-06-19 01:11:49 +01:00
|
|
|
endif()
|
|
|
|
|
2021-05-26 08:01:47 +01:00
|
|
|
# Dependencies
|
2021-06-19 01:11:49 +01:00
|
|
|
ExternalProject_Add(
|
|
|
|
gtest_project
|
2021-05-26 08:01:47 +01:00
|
|
|
SOURCE_DIR ${PROJECT_SOURCE_DIR}/3rd/gtest
|
|
|
|
GIT_REPOSITORY https://github.com/google/googletest.git
|
|
|
|
GIT_TAG a3460d1aeeaa43fdf137a6adefef10ba0b59fe4b
|
2021-06-19 01:11:49 +01:00
|
|
|
PREFIX ${CMAKE_CURRENT_BINARY_DIR}/3rd/gtest
|
|
|
|
INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/3rd/gtest
|
|
|
|
CMAKE_ARGS -DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_BINARY_DIR}/3rd/gtest -DCMAKE_C_COMPILER=${CMAKE_C_COMPILER} -DCMAKE_CXX_COMPILER=${CMAKE_CXX_COMPILER} -DCMAKE_CXX_FLAGS=${EXTRA_CXX_FLAGS} -DCMAKE_C_FLAGS=${EXTRA_CXX_FLAGS} -Dgtest_disable_pthreads=ON
|
2021-05-26 08:01:47 +01:00
|
|
|
)
|
2021-06-22 01:14:17 +01:00
|
|
|
if(MEMSAN)
|
|
|
|
add_dependencies(gtest_project ${CXXLIBS_FOR_MEMORY_SANITIZER})
|
|
|
|
endif()
|
2021-05-26 08:01:47 +01:00
|
|
|
|
|
|
|
FetchContent_Declare(
|
|
|
|
gbench
|
|
|
|
SOURCE_DIR ${PROJECT_SOURCE_DIR}/3rd/gbench
|
|
|
|
GIT_REPOSITORY https://github.com/kriskwiatkowski/benchmark.git
|
2021-06-14 21:11:07 +01:00
|
|
|
GIT_TAG 49862ab56b6b7c3afd87b80bd5d787ed78ce3b96
|
2021-06-17 08:27:29 +01:00
|
|
|
GIT_SHALLOW TRUE
|
2021-05-26 08:01:47 +01:00
|
|
|
)
|
|
|
|
FetchContent_Populate(gbench)
|
|
|
|
|
2021-06-19 01:11:49 +01:00
|
|
|
FetchContent_Declare(
|
|
|
|
cpu_features
|
|
|
|
SOURCE_DIR ${PROJECT_SOURCE_DIR}/3rd/cpu_features
|
|
|
|
GIT_REPOSITORY https://github.com/google/cpu_features.git
|
|
|
|
GIT_TAG bc2846e78faeb26b8a46c17df369d4e5f1f9e2bb
|
|
|
|
GIT_SHALLOW TRUE
|
|
|
|
)
|
|
|
|
FetchContent_Populate(cpu_features)
|
|
|
|
|
2021-06-17 08:27:29 +01:00
|
|
|
|
2021-06-14 21:16:14 +01:00
|
|
|
set(BUILD_PIC ON CACHE BOOL "")
|
2021-04-14 08:04:14 +01:00
|
|
|
add_subdirectory(3rd/cpu_features)
|
|
|
|
|
2021-02-10 00:21:31 +00:00
|
|
|
set(CMAKE_VERBOSE_MAKEFILE ON)
|
|
|
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "~/.cmake/Modules")
|
|
|
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "3rd/cmake-modules")
|
|
|
|
set(CMAKE_CXX_STANDARD 11)
|
2021-03-24 10:25:45 +00:00
|
|
|
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
|
2021-02-10 00:21:31 +00:00
|
|
|
|
|
|
|
string(TOLOWER "${CMAKE_BUILD_TYPE}" CMAKE_BUILD_TYPE_LOWER)
|
|
|
|
|
|
|
|
if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86_64")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86_64")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "amd64")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86_64")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "AMD64")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86_64")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i386")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i686")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_x86")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_aarch64")
|
2021-02-10 00:21:31 +00:00
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm64")
|
2021-02-17 13:38:23 +00:00
|
|
|
set(ARCH "ARCH_aarch64")
|
2021-02-10 00:21:31 +00:00
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Unknown processor:" ${CMAKE_SYSTEM_PROCESSOR})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Arch settings
|
|
|
|
|
|
|
|
if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
|
|
|
set(MACOSX TRUE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CMAKE_C_COMPILER_ID MATCHES "Clang")
|
2021-06-16 07:48:47 +01:00
|
|
|
# Additional flags only useful when compiling with clang
|
2021-06-19 01:11:49 +01:00
|
|
|
string(APPEND C_CXX_FLAGS " -Wconditional-uninitialized -Wno-missing-variable-declarations -Wno-unused-command-line-argument")
|
2021-02-10 00:21:31 +00:00
|
|
|
endif()
|
|
|
|
|
|
|
|
if (MACOSX)
|
|
|
|
set(CMAKE_C_COMPILER /usr/bin/cc CACHE PATH "" FORCE)
|
|
|
|
set(CMAKE_CXX_COMPILER /usr/bin/c++ CACHE PATH "" FORCE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Global configuration
|
|
|
|
|
2021-06-16 07:48:47 +01:00
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} -Wno-ignored-qualifiers \
|
2021-02-10 00:21:31 +00:00
|
|
|
-Wall \
|
|
|
|
-Werror \
|
|
|
|
-Wextra \
|
|
|
|
-Wpedantic \
|
|
|
|
-Wshadow \
|
|
|
|
-Wno-variadic-macros \
|
2021-06-16 07:48:47 +01:00
|
|
|
-Wunused-result \
|
2021-06-19 01:11:49 +01:00
|
|
|
-Wno-unused-command-line-argument \
|
|
|
|
-Wno-undef \
|
|
|
|
${EXTRA_CXX_FLAGS}")
|
|
|
|
|
|
|
|
if(CMAKE_COMPILER_IS_GNUCC AND CMAKE_C_COMPILER_VERSION VERSION_GREATER 11.0)
|
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} \
|
|
|
|
-Wno-stringop-overread \
|
|
|
|
-Wno-stringop-overflow \
|
|
|
|
-Wno-array-parameter")
|
|
|
|
endif()
|
2021-02-10 00:21:31 +00:00
|
|
|
|
2021-06-16 06:21:58 +01:00
|
|
|
# Build with address sanitizer
|
|
|
|
if(ADDRSAN)
|
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} -fsanitize=undefined,address,leak -fno-omit-frame-pointer")
|
|
|
|
set(LDFLAGS "${LDFLAGS} -fsanitize=undefined,address,leak")
|
|
|
|
endif()
|
|
|
|
|
2021-03-03 06:50:25 +00:00
|
|
|
include(.cmake/common.mk)
|
|
|
|
|
2021-02-10 00:21:31 +00:00
|
|
|
# Control Debug/Release mode
|
|
|
|
if(CMAKE_BUILD_TYPE_LOWER STREQUAL "debug")
|
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} -g3 -O0 -Wno-unused")
|
|
|
|
else()
|
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} -O3")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
include_directories(
|
2021-03-24 23:34:34 +00:00
|
|
|
public
|
2021-03-03 06:50:25 +00:00
|
|
|
src/common/
|
2021-02-10 00:21:31 +00:00
|
|
|
src
|
2021-04-14 08:04:14 +01:00
|
|
|
3rd/cpu_features/include
|
2021-02-10 00:21:31 +00:00
|
|
|
)
|
|
|
|
|
2021-03-24 10:25:45 +00:00
|
|
|
set_property(GLOBAL PROPERTY obj_libs "")
|
|
|
|
|
2021-02-10 00:21:31 +00:00
|
|
|
# Set CPU architecture
|
2021-06-16 07:48:47 +01:00
|
|
|
set(C_CXX_FLAGS "${C_CXX_FLAGS} -D${ARCH}")
|
|
|
|
|
|
|
|
# Build for haswell if on x86_64
|
|
|
|
if(${ARCH} STREQUAL "ARCH_x86_64")
|
|
|
|
string(APPEND C_CXX_FLAGS " -march=haswell")
|
|
|
|
endif()
|
|
|
|
|
2021-06-19 01:11:49 +01:00
|
|
|
set(PQC_CMAKE_C_FLAGS "${PQC_CMAKE_C_FLAGS} ${C_CXX_FLAGS}")
|
|
|
|
set(PQC_CMAKE_CXX_FLAGS "${PQC_CMAKE_CXX_FLAGS} ${C_CXX_FLAGS}")
|
2021-06-16 07:48:47 +01:00
|
|
|
set(CMAKE_C_FLAGS ${PQC_CMAKE_C_FLAGS})
|
|
|
|
set(CMAKE_CXX_FLAGS ${PQC_CMAKE_CXX_FLAGS})
|
2021-02-10 00:21:31 +00:00
|
|
|
|
2021-03-30 01:12:11 +01:00
|
|
|
if(PQC_WEAK_RANDOMBYTES)
|
2021-06-16 07:48:47 +01:00
|
|
|
string(APPEND PQC_CMAKE_C_FLAGS " -DPQC_WEAK_RANDOMBYTES")
|
2021-03-30 01:12:11 +01:00
|
|
|
endif()
|
|
|
|
|
2021-02-17 13:38:23 +00:00
|
|
|
# Define sources of the components
|
2021-03-03 06:50:25 +00:00
|
|
|
add_subdirectory(src/sign/dilithium/dilithium2/clean)
|
|
|
|
add_subdirectory(src/sign/dilithium/dilithium3/clean)
|
|
|
|
add_subdirectory(src/sign/dilithium/dilithium5/clean)
|
2021-05-25 08:20:31 +01:00
|
|
|
add_subdirectory(src/sign/falcon)
|
2021-03-03 06:50:25 +00:00
|
|
|
add_subdirectory(src/sign/rainbow/rainbowV-classic/clean)
|
|
|
|
add_subdirectory(src/sign/rainbow/rainbowI-classic/clean)
|
|
|
|
add_subdirectory(src/sign/rainbow/rainbowIII-classic/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192f-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128f-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128f-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128s-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256f-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256f-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128s-robust/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128f-simple/clean)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192f-robust/clean)
|
2021-03-24 10:25:45 +00:00
|
|
|
|
2021-03-23 09:25:18 +00:00
|
|
|
add_subdirectory(src/kem/kyber/kyber512/clean)
|
|
|
|
add_subdirectory(src/kem/kyber/kyber768/clean)
|
|
|
|
add_subdirectory(src/kem/kyber/kyber1024/clean)
|
|
|
|
add_subdirectory(src/kem/saber/lightsaber/clean)
|
|
|
|
add_subdirectory(src/kem/saber/firesaber/clean)
|
|
|
|
add_subdirectory(src/kem/saber/saber/clean)
|
|
|
|
add_subdirectory(src/kem/frodo/frodokem640shake/clean)
|
|
|
|
add_subdirectory(src/kem/frodo/frodokem976shake/clean)
|
|
|
|
add_subdirectory(src/kem/frodo/frodokem1344shake/clean)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps4096821/clean)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps2048509/clean)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhrss701/clean)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps2048677/clean)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr761/clean)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr653/clean)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr857/clean)
|
2021-03-27 00:34:03 +00:00
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-128/clean)
|
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-192/clean)
|
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-256/clean)
|
2021-04-06 23:41:01 +01:00
|
|
|
add_subdirectory(src/kem/sike)
|
2021-05-26 13:09:25 +01:00
|
|
|
add_subdirectory(src/kem/mceliece/mceliece348864/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece460896/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece6688128/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece6960119/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece8192128/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece348864f/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece460896f/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece6688128f/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece6960119f/clean)
|
|
|
|
add_subdirectory(src/kem/mceliece/mceliece8192128f/clean)
|
2021-03-23 09:25:18 +00:00
|
|
|
# Hardware optimized targets
|
|
|
|
|
2021-06-16 07:48:47 +01:00
|
|
|
if(${ARCH} STREQUAL "ARCH_x86_64")
|
2021-03-23 09:25:18 +00:00
|
|
|
set(SRC_COMMON_AVX2
|
|
|
|
src/common/keccak4x/KeccakP-1600-times4-SIMD256.c
|
|
|
|
)
|
|
|
|
|
|
|
|
# Sign
|
2021-03-03 06:50:25 +00:00
|
|
|
add_subdirectory(src/sign/dilithium/dilithium2/avx2)
|
|
|
|
add_subdirectory(src/sign/dilithium/dilithium3/avx2)
|
|
|
|
add_subdirectory(src/sign/dilithium/dilithium5/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128s-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-128f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192s-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-192f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-shake256-256s-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128s-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-128f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192s-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-192f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256s-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256f-robust/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256f-simple/avx2)
|
|
|
|
add_subdirectory(src/sign/sphincs/sphincs-sha256-256s-robust/avx2)
|
2021-03-23 09:25:18 +00:00
|
|
|
# KEMs
|
2021-03-03 06:50:25 +00:00
|
|
|
add_subdirectory(src/kem/kyber/kyber512/avx2)
|
|
|
|
add_subdirectory(src/kem/kyber/kyber768/avx2)
|
|
|
|
add_subdirectory(src/kem/kyber/kyber1024/avx2)
|
|
|
|
add_subdirectory(src/kem/saber/lightsaber/avx2)
|
|
|
|
add_subdirectory(src/kem/saber/firesaber/avx2)
|
|
|
|
add_subdirectory(src/kem/saber/saber/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps4096821/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps2048509/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhrss701/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru/ntruhps2048677/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr761/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr653/avx2)
|
|
|
|
add_subdirectory(src/kem/ntru_prime/ntrulpr857/avx2)
|
2021-03-27 00:34:03 +00:00
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-128/avx2)
|
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-192/avx2)
|
|
|
|
add_subdirectory(src/kem/hqc/hqc-rmrs-256/avx2)
|
2021-02-17 13:38:23 +00:00
|
|
|
endif()
|
|
|
|
|
2021-03-23 09:25:18 +00:00
|
|
|
# The rest of the library
|
|
|
|
set(SRC_COMMON_GENERIC
|
|
|
|
src/common/aes.c
|
|
|
|
src/common/fips202.c
|
|
|
|
src/common/sp800-185.c
|
|
|
|
src/common/randombytes.c
|
|
|
|
src/common/sha2.c
|
2021-03-27 00:34:03 +00:00
|
|
|
src/common/nistseedexpander.c
|
2021-03-23 09:25:18 +00:00
|
|
|
src/capi/pqapi.c
|
|
|
|
)
|
2021-03-03 06:50:25 +00:00
|
|
|
|
2021-02-17 13:38:23 +00:00
|
|
|
add_library(
|
|
|
|
common
|
|
|
|
OBJECT
|
|
|
|
${SRC_COMMON_GENERIC}
|
|
|
|
${SRC_COMMON_AVX2}
|
|
|
|
)
|
|
|
|
|
2021-02-17 12:40:38 +00:00
|
|
|
add_library(
|
2021-03-25 00:59:41 +00:00
|
|
|
pqc
|
2021-02-17 12:40:38 +00:00
|
|
|
SHARED
|
|
|
|
)
|
2021-02-10 00:21:31 +00:00
|
|
|
|
2021-02-17 12:40:38 +00:00
|
|
|
add_library(
|
2021-03-25 00:59:41 +00:00
|
|
|
pqc_s
|
2021-02-17 12:40:38 +00:00
|
|
|
STATIC
|
2021-02-10 00:21:31 +00:00
|
|
|
)
|
2021-03-24 10:25:45 +00:00
|
|
|
get_property(OBJ_LIBS GLOBAL PROPERTY obj_libs)
|
2021-02-10 00:21:31 +00:00
|
|
|
|
2021-02-17 12:40:38 +00:00
|
|
|
target_link_libraries(
|
2021-03-25 00:59:41 +00:00
|
|
|
pqc
|
2021-04-14 08:04:14 +01:00
|
|
|
|
2021-03-24 10:25:45 +00:00
|
|
|
${OBJ_LIBS}
|
2021-04-14 08:04:14 +01:00
|
|
|
cpu_features
|
|
|
|
common
|
2021-02-10 00:21:31 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
target_link_libraries(
|
2021-03-25 00:59:41 +00:00
|
|
|
pqc_s
|
2021-04-14 08:04:14 +01:00
|
|
|
|
|
|
|
cpu_features
|
2021-02-17 12:40:38 +00:00
|
|
|
common
|
2021-03-24 10:25:45 +00:00
|
|
|
${OBJ_LIBS}
|
2021-02-10 00:21:31 +00:00
|
|
|
)
|
2021-03-23 09:31:12 +00:00
|
|
|
|
2021-06-16 07:48:47 +01:00
|
|
|
SET(UT_SRC test/ut.cpp)
|
|
|
|
if(MEMSAN)
|
|
|
|
SET(UT_SRC ${UT_SRC} test/ct.cpp)
|
|
|
|
endif()
|
|
|
|
|
2021-03-23 09:31:12 +00:00
|
|
|
add_executable(
|
2021-03-24 10:25:45 +00:00
|
|
|
ut
|
2021-06-16 07:48:47 +01:00
|
|
|
${UT_SRC}
|
2021-03-23 09:31:12 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
target_link_libraries(
|
2021-03-24 10:25:45 +00:00
|
|
|
ut
|
2021-06-19 01:11:49 +01:00
|
|
|
|
2021-03-23 09:31:12 +00:00
|
|
|
gtest
|
2021-03-24 10:25:45 +00:00
|
|
|
gtest_main
|
2021-06-22 01:14:17 +01:00
|
|
|
pqc_s
|
|
|
|
${CXXLIBS_FOR_MEMORY_SANITIZER})
|
2021-03-23 09:31:12 +00:00
|
|
|
|
2021-06-19 01:11:49 +01:00
|
|
|
ExternalProject_Get_Property(gtest_project INSTALL_DIR)
|
2021-03-23 09:31:12 +00:00
|
|
|
target_include_directories(
|
2021-03-24 10:25:45 +00:00
|
|
|
ut PRIVATE
|
2021-06-19 01:11:49 +01:00
|
|
|
|
|
|
|
${CMAKE_SOURCE_DIR}
|
|
|
|
${INSTALL_DIR}/include)
|
|
|
|
|
|
|
|
target_link_directories(
|
|
|
|
ut
|
|
|
|
PRIVATE
|
|
|
|
${INSTALL_DIR}/lib)
|
|
|
|
|
|
|
|
# github CI requires that
|
|
|
|
add_dependencies(ut gtest_project)
|
2021-03-23 09:31:12 +00:00
|
|
|
|
2021-04-22 21:41:40 +01:00
|
|
|
if(NOT CMAKE_BUILD_TYPE_LOWER STREQUAL "debug")
|
2021-06-19 01:11:49 +01:00
|
|
|
# settings below are required by benchmark library
|
|
|
|
set(CMAKE_BUILD_TYPE "Release" CACHE STRING "" FORCE)
|
|
|
|
# Target for benchmark - it also builds gtest library
|
|
|
|
set(BENCHMARK_ENABLE_GTEST_TESTS ON CACHE BOOL "Enable testing of the benchmark library." FORCE)
|
|
|
|
set(BENCHMARK_ENABLE_TESTING OFF CACHE BOOL "Disable benchmark tests" FORCE)
|
|
|
|
set(GOOGLETEST_PATH "${CMAKE_SOURCE_DIR}/3rd/gtest" CACHE PATH "Path to the gtest sources" FORCE)
|
|
|
|
#if (NOT MACOSX)
|
|
|
|
# set(BENCHMARK_ENABLE_LTO ON CACHE BOOL "Enable link time optim" FORCE)
|
|
|
|
#endif()
|
|
|
|
set(BENCHMARK_ENABLE_INSTALL OFF CACHE BOOL "" FORCE)
|
|
|
|
set(CMAKE_C_FLAGS "${C_CXX_FLAGS} ${EXTRA_CXX_FLAGS}")
|
|
|
|
set(CMAKE_CXX_FLAGS "${C_CXX_FLAGS} ${EXTRA_CXX_FLAGS}")
|
|
|
|
add_subdirectory(${CMAKE_SOURCE_DIR}/3rd/gbench)
|
|
|
|
add_subdirectory(test/bench)
|
2021-04-22 21:41:40 +01:00
|
|
|
endif()
|
2021-03-23 09:31:12 +00:00
|
|
|
|
2021-03-25 00:59:41 +00:00
|
|
|
install(TARGETS pqc pqc_s
|
2021-03-23 09:31:12 +00:00
|
|
|
PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ GROUP_WRITE WORLD_READ WORLD_WRITE
|
|
|
|
LIBRARY DESTINATION lib
|
|
|
|
ARCHIVE DESTINATION lib)
|
|
|
|
install(FILES
|
|
|
|
${QRS_PUBLIC_INC}
|
2021-03-25 00:59:41 +00:00
|
|
|
DESTINATION include/pqc)
|