Mirror of BoringSSL (grpc依赖)
https://boringssl.googlesource.com/boringssl
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
570 lines
13 KiB
570 lines
13 KiB
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} |
|
cipher_extra/chacha20_poly1305_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(cipher_extra/chacha20_poly1305_armv8.${ASM_EXT} cipher_extra/asm/chacha20_poly1305_armv8.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_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_strex.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_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/posix_time.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_aesctrhmac.c |
|
cipher_extra/e_aesgcmsiv.c |
|
cipher_extra/e_chacha20poly1305.c |
|
cipher_extra/e_des.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 |
|
conf/conf.c |
|
cpu_aarch64_apple.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 |
|
des/des.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/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_hkdf.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_verify.c |
|
x509/algorithm.c |
|
x509/asn1_gen.c |
|
x509/by_dir.c |
|
x509/by_file.c |
|
x509/i2d_pr.c |
|
x509/name_print.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_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 |
|
|
|
$<TARGET_OBJECTS:fipsmodule> |
|
|
|
${CRYPTO_ARCH_SOURCES} |
|
${CRYPTO_FIPS_OBJECTS} |
|
) |
|
target_include_directories(crypto INTERFACE |
|
$<BUILD_INTERFACE:${CMAKE_SOURCE_DIR}/include> |
|
$<INSTALL_INTERFACE:include> |
|
) |
|
install(TARGETS crypto EXPORT OpenSSLTargets DESTINATION ${CMAKE_INSTALL_LIBDIR}) |
|
set_property(TARGET crypto PROPERTY EXPORT_NAME Crypto) |
|
|
|
if(FIPS_SHARED) |
|
# 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 |
|
# 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 |
|
compiler_test.cc |
|
conf/conf_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/cmac/cmac_test.cc |
|
fipsmodule/ec/ec_test.cc |
|
fipsmodule/ec/p256-nistz_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/service_indicator/service_indicator_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 |
|
|
|
$<TARGET_OBJECTS:crypto_test_data> |
|
$<TARGET_OBJECTS:boringssl_gtest_main> |
|
) |
|
|
|
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)
|
|
|