include_directories(../include) if(NOT OPENSSL_NO_ASM) if(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. if(APPLE) set(PERLASM_STYLE ios64) else() set(PERLASM_STYLE linux64) endif() elseif(${ARCH} STREQUAL "arm") if(APPLE) set(PERLASM_STYLE ios32) else() set(PERLASM_STYLE linux32) endif() elseif(${ARCH} STREQUAL "ppc64le") set(PERLASM_STYLE linux64le) else() if(${ARCH} STREQUAL "x86") set(PERLASM_FLAGS "-fPIC -DOPENSSL_IA32_SSE2") endif() if(APPLE) set(PERLASM_STYLE macosx) else() set(PERLASM_STYLE elf) endif() endif() set(ASM_EXT S) enable_language(ASM) set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -Wa,--noexecstack") # Clang's integerated assembler does not support debug symbols. if(NOT CMAKE_ASM_COMPILER_ID MATCHES "Clang") set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -Wa,-g") endif() # CMake does not add -isysroot and -arch flags to assembly. if(APPLE) if(CMAKE_OSX_SYSROOT) set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -isysroot \"${CMAKE_OSX_SYSROOT}\"") endif() foreach(arch ${CMAKE_OSX_ARCHITECTURES}) set(CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} -arch ${arch}") endforeach() endif() else() if(${ARCH} STREQUAL "aarch64") set(PERLASM_STYLE win64) set(ASM_EXT S) enable_language(ASM) else() if(${ARCH} STREQUAL "x86_64") set(PERLASM_STYLE nasm) else() set(PERLASM_STYLE win32n) set(PERLASM_FLAGS "-DOPENSSL_IA32_SSE2") endif() set(CMAKE_ASM_NASM_FLAGS "${CMAKE_ASM_NASM_FLAGS} -gcv8") # On Windows, we use the NASM output. set(ASM_EXT asm) enable_language(ASM_NASM) endif() endif() endif() function(perlasm dest src) get_filename_component(dir ${dest} DIRECTORY) if ("${dir}" STREQUAL "") set(dir ".") endif() add_custom_command( OUTPUT ${dest} COMMAND ${CMAKE_COMMAND} -E make_directory ${dir} 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/ppc-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() add_subdirectory(fipsmodule) add_subdirectory(test) if(FIPS_DELOCATE OR FIPS_SHARED) SET_SOURCE_FILES_PROPERTIES(fipsmodule/bcm.o PROPERTIES EXTERNAL_OBJECT true) SET_SOURCE_FILES_PROPERTIES(fipsmodule/bcm.o PROPERTIES GENERATED true) set( CRYPTO_FIPS_OBJECTS fipsmodule/bcm.o ) endif() if(${ARCH} STREQUAL "arm") set( CRYPTO_ARCH_SOURCES chacha/chacha-armv4.${ASM_EXT} curve25519/asm/x25519-asm-arm.S poly1305/poly1305_arm_asm.S test/trampoline-armv4.${ASM_EXT} ) endif() if(${ARCH} STREQUAL "aarch64") set( CRYPTO_ARCH_SOURCES chacha/chacha-armv8.${ASM_EXT} test/trampoline-armv8.${ASM_EXT} ) endif() if(${ARCH} STREQUAL "ppc64le") set( CRYPTO_ARCH_SOURCES test/trampoline-ppc.${ASM_EXT} ) endif() if(${ARCH} STREQUAL "x86") set( CRYPTO_ARCH_SOURCES chacha/chacha-x86.${ASM_EXT} test/trampoline-x86.${ASM_EXT} ) endif() if(${ARCH} STREQUAL "x86_64") set( CRYPTO_ARCH_SOURCES chacha/chacha-x86_64.${ASM_EXT} cipher_extra/aes128gcmsiv-x86_64.${ASM_EXT} cipher_extra/chacha20_poly1305_x86_64.${ASM_EXT} hrss/asm/poly_rq_mul.S test/trampoline-x86_64.${ASM_EXT} ) endif() perlasm(chacha/chacha-armv4.${ASM_EXT} chacha/asm/chacha-armv4.pl) perlasm(chacha/chacha-armv8.${ASM_EXT} chacha/asm/chacha-armv8.pl) perlasm(chacha/chacha-x86.${ASM_EXT} chacha/asm/chacha-x86.pl) perlasm(chacha/chacha-x86_64.${ASM_EXT} chacha/asm/chacha-x86_64.pl) perlasm(cipher_extra/aes128gcmsiv-x86_64.${ASM_EXT} cipher_extra/asm/aes128gcmsiv-x86_64.pl) perlasm(cipher_extra/chacha20_poly1305_x86_64.${ASM_EXT} cipher_extra/asm/chacha20_poly1305_x86_64.pl) perlasm(test/trampoline-armv4.${ASM_EXT} test/asm/trampoline-armv4.pl) perlasm(test/trampoline-armv8.${ASM_EXT} test/asm/trampoline-armv8.pl) perlasm(test/trampoline-ppc.${ASM_EXT} test/asm/trampoline-ppc.pl) perlasm(test/trampoline-x86.${ASM_EXT} test/asm/trampoline-x86.pl) perlasm(test/trampoline-x86_64.${ASM_EXT} test/asm/trampoline-x86_64.pl) add_custom_command( OUTPUT err_data.c COMMAND ${GO_EXECUTABLE} run err_data_generate.go > ${CMAKE_CURRENT_BINARY_DIR}/err_data.c DEPENDS err/err_data_generate.go err/asn1.errordata err/bio.errordata err/bn.errordata err/cipher.errordata err/conf.errordata err/dh.errordata err/digest.errordata err/dsa.errordata err/ecdh.errordata err/ecdsa.errordata err/ec.errordata err/engine.errordata err/evp.errordata err/hkdf.errordata err/obj.errordata err/pem.errordata err/pkcs7.errordata err/pkcs8.errordata err/rsa.errordata err/ssl.errordata err/trust_token.errordata err/x509.errordata err/x509v3.errordata WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/err ) add_library( crypto asn1/a_bitstr.c asn1/a_bool.c asn1/a_d2i_fp.c asn1/a_dup.c asn1/a_enum.c asn1/a_gentm.c asn1/a_i2d_fp.c asn1/a_int.c asn1/a_mbstr.c asn1/a_object.c asn1/a_octet.c asn1/a_print.c asn1/a_strnid.c asn1/a_time.c asn1/a_type.c asn1/a_utctm.c asn1/a_utf8.c asn1/asn1_lib.c asn1/asn1_par.c asn1/asn_pack.c asn1/f_enum.c asn1/f_int.c asn1/f_string.c asn1/tasn_dec.c asn1/tasn_enc.c asn1/tasn_fre.c asn1/tasn_new.c asn1/tasn_typ.c asn1/tasn_utl.c asn1/time_support.c base64/base64.c bio/bio.c bio/bio_mem.c bio/connect.c bio/fd.c bio/file.c bio/hexdump.c bio/pair.c bio/printf.c bio/socket.c bio/socket_helper.c blake2/blake2.c bn_extra/bn_asn1.c bn_extra/convert.c buf/buf.c bytestring/asn1_compat.c bytestring/ber.c bytestring/cbb.c bytestring/cbs.c bytestring/unicode.c chacha/chacha.c cipher_extra/cipher_extra.c cipher_extra/derive_key.c cipher_extra/e_aesccm.c cipher_extra/e_aesctrhmac.c cipher_extra/e_aesgcmsiv.c cipher_extra/e_chacha20poly1305.c cipher_extra/e_null.c cipher_extra/e_rc2.c cipher_extra/e_rc4.c cipher_extra/e_tls.c cipher_extra/tls_cbc.c cmac/cmac.c conf/conf.c cpu-aarch64-fuchsia.c cpu-aarch64-linux.c cpu-aarch64-win.c cpu-arm-linux.c cpu-arm.c cpu-intel.c cpu-ppc64le.c crypto.c curve25519/curve25519.c curve25519/spake25519.c dh_extra/params.c dh_extra/dh_asn1.c digest_extra/digest_extra.c dsa/dsa.c dsa/dsa_asn1.c ecdh_extra/ecdh_extra.c ecdsa_extra/ecdsa_asn1.c ec_extra/ec_asn1.c ec_extra/ec_derive.c ec_extra/hash_to_curve.c err/err.c err_data.c engine/engine.c evp/digestsign.c evp/evp.c evp/evp_asn1.c evp/evp_ctx.c evp/p_dsa_asn1.c evp/p_ec.c evp/p_ec_asn1.c evp/p_ed25519.c evp/p_ed25519_asn1.c evp/p_rsa.c evp/p_rsa_asn1.c evp/p_x25519.c evp/p_x25519_asn1.c evp/pbkdf.c evp/print.c evp/scrypt.c evp/sign.c ex_data.c hkdf/hkdf.c hpke/hpke.c hrss/hrss.c lhash/lhash.c mem.c obj/obj.c obj/obj_xref.c pem/pem_all.c pem/pem_info.c pem/pem_lib.c pem/pem_oth.c pem/pem_pk8.c pem/pem_pkey.c pem/pem_x509.c pem/pem_xaux.c pkcs7/pkcs7.c pkcs7/pkcs7_x509.c pkcs8/pkcs8.c pkcs8/pkcs8_x509.c pkcs8/p5_pbev2.c poly1305/poly1305.c poly1305/poly1305_arm.c poly1305/poly1305_vec.c pool/pool.c rand_extra/deterministic.c rand_extra/forkunsafe.c rand_extra/fuchsia.c rand_extra/passive.c rand_extra/rand_extra.c rand_extra/windows.c rc4/rc4.c refcount_c11.c refcount_lock.c rsa_extra/rsa_asn1.c rsa_extra/rsa_print.c stack/stack.c siphash/siphash.c thread.c thread_none.c thread_pthread.c thread_win.c trust_token/pmbtoken.c trust_token/trust_token.c trust_token/voprf.c x509/a_digest.c x509/a_sign.c x509/a_strex.c x509/a_verify.c x509/algorithm.c x509/asn1_gen.c x509/by_dir.c x509/by_file.c x509/i2d_pr.c x509/rsa_pss.c x509/t_crl.c x509/t_req.c x509/t_x509.c x509/t_x509a.c x509/x509.c x509/x509_att.c x509/x509_cmp.c x509/x509_d2.c x509/x509_def.c x509/x509_ext.c x509/x509_lu.c x509/x509_obj.c x509/x509_req.c x509/x509_set.c x509/x509_trs.c x509/x509_txt.c x509/x509_v3.c x509/x509_vfy.c x509/x509_vpm.c x509/x509cset.c x509/x509name.c x509/x509rset.c x509/x509spki.c x509/x_algor.c x509/x_all.c x509/x_attrib.c x509/x_crl.c x509/x_exten.c x509/x_info.c x509/x_name.c x509/x_pkey.c x509/x_pubkey.c x509/x_req.c x509/x_sig.c x509/x_spki.c x509/x_val.c x509/x_x509.c x509/x_x509a.c x509v3/pcy_cache.c x509v3/pcy_data.c x509v3/pcy_lib.c x509v3/pcy_map.c x509v3/pcy_node.c x509v3/pcy_tree.c x509v3/v3_akey.c x509v3/v3_akeya.c x509v3/v3_alt.c x509v3/v3_bcons.c x509v3/v3_bitst.c x509v3/v3_conf.c x509v3/v3_cpols.c x509v3/v3_crld.c x509v3/v3_enum.c x509v3/v3_extku.c x509v3/v3_genn.c x509v3/v3_ia5.c x509v3/v3_info.c x509v3/v3_int.c x509v3/v3_lib.c x509v3/v3_ncons.c x509v3/v3_ocsp.c x509v3/v3_pci.c x509v3/v3_pcia.c x509v3/v3_pcons.c x509v3/v3_pmaps.c x509v3/v3_prn.c x509v3/v3_purp.c x509v3/v3_skey.c x509v3/v3_utl.c $ ${CRYPTO_ARCH_SOURCES} ${CRYPTO_FIPS_OBJECTS} ) if(FIPS_SHARED) set(EXTRA_INJECT_HASH_ARGS) if(ANDROID) set(EXTRA_INJECT_HASH_ARGS "-sha256") endif() # Rewrite libcrypto.so to inject the correct module hash value. This assumes # UNIX-style library naming, but we only support FIPS mode on Linux anyway. add_custom_command( TARGET crypto POST_BUILD COMMAND ${GO_EXECUTABLE} run ${CMAKE_CURRENT_SOURCE_DIR}/../util/fipstools/inject_hash/inject_hash.go -o libcrypto.so -in-object libcrypto.so ${EXTRA_INJECT_HASH_ARGS} # The DEPENDS argument to a POST_BUILD rule appears to be ignored. Thus # go_executable isn't used (as it doesn't get built), but we list this # dependency anyway in case it starts working in some CMake version. DEPENDS ../util/fipstools/inject_hash/inject_hash.go WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR} ) endif() add_dependencies(crypto global_target) if(FIPS_DELOCATE OR FIPS_SHARED) add_dependencies(crypto bcm_o_target) endif() SET_TARGET_PROPERTIES(crypto PROPERTIES LINKER_LANGUAGE C) if(NOT WIN32 AND NOT ANDROID) target_link_libraries(crypto pthread) endif() # Every target depends on crypto, so we add libcxx as a dependency here to # simplify injecting it everywhere. if(USE_CUSTOM_LIBCXX) target_link_libraries(crypto libcxx) endif() # urandom_test is a separate binary because it needs to be able to observe the # PRNG initialisation, which means that it can't have other tests running before # it does. add_executable( urandom_test fipsmodule/rand/urandom_test.cc ) target_link_libraries(urandom_test test_support_lib boringssl_gtest crypto) add_dependencies(urandom_test global_target) add_dependencies(all_tests urandom_test) add_executable( crypto_test abi_self_test.cc asn1/asn1_test.cc base64/base64_test.cc bio/bio_test.cc blake2/blake2_test.cc buf/buf_test.cc bytestring/bytestring_test.cc chacha/chacha_test.cc cipher_extra/aead_test.cc cipher_extra/cipher_test.cc cmac/cmac_test.cc compiler_test.cc constant_time_test.cc cpu-arm-linux_test.cc crypto_test.cc curve25519/ed25519_test.cc curve25519/spake25519_test.cc curve25519/x25519_test.cc ecdh_extra/ecdh_test.cc dh_extra/dh_test.cc digest_extra/digest_test.cc dsa/dsa_test.cc err/err_test.cc evp/evp_extra_test.cc evp/evp_test.cc evp/pbkdf_test.cc evp/scrypt_test.cc fipsmodule/aes/aes_test.cc fipsmodule/bn/bn_test.cc fipsmodule/ec/ec_test.cc fipsmodule/ec/p256-x86_64_test.cc fipsmodule/ecdsa/ecdsa_test.cc fipsmodule/md5/md5_test.cc fipsmodule/modes/gcm_test.cc fipsmodule/rand/ctrdrbg_test.cc fipsmodule/rand/fork_detect_test.cc fipsmodule/sha/sha_test.cc hkdf/hkdf_test.cc hpke/hpke_test.cc hmac_extra/hmac_test.cc hrss/hrss_test.cc impl_dispatch_test.cc lhash/lhash_test.cc obj/obj_test.cc pem/pem_test.cc pkcs7/pkcs7_test.cc pkcs8/pkcs8_test.cc pkcs8/pkcs12_test.cc poly1305/poly1305_test.cc pool/pool_test.cc rand_extra/rand_test.cc refcount_test.cc rsa_extra/rsa_test.cc self_test.cc stack/stack_test.cc siphash/siphash_test.cc test/file_test_gtest.cc thread_test.cc trust_token/trust_token_test.cc x509/x509_test.cc x509/x509_time_test.cc x509v3/tab_test.cc x509v3/v3name_test.cc $ $ ) add_dependencies(crypto_test global_target) target_link_libraries(crypto_test test_support_lib boringssl_gtest crypto) if(WIN32) target_link_libraries(crypto_test ws2_32) endif() add_dependencies(all_tests crypto_test)