|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283 |
- cmake_minimum_required(VERSION 3.13)
- project(cryptocore NONE)
-
- enable_language(C)
- enable_language(CXX)
- enable_language(ASM)
-
- 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)
- set(CMAKE_POSITION_INDEPENDENT_CODE ON)
-
- string(TOLOWER "${CMAKE_BUILD_TYPE}" CMAKE_BUILD_TYPE_LOWER)
-
- if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86_64")
- set(ARCH "ARCH_x86_64")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "amd64")
- set(ARCH "ARCH_x86_64")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "AMD64")
- set(ARCH "ARCH_x86_64")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86")
- set(ARCH "ARCH_x86")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i386")
- set(ARCH "ARCH_x86")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "i686")
- set(ARCH "ARCH_x86")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64")
- set(ARCH "ARCH_aarch64")
- elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm64")
- set(ARCH "ARCH_aarch64")
- else()
- message(FATAL_ERROR "Unknown processor:" ${CMAKE_SYSTEM_PROCESSOR})
- endif()
-
- add_subdirectory(3rd/gtest)
- add_subdirectory(3rd/cpu_features)
-
- # Arch settings
-
- if (${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
- set(MACOSX TRUE)
- endif()
-
- if(CMAKE_C_COMPILER_ID MATCHES "Clang")
- set(CLANG 1)
- 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
-
- set(C_CXX_FLAGS
- "-Wno-ignored-qualifiers \
- -Wall \
- -Werror \
- -Wextra \
- -Wpedantic \
- -Wshadow \
- -Wno-variadic-macros \
- -Wundef \
- -Wunused-result")
-
- if(CLANG)
- set(C_CXX_FLAGS
- "-Wconditional-uninitialized \
- -Wmissing-variable-declarations")
- endif()
-
- include(.cmake/common.mk)
-
- # 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(
- public
- src/common/
- src
- 3rd/cpu_features/include
- )
-
- set_property(GLOBAL PROPERTY obj_libs "")
-
-
- # Set CPU architecture
- set(CMAKE_C_FLAGS "${C_CXX_FLAGS} -D${ARCH}")
- set(CMAKE_CXX_FLAGS "${C_CXX_FLAGS} -D${ARCH}")
-
- if(PQC_WEAK_RANDOMBYTES)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DPQC_WEAK_RANDOMBYTES")
- endif()
-
- # Define sources of the components
- add_subdirectory(src/sign/dilithium/dilithium2/clean)
- add_subdirectory(src/sign/dilithium/dilithium3/clean)
- add_subdirectory(src/sign/dilithium/dilithium5/clean)
- add_subdirectory(src/sign/falcon/falcon-1024/clean)
- add_subdirectory(src/sign/falcon/falcon-512/clean)
- 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)
-
- 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)
- 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)
- add_subdirectory(src/kem/sike)
-
- # Hardware optimized targets
- if(${ARCH} STREQUAL "ARCH_x86_64")
-
- set(CMAKE_C_FLAGS
- "${CMAKE_C_FLAGS} -march=native -mtune=native")
- set(SRC_COMMON_AVX2
- src/common/keccak4x/KeccakP-1600-times4-SIMD256.c
- )
-
- # Sign
- add_subdirectory(src/sign/falcon/falcon-512/avx2)
- add_subdirectory(src/sign/falcon/falcon-1024/avx2)
- 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)
-
- # KEMs
- 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)
- 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)
- endif()
-
-
-
- # 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
- src/common/nistseedexpander.c
- src/capi/pqapi.c
- )
-
- add_library(
- common
- OBJECT
- ${SRC_COMMON_GENERIC}
- ${SRC_COMMON_AVX2}
- )
-
- add_library(
- pqc
- SHARED
- )
-
- add_library(
- pqc_s
- STATIC
- )
- get_property(OBJ_LIBS GLOBAL PROPERTY obj_libs)
-
- target_link_libraries(
- pqc
- common
- cpu_features
- ${OBJ_LIBS}
- )
-
- target_link_libraries(
- pqc_s
- common
- cpu_features
- ${OBJ_LIBS}
- )
-
- add_executable(
- ut
-
- test/ut.cpp
- )
-
- target_link_libraries(
- ut
- gtest
- gtest_main
- pqc_s)
-
- target_include_directories(
- ut PRIVATE
-
- ${CMAKE_SOURCE_DIR})
-
-
- install(TARGETS pqc pqc_s
- PERMISSIONS OWNER_READ OWNER_WRITE GROUP_READ GROUP_WRITE WORLD_READ WORLD_WRITE
- LIBRARY DESTINATION lib
- ARCHIVE DESTINATION lib)
- install(FILES
- ${QRS_PUBLIC_INC}
- DESTINATION include/pqc)
|