add cmake build options
- add cmake build options as configure provides * -DENABLE_ASM (default ON) * -DENABLE_EXTRATESTS (default OFF) * -DENABLE_NC (default OFF) * -DOPENSSLDIR (default ${CMAKE_INSTALL_PREFIX}/etc/ssl) - add biotest and pidwraptest if ENABLE_EXTRATESTS is ON - add compiler flag `-fno-common` if CMAKE_SYSTEM_NAME is Darwin to prevent link error Undefined symbols "_OPENSSL_ia32cap_P"
This commit is contained in:
parent
c94670a8cd
commit
bda62f7fe4
@ -23,6 +23,17 @@ string(STRIP ${TLS_VERSION} TLS_VERSION)
|
|||||||
string(REPLACE ":" "." TLS_VERSION ${TLS_VERSION})
|
string(REPLACE ":" "." TLS_VERSION ${TLS_VERSION})
|
||||||
string(REGEX REPLACE "\\..*" "" TLS_MAJOR_VERSION ${TLS_VERSION})
|
string(REGEX REPLACE "\\..*" "" TLS_MAJOR_VERSION ${TLS_VERSION})
|
||||||
|
|
||||||
|
option(ENABLE_ASM "Enable assembly" ON)
|
||||||
|
option(ENABLE_EXTRATESTS "Enable extra tests that may be unreliable on some platforms" OFF)
|
||||||
|
option(ENABLE_NC "Enable installing TLS-enabled nc(1)" OFF)
|
||||||
|
set(OPENSSLDIR ${OPENSSLDIR} CACHE PATH "Set the default openssl directory" FORCE)
|
||||||
|
|
||||||
|
set(BUILD_NC true)
|
||||||
|
|
||||||
|
if(CMAKE_SYSTEM_NAME MATCHES "Darwin")
|
||||||
|
add_definitions(-fno-common)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
if(CMAKE_SYSTEM_NAME MATCHES "OpenBSD")
|
||||||
add_definitions(-DHAVE_ATTRIBUTE__BOUNDED__)
|
add_definitions(-DHAVE_ATTRIBUTE__BOUNDED__)
|
||||||
endif()
|
endif()
|
||||||
@ -34,6 +45,10 @@ if(CMAKE_SYSTEM_NAME MATCHES "Linux")
|
|||||||
add_definitions(-D_GNU_SOURCE)
|
add_definitions(-D_GNU_SOURCE)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(CMAKE_SYSTEM_NAME MATCHES "MINGW")
|
||||||
|
set(BUILD_NC false)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(CMAKE_SYSTEM_NAME MATCHES "HP-UX")
|
if(CMAKE_SYSTEM_NAME MATCHES "HP-UX")
|
||||||
if(CMAKE_C_COMPILER MATCHES "gcc")
|
if(CMAKE_C_COMPILER MATCHES "gcc")
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -std=gnu99 -fno-strict-aliasing")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -std=gnu99 -fno-strict-aliasing")
|
||||||
|
@ -43,6 +43,12 @@ else()
|
|||||||
set(NC_SRC ${NC_SRC} compat/strtonum.c)
|
set(NC_SRC ${NC_SRC} compat/strtonum.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(NOT "${OPENSSLDIR}" STREQUAL "")
|
||||||
|
add_definitions(-DDEFAULT_CA_FILE=\"${OPENSSLDIR}/cert.pem\")
|
||||||
|
else()
|
||||||
|
add_definitions(-DDEFAULT_CA_FILE=\"${CMAKE_INSTALL_PREFIX}/etc/ssl/cert.pem\")
|
||||||
|
endif()
|
||||||
|
|
||||||
add_executable(nc ${NC_SRC})
|
add_executable(nc ${NC_SRC})
|
||||||
target_link_libraries(nc tls ${OPENSSL_LIBS})
|
target_link_libraries(nc tls ${OPENSSL_LIBS})
|
||||||
|
|
||||||
|
@ -79,3 +79,11 @@ target_link_libraries(openssl ${OPENSSL_LIBS})
|
|||||||
|
|
||||||
install(TARGETS openssl DESTINATION bin)
|
install(TARGETS openssl DESTINATION bin)
|
||||||
install(FILES openssl.1 DESTINATION share/man/man1)
|
install(FILES openssl.1 DESTINATION share/man/man1)
|
||||||
|
|
||||||
|
if(NOT "${OPENSSLDIR}" STREQUAL "")
|
||||||
|
set(CONF_DIR "${OPENSSLDIR}")
|
||||||
|
else()
|
||||||
|
set(CONF_DIR "${CMAKE_INSTALL_PREFIX}/etc/ssl")
|
||||||
|
endif()
|
||||||
|
install(FILES cert.pem openssl.cnf x509v3.cnf DESTINATION ${CONF_DIR})
|
||||||
|
install(DIRECTORY DESTINATION ${CONF_DIR}/cert)
|
||||||
|
@ -742,6 +742,12 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(NOT "${OPENSSLDIR}" STREQUAL "")
|
||||||
|
add_definitions(-DOPENSSLDIR=\"${OPENSSLDIR}\")
|
||||||
|
else()
|
||||||
|
add_definitions(-DOPENSSLDIR=\"${CMAKE_INSTALL_PREFIX}/etc/ssl\")
|
||||||
|
endif()
|
||||||
|
|
||||||
if (BUILD_SHARED)
|
if (BUILD_SHARED)
|
||||||
add_library(crypto-objects OBJECT ${CRYPTO_SRC})
|
add_library(crypto-objects OBJECT ${CRYPTO_SRC})
|
||||||
add_library(crypto STATIC $<TARGET_OBJECTS:crypto-objects>)
|
add_library(crypto STATIC $<TARGET_OBJECTS:crypto-objects>)
|
||||||
|
@ -9,8 +9,6 @@ include_directories(
|
|||||||
../apps/openssl/compat
|
../apps/openssl/compat
|
||||||
)
|
)
|
||||||
|
|
||||||
set(ENV{srcdir} ${CMAKE_CURRENT_SOURCE_DIR})
|
|
||||||
|
|
||||||
# aeadtest
|
# aeadtest
|
||||||
add_executable(aeadtest aeadtest.c)
|
add_executable(aeadtest aeadtest.c)
|
||||||
target_link_libraries(aeadtest ${OPENSSL_LIBS})
|
target_link_libraries(aeadtest ${OPENSSL_LIBS})
|
||||||
@ -24,7 +22,7 @@ add_test(aes_wrap aes_wrap)
|
|||||||
|
|
||||||
# arc4randomforktest
|
# arc4randomforktest
|
||||||
# Windows/mingw does not have fork, but Cygwin does.
|
# Windows/mingw does not have fork, but Cygwin does.
|
||||||
if(NOT CMAKE_HOST_WIN32)
|
if(NOT CMAKE_HOST_WIN32 AND NOT CMAKE_SYSTEM_NAME MATCHES "MINGW")
|
||||||
add_executable(arc4randomforktest arc4randomforktest.c)
|
add_executable(arc4randomforktest arc4randomforktest.c)
|
||||||
target_link_libraries(arc4randomforktest ${OPENSSL_LIBS})
|
target_link_libraries(arc4randomforktest ${OPENSSL_LIBS})
|
||||||
add_test(arc4randomforktest ${CMAKE_CURRENT_SOURCE_DIR}/arc4randomforktest.sh)
|
add_test(arc4randomforktest ${CMAKE_CURRENT_SOURCE_DIR}/arc4randomforktest.sh)
|
||||||
@ -50,6 +48,14 @@ add_executable(bftest bftest.c)
|
|||||||
target_link_libraries(bftest ${OPENSSL_LIBS})
|
target_link_libraries(bftest ${OPENSSL_LIBS})
|
||||||
add_test(bftest bftest)
|
add_test(bftest bftest)
|
||||||
|
|
||||||
|
# biotest
|
||||||
|
# the BIO tests rely on resolver results that are OS and environment-specific
|
||||||
|
if(ENABLE_EXTRATESTS)
|
||||||
|
add_executable(biotest biotest.c)
|
||||||
|
target_link_libraries(biotest ${OPENSSL_LIBS})
|
||||||
|
add_test(biotest biotest)
|
||||||
|
endif()
|
||||||
|
|
||||||
# bntest
|
# bntest
|
||||||
add_executable(bntest bntest.c)
|
add_executable(bntest bntest.c)
|
||||||
target_link_libraries(bntest ${OPENSSL_LIBS})
|
target_link_libraries(bntest ${OPENSSL_LIBS})
|
||||||
@ -198,6 +204,15 @@ add_executable(pbkdf2 pbkdf2.c)
|
|||||||
target_link_libraries(pbkdf2 ${OPENSSL_LIBS})
|
target_link_libraries(pbkdf2 ${OPENSSL_LIBS})
|
||||||
add_test(pbkdf2 pbkdf2)
|
add_test(pbkdf2 pbkdf2)
|
||||||
|
|
||||||
|
# pidwraptest
|
||||||
|
# pidwraptest relies on an OS-specific way to give out pids and is generally
|
||||||
|
# awkward on systems with slow fork
|
||||||
|
if(ENABLE_EXTRATESTS)
|
||||||
|
add_executable(pidwraptest pidwraptest.c)
|
||||||
|
target_link_libraries(pidwraptest ${OPENSSL_LIBS})
|
||||||
|
add_test(pidwraptest ${CMAKE_CURRENT_SOURCE_DIR}/pidwraptest.sh)
|
||||||
|
endif()
|
||||||
|
|
||||||
# pkcs7test
|
# pkcs7test
|
||||||
add_executable(pkcs7test pkcs7test.c)
|
add_executable(pkcs7test pkcs7test.c)
|
||||||
target_link_libraries(pkcs7test ${OPENSSL_LIBS})
|
target_link_libraries(pkcs7test ${OPENSSL_LIBS})
|
||||||
|
@ -21,6 +21,12 @@ if(NOT HAVE_STRSEP)
|
|||||||
set(TLS_SRC ${TLS_SRC} strsep.c)
|
set(TLS_SRC ${TLS_SRC} strsep.c)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(NOT "${OPENSSLDIR}" STREQUAL "")
|
||||||
|
add_definitions(-D_PATH_SSL_CA_FILE=\"${OPENSSLDIR}/cert.pem\")
|
||||||
|
else()
|
||||||
|
add_definitions(-D_PATH_SSL_CA_FILE=\"${CMAKE_INSTALL_PREFIX}/etc/ssl/cert.pem\")
|
||||||
|
endif()
|
||||||
|
|
||||||
if (BUILD_SHARED)
|
if (BUILD_SHARED)
|
||||||
add_library(tls-objects OBJECT ${TLS_SRC})
|
add_library(tls-objects OBJECT ${TLS_SRC})
|
||||||
add_library(tls STATIC $<TARGET_OBJECTS:tls-objects>)
|
add_library(tls STATIC $<TARGET_OBJECTS:tls-objects>)
|
||||||
|
Loading…
Reference in New Issue
Block a user