include_directories(../include) if(APPLE) if (${ARCH} STREQUAL "x86") set(PERLASM_FLAGS "-fPIC -DOPENSSL_IA32_SSE2") endif() set(PERLASM_STYLE macosx) set(ASM_EXT S) enable_language(ASM) elseif(UNIX) if (${ARCH} STREQUAL "aarch64") # The "armx" Perl scripts look for "64" in the style argument # in order to decide whether to generate 32- or 64-bit asm. set(PERLASM_STYLE linux64) elseif (${ARCH} STREQUAL "arm") set(PERLASM_STYLE linux32) elseif (${ARCH} STREQUAL "x86") set(PERLASM_FLAGS "-fPIC -DOPENSSL_IA32_SSE2") set(PERLASM_STYLE elf) else() set(PERLASM_STYLE elf) endif() set(ASM_EXT S) enable_language(ASM) set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -Wa,--noexecstack") else() if (CMAKE_CL_64) message("Using nasm") set(PERLASM_STYLE nasm) else() message("Using win32n") set(PERLASM_STYLE win32n) set(PERLASM_FLAGS "-DOPENSSL_IA32_SSE2") endif() # On Windows, we use the NASM output, specifically built with Yasm. set(ASM_EXT asm) enable_language(ASM_NASM) endif() function(perlasm dest src) add_custom_command( OUTPUT ${dest} COMMAND ${PERL_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/${src} ${PERLASM_STYLE} ${PERLASM_FLAGS} ${ARGN} > ${dest} DEPENDS ${src} ${PROJECT_SOURCE_DIR}/crypto/perlasm/arm-xlate.pl ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86_64-xlate.pl ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86asm.pl ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86gas.pl ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86masm.pl ${PROJECT_SOURCE_DIR}/crypto/perlasm/x86nasm.pl WORKING_DIRECTORY . ) endfunction() # Level 0.1 - depends on nothing outside this set. add_subdirectory(stack) add_subdirectory(lhash) add_subdirectory(err) add_subdirectory(buf) add_subdirectory(base64) add_subdirectory(bytestring) # Level 0.2 - depends on nothing but itself add_subdirectory(sha) add_subdirectory(md4) add_subdirectory(md5) add_subdirectory(modes) add_subdirectory(aes) add_subdirectory(des) add_subdirectory(rc4) add_subdirectory(conf) add_subdirectory(chacha) add_subdirectory(poly1305) add_subdirectory(curve25519) add_subdirectory(newhope) # Level 1, depends only on 0.* add_subdirectory(digest) add_subdirectory(cipher) add_subdirectory(rand) add_subdirectory(bio) add_subdirectory(bn) add_subdirectory(obj) add_subdirectory(asn1) # Level 2 add_subdirectory(engine) add_subdirectory(dh) add_subdirectory(dsa) add_subdirectory(rsa) add_subdirectory(ec) add_subdirectory(ecdh) add_subdirectory(ecdsa) add_subdirectory(hmac) # Level 3 add_subdirectory(cmac) add_subdirectory(evp) add_subdirectory(hkdf) add_subdirectory(pem) add_subdirectory(x509) add_subdirectory(x509v3) # Level 4 add_subdirectory(pkcs8) # Test support code if(ENABLE_TESTS) add_subdirectory(test) endif() set( crypto_objects_dependencies $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ PARENT_SCOPE ) add_library( crypto-objects OBJECT cpu-aarch64-linux.c cpu-arm.c cpu-arm-linux.c cpu-intel.c crypto.c ex_data.c mem.c refcount_c11.c refcount_lock.c thread.c thread_none.c thread_pthread.c thread_win.c time_support.c ${CRYPTO_ARCH_SOURCES} ) add_library( crypto cpu-aarch64-linux.c cpu-arm.c cpu-arm-linux.c cpu-intel.c crypto.c ex_data.c mem.c refcount_c11.c refcount_lock.c thread.c thread_none.c thread_pthread.c thread_win.c time_support.c $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ $ ) if(NOT MSVC AND NOT ANDROID) target_link_libraries(crypto pthread) endif() if(ENABLE_TESTS) add_executable( constant_time_test constant_time_test.c $ ) target_link_libraries(constant_time_test crypto) add_dependencies(all_tests constant_time_test) add_executable( thread_test thread_test.c $ ) target_link_libraries(thread_test crypto) add_dependencies(all_tests thread_test) add_executable( refcount_test refcount_test.c ) target_link_libraries(refcount_test crypto) add_dependencies(all_tests refcount_test) endif()