|
|
|
cmake_minimum_required (VERSION 3.8)
|
|
|
|
project(mcl CXX C ASM)
|
|
|
|
|
|
|
|
option(
|
|
|
|
MCL_MAX_BIT_SIZE
|
|
|
|
"max bit size for Fp"
|
|
|
|
0
|
|
|
|
)
|
|
|
|
if(MSVC)
|
|
|
|
option(
|
|
|
|
MCL_DOWNLOAD_SOURCE
|
|
|
|
"download cybozulib_ext"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
option(
|
|
|
|
MCL_USE_OPENSSL
|
|
|
|
"use openssl"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_USE_GMP
|
|
|
|
"use gmp"
|
|
|
|
ON
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_USE_ASM
|
|
|
|
"use asm"
|
|
|
|
ON
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_USE_XBYAK
|
|
|
|
"use xbyak"
|
|
|
|
ON
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_USE_LLVM
|
|
|
|
"use base64.ll with -DCMAKE_CXX_COMPILER=clang++"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_BUILD_SAMPLE
|
|
|
|
"Build mcl samples"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
option(
|
|
|
|
MCL_BUILD_TESTING
|
|
|
|
"Build mcl tests"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
if(MSVC)
|
|
|
|
option(
|
|
|
|
MCL_MSVC_RUNTIME_DLL
|
|
|
|
"use dynamic runtime /MD in msvc builds"
|
|
|
|
OFF
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
if(MSVC)
|
|
|
|
set(MCL_CYBOZULIB_EXT_DIR "${CMAKE_CURRENT_SOURCE_DIR}/../cybozulib_ext"
|
|
|
|
CACHE PATH "external cybozulib_ext directory")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
|
|
|
|
|
|
|
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
|
|
|
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
|
|
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
|
|
|
|
|
|
|
|
if(MCL_USE_LLVM AND NOT CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
|
|
message(WARNING "MCL_USE_LLVM will not be used: requiring clang/clang++.")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
add_library(mcl SHARED src/fp.cpp)
|
|
|
|
add_library(mcl::mcl ALIAS mcl)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_NO_AUTOLINK MCLBN_NO_AUTOLINK)
|
|
|
|
target_include_directories(mcl PUBLIC
|
|
|
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
|
|
|
$<INSTALL_INTERFACE:$CMAKE_INSTALL_DIR/include>)
|
|
|
|
set_target_properties(mcl PROPERTIES
|
|
|
|
POSITION_INDEPENDENT_CODE ON)
|
|
|
|
#set_target_properties(mcl PROPERTIES OUTPUT_NAME mcl VERSION 1.0.0 SOVERSION 1)
|
|
|
|
# For semantics of ABI compatibility including when you must bump SOVERSION, see:
|
|
|
|
# https://community.kde.org/Policies/Binary_Compatibility_Issues_With_C%2B%2B#The_Do.27s_and_Don.27ts
|
|
|
|
|
|
|
|
add_library(mcl_st STATIC src/fp.cpp)
|
|
|
|
add_library(mcl::mcl_st ALIAS mcl_st)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_NO_AUTOLINK MCLBN_NO_AUTOLINK)
|
|
|
|
target_include_directories(mcl_st PUBLIC
|
|
|
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
|
|
|
$<INSTALL_INTERFACE:$CMAKE_INSTALL_DIR/include>)
|
|
|
|
set_target_properties(mcl_st PROPERTIES
|
|
|
|
OUTPUT_NAME mcl
|
|
|
|
POSITION_INDEPENDENT_CODE ON)
|
|
|
|
#set_target_properties(mcl_st PROPERTIES PREFIX "lib")
|
|
|
|
|
|
|
|
if(MCL_USE_LLVM AND CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
|
|
add_executable(gen src/gen.cpp)
|
|
|
|
target_include_directories(gen PRIVATE
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
|
|
if(MCL_USE_GMP)
|
|
|
|
find_package(GMP REQUIRED)
|
|
|
|
target_link_libraries(gen PRIVATE GMP::GMPXX GMP::GMP)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
add_custom_command(OUTPUT base64.ll
|
|
|
|
COMMAND gen > base64.ll
|
|
|
|
DEPENDS gen
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
|
|
|
|
add_custom_target(gen_base64.ll
|
|
|
|
SOURCES ${CMAKE_CURRENT_BINARY_DIR}/base64.ll)
|
|
|
|
|
|
|
|
add_custom_command(OUTPUT base64.o
|
|
|
|
COMMAND ${CMAKE_CXX_COMPILER} -c -o base64.o base64.ll -O3 -fPIC
|
|
|
|
DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/base64.ll
|
|
|
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
|
|
|
|
add_custom_target(gen_base64.o
|
|
|
|
SOURCES ${CMAKE_CURRENT_BINARY_DIR}/base64.o)
|
|
|
|
|
|
|
|
target_link_libraries(mcl PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/base64.o)
|
|
|
|
add_dependencies(mcl gen_base64.o)
|
|
|
|
target_link_libraries(mcl_st PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/base64.o)
|
|
|
|
add_dependencies(mcl_st gen_base64.o)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(MSVC)
|
|
|
|
if(MCL_MSVC_RUNTIME_DLL)
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} /MD /Oy /Ox /EHsc /GS- /Zi /DNDEBUG")
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS} /MDd")
|
|
|
|
else()
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} /MT /Oy /Ox /EHsc /GS- /Zi /DNDEBUG")
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS} /MTd")
|
|
|
|
endif()
|
|
|
|
target_compile_definitions(mcl PUBLIC NOMINMAX)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC NOMINMAX)
|
|
|
|
# set compiler flags for warnings level
|
|
|
|
set(MCL_COMPILE_OPTIONS /W4)
|
|
|
|
target_compile_options(mcl PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
target_compile_options(mcl_st PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
else()
|
|
|
|
# Set compiler flags for warnings
|
|
|
|
set(MCL_COMPILE_OPTIONS -Wall -Wextra -Wformat=2 -Wcast-qual -Wcast-align
|
|
|
|
-Wwrite-strings -Wfloat-equal -Wpointer-arith -march=native)
|
|
|
|
|
|
|
|
target_compile_options(mcl PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
target_compile_options(mcl_st PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
set_target_properties(mcl PROPERTIES
|
|
|
|
CXX_STANDARD 11
|
|
|
|
CXX_STANDARD_REQUIRED YES
|
|
|
|
CXX_EXTENSIONS NO)
|
|
|
|
set_target_properties(mcl_st PROPERTIES
|
|
|
|
CXX_STANDARD 11
|
|
|
|
CXX_STANDARD_REQUIRED YES
|
|
|
|
CXX_EXTENSIONS NO)
|
|
|
|
target_compile_features(mcl PUBLIC cxx_std_11)
|
|
|
|
target_compile_features(mcl_st PUBLIC cxx_std_11)
|
|
|
|
|
|
|
|
if(${MCL_MAX_BIT_SIZE} GREATER 0)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_MAX_BIT_SIZE=${MCL_MAX_BIT_SIZE})
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_MAX_BIT_SIZE=${MCL_MAX_BIT_SIZE})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(MCL_USE_LLVM AND CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_LLVM=1 MCL_LLVM_BMI2=0)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_LLVM=1 MCL_LLVM_BMI2=0)
|
|
|
|
elseif(MCL_USE_ASM)
|
|
|
|
if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64")
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_sources(mcl PRIVATE src/asm/aarch64.s)
|
|
|
|
target_sources(mcl_st PRIVATE src/asm/aarch64.s)
|
|
|
|
set(CPU arch64)
|
|
|
|
elseif(${CMAKE_SYSTEM_PROCESSOR} MATCHES "^arm")
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_sources(mcl PRIVATE src/asm/arm.s)
|
|
|
|
target_sources(mcl_st PRIVATE src/asm/arm.s)
|
|
|
|
set(CPU arm)
|
|
|
|
elseif(APPLE)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_sources(mcl PRIVATE src/asm/x86-64mac.s src/asm/x86-64mac.bmi2.s)
|
|
|
|
target_sources(mcl_st PRIVATE src/asm/x86-64mac.s src/asm/x86-64mac.bmi2.s)
|
|
|
|
set(CPU x86-64)
|
|
|
|
elseif(UNIX)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_LLVM=1)
|
|
|
|
target_sources(mcl PRIVATE src/asm/x86-64.s src/asm/x86-64.bmi2.s)
|
|
|
|
target_sources(mcl_st PRIVATE src/asm/x86-64.s src/asm/x86-64.bmi2.s)
|
|
|
|
set(CPU x86-64)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if(MCL_USE_GMP)
|
|
|
|
find_package(GMP REQUIRED)
|
|
|
|
target_link_libraries(mcl PUBLIC GMP::GMPXX GMP::GMP)
|
|
|
|
target_link_libraries(mcl_st PUBLIC GMP::GMPXX GMP::GMP)
|
|
|
|
endif()
|
|
|
|
if(MCL_USE_OPENSSL)
|
|
|
|
find_package(OpenSSL REQUIRED)
|
|
|
|
target_link_libraries(mcl PUBLIC OpenSSL::Crypto)
|
|
|
|
target_link_libraries(mcl_st PUBLIC OpenSSL::Crypto)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(NOT MCL_USE_GMP)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_USE_VINT MCL_VINT_FIXED_BUFFER)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_USE_VINT MCL_VINT_FIXED_BUFFER)
|
|
|
|
endif()
|
|
|
|
if(NOT MCL_USE_OPENSSL)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_DONT_USE_OPENSSL)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_DONT_USE_OPENSSL)
|
|
|
|
endif()
|
|
|
|
if(NOT MCL_USE_XBYAK)
|
|
|
|
target_compile_definitions(mcl PUBLIC MCL_DONT_USE_XBYAK)
|
|
|
|
target_compile_definitions(mcl_st PUBLIC MCL_DONT_USE_XBYAK)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(MCL_DOWNLOAD_SOURCE)
|
|
|
|
if(MSVC)
|
|
|
|
set(CYBOZULIB_EXT_DOWNLOAD_DIR ${CMAKE_CURRENT_SOURCE_DIR}/external/cybozulib_ext)
|
|
|
|
set(CYBOZULIB_EXT_TAG release20170521)
|
|
|
|
set(FILES config.h gmp-impl.h gmp-mparam.h gmp.h gmpxx.h longlong.h mpir.h mpirxx.h)
|
|
|
|
foreach(file IN ITEMS ${FILES})
|
|
|
|
file(DOWNLOAD https://raw.githubusercontent.com/herumi/cybozulib_ext/${CYBOZULIB_EXT_TAG}/include/${file} ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include/${file})
|
|
|
|
message("download cybozulib_ext/" ${file})
|
|
|
|
endforeach()
|
|
|
|
set(FILES aes.h applink.c asn1.h asn1_mac.h asn1t.h bio.h blowfish.h bn.h buffer.h camellia.h cast.h cmac.h cms.h comp.h conf.h conf_api.h crypto.h des.h des_old.h dh.h dsa.h dso.h dtls1.h e_os2.h ebcdic.h ec.h ecdh.h ecdsa.h engine.h err.h evp.h hmac.h idea.h krb5_asn.h kssl.h lhash.h md4.h md5.h mdc2.h modes.h obj_mac.h objects.h ocsp.h opensslconf.h opensslv.h ossl_typ.h pem.h pem2.h pkcs12.h pkcs7.h pqueue.h rand.h rc2.h rc4.h ripemd.h rsa.h safestack.h seed.h sha.h srp.h srtp.h ssl.h ssl2.h ssl23.h ssl3.h stack.h symhacks.h tls1.h ts.h txt_db.h ui.h ui_compat.h whrlpool.h x509.h x509_vfy.h x509v3.h)
|
|
|
|
foreach(file IN ITEMS ${FILES})
|
|
|
|
file(DOWNLOAD
|
|
|
|
https://raw.githubusercontent.com/herumi/cybozulib_ext/${CYBOZULIB_EXT_TAG}/include/openssl/${file} ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include/openssl/${file})
|
|
|
|
message("download cybozulib_ext/openssl/" ${file})
|
|
|
|
endforeach()
|
|
|
|
set(FILES mpir.lib mpirxx.lib mpirxx.pdb ssleay32.lib libeay32.lib mpir.pdb)
|
|
|
|
foreach(file IN ITEMS ${FILES})
|
|
|
|
file(DOWNLOAD
|
|
|
|
https://raw.githubusercontent.com/herumi/cybozulib_ext/${CYBOZULIB_EXT_TAG}/lib/mt/14/${file} ${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14/${file})
|
|
|
|
message("download lib/mt/14/" ${file})
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
# mpir
|
|
|
|
add_library(cybozulib_ext::mpir STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::mpir PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14/mpir.lib)
|
|
|
|
# mpirxx
|
|
|
|
add_library(cybozulib_ext::mpirxx STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::mpirxx PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14/mpirxx.lib)
|
|
|
|
# libeay32
|
|
|
|
add_library(cybozulib_ext::libeay32 STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::libeay32 PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14/libeay32.lib)
|
|
|
|
# ssleay32
|
|
|
|
add_library(cybozulib_ext::ssleay32 STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::ssleay32 PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${CYBOZULIB_EXT_DOWNLOAD_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14/ssleay32.lib)
|
|
|
|
# abstracted cybozulib_ext libraries
|
|
|
|
add_library(windows_specific INTERFACE)
|
|
|
|
add_library(mcl::windows_specific ALIAS windows_specific)
|
|
|
|
target_link_libraries(windows_specific INTERFACE
|
|
|
|
-LIBPATH:${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib
|
|
|
|
-LIBPATH:${CYBOZULIB_EXT_DOWNLOAD_DIR}/lib/mt/14
|
|
|
|
cybozulib_ext::mpir
|
|
|
|
cybozulib_ext::mpirxx
|
|
|
|
cybozulib_ext::libeay32
|
|
|
|
cybozulib_ext::ssleay32)
|
|
|
|
|
|
|
|
target_link_libraries(mcl PUBLIC mcl::windows_specific)
|
|
|
|
target_link_libraries(mcl_st PUBLIC mcl::windows_specific)
|
|
|
|
endif()
|
|
|
|
else()
|
|
|
|
if(MSVC)
|
|
|
|
# mpir
|
|
|
|
add_library(cybozulib_ext::mpir STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::mpir PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${MCL_CYBOZULIB_EXT_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${MCL_CYBOZULIB_EXT_DIR}/lib/mt/14/mpir.lib)
|
|
|
|
# mpirxx
|
|
|
|
add_library(cybozulib_ext::mpirxx STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::mpirxx PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${MCL_CYBOZULIB_EXT_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${MCL_CYBOZULIB_EXT_DIR}/lib/mt/14/mpirxx.lib)
|
|
|
|
# libeay32
|
|
|
|
add_library(cybozulib_ext::libeay32 STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::libeay32 PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${MCL_CYBOZULIB_EXT_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${MCL_CYBOZULIB_EXT_DIR}/lib/mt/14/libeay32.lib)
|
|
|
|
# ssleay32
|
|
|
|
add_library(cybozulib_ext::ssleay32 STATIC IMPORTED)
|
|
|
|
set_target_properties(cybozulib_ext::ssleay32 PROPERTIES
|
|
|
|
INTERFACE_INCLUDE_DIRECTORIES ${MCL_CYBOZULIB_EXT_DIR}/include
|
|
|
|
IMPORTED_LOCATION ${MCL_CYBOZULIB_EXT_DIR}/lib/mt/14/ssleay32.lib)
|
|
|
|
# abstracted cybozulib_ext libraries
|
|
|
|
add_library(windows_specific INTERFACE)
|
|
|
|
add_library(mcl::windows_specific ALIAS windows_specific)
|
|
|
|
target_link_libraries(windows_specific INTERFACE
|
|
|
|
-LIBPATH:${MCL_CYBOZULIB_EXT_DIR}/lib
|
|
|
|
-LIBPATH:${MCL_CYBOZULIB_EXT_DIR}/lib/mt/14
|
|
|
|
cybozulib_ext::mpir
|
|
|
|
cybozulib_ext::mpirxx
|
|
|
|
cybozulib_ext::libeay32
|
|
|
|
cybozulib_ext::ssleay32)
|
|
|
|
|
|
|
|
target_link_libraries(mcl PUBLIC mcl::windows_specific)
|
|
|
|
target_link_libraries(mcl_st PUBLIC mcl::windows_specific)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# mclbnXXX
|
|
|
|
foreach(bit IN ITEMS 256 384 384_256 512)
|
|
|
|
add_library(mclbn${bit} SHARED src/bn_c${bit}.cpp)
|
|
|
|
add_library(mcl::mclbn${bit} ALIAS mclbn${bit})
|
|
|
|
set_target_properties(mclbn${bit} PROPERTIES
|
|
|
|
CXX_STANDARD 11
|
|
|
|
CXX_STANDARD_REQUIRED YES
|
|
|
|
CXX_EXTENSIONS NO)
|
|
|
|
target_compile_options(mclbn${bit} PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
target_compile_definitions(mclbn${bit}
|
|
|
|
PUBLIC MCL_NO_AUTOLINK MCLBN_NO_AUTOLINK)
|
|
|
|
target_link_libraries(mclbn${bit} PUBLIC mcl::mcl)
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
# mclsheXXX
|
|
|
|
foreach(bit IN ITEMS 256 384 384_256)
|
|
|
|
add_library(mclshe${bit} SHARED src/she_c${bit}.cpp)
|
|
|
|
add_library(mcl::mclshe${bit} ALIAS mclshe${bit})
|
|
|
|
set_target_properties(mclshe${bit} PROPERTIES
|
|
|
|
CXX_STANDARD 11
|
|
|
|
CXX_STANDARD_REQUIRED YES
|
|
|
|
CXX_EXTENSIONS NO)
|
|
|
|
target_compile_options(mclshe${bit} PRIVATE ${MCL_COMPILE_OPTIONS})
|
|
|
|
target_compile_definitions(mclshe${bit}
|
|
|
|
PUBLIC MCL_NO_AUTOLINK MCLBN_NO_AUTOLINK MCLSHE_NO_AUTOLINK)
|
|
|
|
target_link_libraries(mclshe${bit} PUBLIC mcl::mcl)
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
# ECDSA
|
|
|
|
add_library(mclecdsa SHARED src/ecdsa_c.cpp)
|
|
|
|
add_library(mcl::mclecdsa ALIAS mclecdsa)
|
|
|
|
set_target_properties(mclecdsa PROPERTIES
|
|
|
|
CXX_STANDARD 11
|
|
|
|
CXX_STANDARD_REQUIRED YES
|
|
|
|
CXX_EXTENSIONS NO)
|
|
|
|
target_link_libraries(mclecdsa PUBLIC mcl::mcl)
|
|
|
|
|
|
|
|
if(MSVC)
|
|
|
|
install(TARGETS mcl mcl_st mclbn256 mclbn384 mclbn384_256 mclbn512 mclshe256
|
|
|
|
mclshe384 mclshe384_256 windows_specific
|
|
|
|
EXPORT mclTargets
|
|
|
|
LIBRARY DESTINATION lib
|
|
|
|
ARCHIVE DESTINATION lib
|
|
|
|
RUNTIME DESTINATION lib)
|
|
|
|
else()
|
|
|
|
install(TARGETS mcl mcl_st mclbn256 mclbn384 mclbn384_256 mclbn512 mclshe256
|
|
|
|
mclshe384 mclshe384_256
|
|
|
|
EXPORT mclTargets
|
|
|
|
LIBRARY DESTINATION lib
|
|
|
|
ARCHIVE DESTINATION lib
|
|
|
|
RUNTIME DESTINATION lib)
|
|
|
|
endif()
|
|
|
|
install(DIRECTORY include/mcl
|
|
|
|
DESTINATION include
|
|
|
|
FILES_MATCHING PATTERN "*.hpp"
|
|
|
|
PATTERN "curve_type.h"
|
|
|
|
PATTERN "bn.h"
|
|
|
|
PATTERN "bn_c256.h"
|
|
|
|
PATTERN "bn_c384_256.h"
|
|
|
|
PATTERN "bn_c384.h")
|
|
|
|
install(DIRECTORY include/cybozu
|
|
|
|
DESTINATION include
|
|
|
|
FILES_MATCHING PATTERN "*.hpp")
|
|
|
|
|
|
|
|
install(EXPORT mclTargets
|
|
|
|
FILE mclTargets.cmake
|
|
|
|
NAMESPACE mcl::
|
|
|
|
DESTINATION lib/cmake/mcl)
|
|
|
|
|
|
|
|
# support local build-tree export to allow import from external projects
|
|
|
|
export(EXPORT mclTargets
|
|
|
|
FILE mclTargets.cmake
|
|
|
|
NAMESPACE mcl::)
|
|
|
|
set(CMAKE_EXPORT_PACKAGE_REGISTRY ON)
|
|
|
|
export(PACKAGE mcl)
|
|
|
|
|
|
|
|
|
|
|
|
# Tests
|
|
|
|
if((CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME OR MCL_BUILD_TESTING)
|
|
|
|
AND BUILD_TESTING)
|
|
|
|
enable_testing()
|
|
|
|
add_subdirectory(test)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(MCL_BUILD_SAMPLE)
|
|
|
|
# sample code
|
|
|
|
add_subdirectory(sample)
|
|
|
|
endif()
|