2018-01-11 21:49:13 -05:00
|
|
|
set(SRC libsodium/src/libsodium)
|
2018-09-12 20:56:59 -04:00
|
|
|
# Derived from libsodium/src/libsodium/Makefile.am
|
|
|
|
# (ignoring the !MINIMAL set)
|
2020-11-10 02:40:01 -05:00
|
|
|
set(srcs
|
2019-06-21 02:29:32 -04:00
|
|
|
"${SRC}/crypto_aead/chacha20poly1305/sodium/aead_chacha20poly1305.c"
|
|
|
|
"${SRC}/crypto_aead/xchacha20poly1305/sodium/aead_xchacha20poly1305.c"
|
|
|
|
"${SRC}/crypto_auth/crypto_auth.c"
|
|
|
|
"${SRC}/crypto_auth/hmacsha256/auth_hmacsha256.c"
|
|
|
|
"${SRC}/crypto_auth/hmacsha512/auth_hmacsha512.c"
|
|
|
|
"${SRC}/crypto_auth/hmacsha512256/auth_hmacsha512256.c"
|
|
|
|
"${SRC}/crypto_box/crypto_box.c"
|
|
|
|
"${SRC}/crypto_box/crypto_box_easy.c"
|
|
|
|
"${SRC}/crypto_box/crypto_box_seal.c"
|
|
|
|
"${SRC}/crypto_box/curve25519xchacha20poly1305/box_curve25519xchacha20poly1305.c"
|
|
|
|
"${SRC}/crypto_box/curve25519xsalsa20poly1305/box_curve25519xsalsa20poly1305.c"
|
|
|
|
"${SRC}/crypto_core/curve25519/ref10/curve25519_ref10.c"
|
|
|
|
"${SRC}/crypto_core/hchacha20/core_hchacha20.c"
|
|
|
|
"${SRC}/crypto_core/hsalsa20/core_hsalsa20.c"
|
|
|
|
"${SRC}/crypto_core/hsalsa20/ref2/core_hsalsa20_ref2.c"
|
|
|
|
"${SRC}/crypto_core/salsa/ref/core_salsa_ref.c"
|
|
|
|
"${SRC}/crypto_generichash/crypto_generichash.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/generichash_blake2.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/blake2b-compress-avx2.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/blake2b-compress-ref.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/blake2b-compress-sse41.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/blake2b-compress-ssse3.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/blake2b-ref.c"
|
|
|
|
"${SRC}/crypto_generichash/blake2b/ref/generichash_blake2b.c"
|
|
|
|
"${SRC}/crypto_hash/crypto_hash.c"
|
|
|
|
"${SRC}/crypto_hash/sha256/hash_sha256.c"
|
|
|
|
"${SRC}/crypto_hash/sha256/cp/hash_sha256_cp.c"
|
|
|
|
"${SRC}/crypto_hash/sha512/hash_sha512.c"
|
|
|
|
"${SRC}/crypto_hash/sha512/cp/hash_sha512_cp.c"
|
|
|
|
"${SRC}/crypto_kdf/crypto_kdf.c"
|
|
|
|
"${SRC}/crypto_kdf/blake2b/kdf_blake2b.c"
|
|
|
|
"${SRC}/crypto_kx/crypto_kx.c"
|
|
|
|
"${SRC}/crypto_onetimeauth/crypto_onetimeauth.c"
|
|
|
|
"${SRC}/crypto_onetimeauth/poly1305/onetimeauth_poly1305.c"
|
|
|
|
"${SRC}/crypto_onetimeauth/poly1305/donna/poly1305_donna.c"
|
|
|
|
"${SRC}/crypto_onetimeauth/poly1305/sse2/poly1305_sse2.c"
|
|
|
|
"${SRC}/crypto_pwhash/crypto_pwhash.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/argon2-core.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/argon2-encoding.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/argon2-fill-block-ref.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/argon2-fill-block-ssse3.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/argon2.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/blake2b-long.c"
|
|
|
|
"${SRC}/crypto_pwhash/argon2/pwhash_argon2i.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/crypto_scrypt-common.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/pbkdf2-sha256.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/pwhash_scryptsalsa208sha256.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/scrypt_platform.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/nosse/pwhash_scryptsalsa208sha256_nosse.c"
|
|
|
|
"${SRC}/crypto_pwhash/scryptsalsa208sha256/sse/pwhash_scryptsalsa208sha256_sse.c"
|
|
|
|
"${SRC}/crypto_scalarmult/crypto_scalarmult.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/scalarmult_curve25519.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/donna_c64/curve25519_donna_c64.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/ref10/x25519_ref10.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/consts.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/curve25519_sandy2x.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/fe51_invert.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/fe51_mul.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/fe51_nsquare.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/fe51_pack.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/fe_frombytes_sandy2x.c"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/ladder.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/ladder_base.S"
|
|
|
|
"${SRC}/crypto_scalarmult/curve25519/sandy2x/sandy2x.S"
|
|
|
|
"${SRC}/crypto_secretbox/crypto_secretbox.c"
|
|
|
|
"${SRC}/crypto_secretbox/crypto_secretbox_easy.c"
|
|
|
|
"${SRC}/crypto_secretbox/xchacha20poly1305/secretbox_xchacha20poly1305.c"
|
|
|
|
"${SRC}/crypto_secretbox/xsalsa20poly1305/secretbox_xsalsa20poly1305.c"
|
|
|
|
"${SRC}/crypto_shorthash/crypto_shorthash.c"
|
|
|
|
"${SRC}/crypto_shorthash/siphash24/shorthash_siphash24.c"
|
|
|
|
"${SRC}/crypto_shorthash/siphash24/shorthash_siphashx24.c"
|
|
|
|
"${SRC}/crypto_shorthash/siphash24/ref/shorthash_siphash24_ref.c"
|
|
|
|
"${SRC}/crypto_shorthash/siphash24/ref/shorthash_siphashx24_ref.c"
|
|
|
|
"${SRC}/crypto_sign/crypto_sign.c"
|
|
|
|
"${SRC}/crypto_sign/ed25519/sign_ed25519.c"
|
|
|
|
"${SRC}/crypto_sign/ed25519/ref10/keypair.c"
|
|
|
|
"${SRC}/crypto_sign/ed25519/ref10/obsolete.c"
|
|
|
|
"${SRC}/crypto_sign/ed25519/ref10/open.c"
|
|
|
|
"${SRC}/crypto_sign/ed25519/ref10/sign.c"
|
|
|
|
"${SRC}/crypto_stream/crypto_stream.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/stream_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/afternm_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/beforenm_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/consts_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/int128_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/stream_aes128ctr_nacl.c"
|
|
|
|
"${SRC}/crypto_stream/aes128ctr/nacl/xor_afternm_aes128ctr.c"
|
|
|
|
"${SRC}/crypto_stream/chacha20/stream_chacha20.c"
|
|
|
|
"${SRC}/crypto_stream/chacha20/dolbeau/chacha20_dolbeau-avx2.c"
|
|
|
|
"${SRC}/crypto_stream/chacha20/dolbeau/chacha20_dolbeau-ssse3.c"
|
|
|
|
"${SRC}/crypto_stream/chacha20/ref/chacha20_ref.c"
|
|
|
|
"${SRC}/crypto_stream/salsa20/stream_salsa20.c"
|
|
|
|
"${SRC}/crypto_stream/salsa20/ref/salsa20_ref.c"
|
|
|
|
"${SRC}/crypto_stream/salsa20/xmm6/salsa20_xmm6-asm.S"
|
|
|
|
"${SRC}/crypto_stream/salsa20/xmm6/salsa20_xmm6.c"
|
|
|
|
"${SRC}/crypto_stream/salsa20/xmm6int/salsa20_xmm6int-avx2.c"
|
|
|
|
"${SRC}/crypto_stream/salsa20/xmm6int/salsa20_xmm6int-sse2.c"
|
|
|
|
"${SRC}/crypto_stream/salsa2012/stream_salsa2012.c"
|
|
|
|
"${SRC}/crypto_stream/salsa2012/ref/stream_salsa2012_ref.c"
|
|
|
|
"${SRC}/crypto_stream/salsa208/stream_salsa208.c"
|
|
|
|
"${SRC}/crypto_stream/salsa208/ref/stream_salsa208_ref.c"
|
|
|
|
"${SRC}/crypto_stream/xchacha20/stream_xchacha20.c"
|
|
|
|
"${SRC}/crypto_stream/xsalsa20/stream_xsalsa20.c"
|
|
|
|
"${SRC}/crypto_verify/sodium/verify.c"
|
|
|
|
"${SRC}/randombytes/randombytes.c"
|
|
|
|
"${SRC}/randombytes/nativeclient/randombytes_nativeclient.c"
|
|
|
|
"${SRC}/randombytes/salsa20/randombytes_salsa20_random.c"
|
|
|
|
"${SRC}/randombytes/sysrandom/randombytes_sysrandom.c"
|
|
|
|
"${SRC}/sodium/core.c"
|
|
|
|
"${SRC}/sodium/runtime.c"
|
|
|
|
"${SRC}/sodium/utils.c"
|
|
|
|
"${SRC}/sodium/version.c"
|
|
|
|
"port/randombytes_esp32.c")
|
2018-01-11 21:49:13 -05:00
|
|
|
|
|
|
|
if(CONFIG_LIBSODIUM_USE_MBEDTLS_SHA)
|
2020-11-10 02:40:01 -05:00
|
|
|
list(APPEND srcs
|
2019-06-21 02:29:32 -04:00
|
|
|
"port/crypto_hash_mbedtls/crypto_hash_sha256_mbedtls.c"
|
|
|
|
"port/crypto_hash_mbedtls/crypto_hash_sha512_mbedtls.c")
|
2018-01-11 21:49:13 -05:00
|
|
|
else()
|
2020-11-10 02:40:01 -05:00
|
|
|
list(APPEND srcs
|
2019-06-21 02:29:32 -04:00
|
|
|
"${SRC}/crypto_hash/sha256/cp/hash_sha256_cp.c"
|
|
|
|
"${SRC}/crypto_hash/sha512/cp/hash_sha512_cp.c")
|
2018-01-11 21:49:13 -05:00
|
|
|
endif()
|
|
|
|
|
2019-04-28 03:38:23 -04:00
|
|
|
set(include_dirs ${SRC}/include port_include)
|
|
|
|
set(priv_include_dirs ${SRC}/include/sodium port_include/sodium port)
|
|
|
|
idf_component_register(SRCS "${srcs}"
|
|
|
|
INCLUDE_DIRS "${include_dirs}"
|
|
|
|
PRIV_INCLUDE_DIRS "${priv_include_dirs}"
|
|
|
|
REQUIRES mbedtls)
|
2018-01-11 21:49:13 -05:00
|
|
|
|
2020-11-10 02:40:01 -05:00
|
|
|
target_compile_definitions(${COMPONENT_LIB} PRIVATE
|
2018-02-26 23:45:30 -05:00
|
|
|
CONFIGURED
|
|
|
|
NATIVE_LITTLE_ENDIAN
|
|
|
|
HAVE_WEAK_SYMBOLS
|
|
|
|
__STDC_LIMIT_MACROS
|
|
|
|
__STDC_CONSTANT_MACROS
|
|
|
|
)
|
2018-01-11 21:49:13 -05:00
|
|
|
|
|
|
|
# patch around warnings in third-party files
|
|
|
|
set_source_files_properties(
|
2018-02-26 23:45:30 -05:00
|
|
|
${SRC}/crypto_pwhash/argon2/pwhash_argon2i.c
|
|
|
|
${SRC}/crypto_pwhash/argon2/argon2-core.c
|
|
|
|
${SRC}/crypto_pwhash/scryptsalsa208sha256/pwhash_scryptsalsa208sha256.c
|
|
|
|
PROPERTIES COMPILE_FLAGS
|
|
|
|
-Wno-type-limits
|
|
|
|
)
|
2018-01-11 21:49:13 -05:00
|
|
|
set_source_files_properties(
|
2018-02-26 23:45:30 -05:00
|
|
|
${SRC}/sodium/utils.c
|
|
|
|
PROPERTIES COMPILE_FLAGS
|
|
|
|
-Wno-unused-variable
|
|
|
|
)
|
2018-08-16 01:01:43 -04:00
|
|
|
set_source_files_properties(
|
2018-09-17 23:44:24 -04:00
|
|
|
${SRC}/crypto_pwhash/argon2/argon2-fill-block-ref.c
|
2018-08-16 01:01:43 -04:00
|
|
|
PROPERTIES COMPILE_FLAGS
|
2018-09-17 23:44:24 -04:00
|
|
|
-Wno-unknown-pragmas
|
|
|
|
)
|
|
|
|
|
|
|
|
# Temporary suppress "fallthrough" warnings until they are fixed in libsodium repo
|
2019-11-05 06:20:26 -05:00
|
|
|
set_source_files_properties(
|
|
|
|
${SRC}/crypto_shorthash/siphash24/ref/shorthash_siphashx24_ref.c
|
|
|
|
${SRC}/crypto_shorthash/siphash24/ref/shorthash_siphash24_ref.c
|
|
|
|
PROPERTIES COMPILE_FLAGS
|
|
|
|
-Wno-implicit-fallthrough
|
|
|
|
)
|
2018-08-26 22:48:16 -04:00
|
|
|
|
|
|
|
set_source_files_properties(
|
|
|
|
${SRC}/randombytes/randombytes.c
|
|
|
|
PROPERTIES COMPILE_FLAGS
|
|
|
|
-DRANDOMBYTES_DEFAULT_IMPLEMENTATION
|
|
|
|
)
|
2021-02-12 00:01:05 -05:00
|
|
|
|
|
|
|
if(CONFIG_COMPILER_OPTIMIZATION_ASSERTIONS_DISABLE)
|
|
|
|
# some libsodium variables are only used for asserts
|
|
|
|
target_compile_options(${COMPONENT_LIB} PRIVATE -Wno-unused-but-set-variable)
|
|
|
|
endif()
|