OVMS3-idf/components/libsodium/component.mk
2018-09-20 18:53:14 +08:00

95 lines
3.4 KiB
Makefile

COMPONENT_SUBMODULES += libsodium
# Common root directory for all source directories
LSRC := libsodium/src/libsodium
COMPONENT_SRCDIRS := port
# Derived from libsodium/src/libsodium/Makefile.am
# (ignoring the !MINIMAL set)
COMPONENT_SRCDIRS += \
$(LSRC)/crypto_aead/chacha20poly1305/sodium \
$(LSRC)/crypto_aead/xchacha20poly1305/sodium \
$(LSRC)/crypto_auth \
$(LSRC)/crypto_auth/hmacsha256 \
$(LSRC)/crypto_auth/hmacsha512 \
$(LSRC)/crypto_auth/hmacsha512256 \
$(LSRC)/crypto_box \
$(LSRC)/crypto_box/curve25519xsalsa20poly1305 \
$(LSRC)/crypto_core/curve25519/ref10 \
$(LSRC)/crypto_core/hchacha20 \
$(LSRC)/crypto_core/hsalsa20/ref2 \
$(LSRC)/crypto_core/hsalsa20 \
$(LSRC)/crypto_core/salsa/ref \
$(LSRC)/crypto_generichash \
$(LSRC)/crypto_generichash/blake2b \
$(LSRC)/crypto_generichash/blake2b/ref \
$(LSRC)/crypto_hash \
$(LSRC)/crypto_hash/sha256 \
$(LSRC)/crypto_hash/sha512 \
$(LSRC)/crypto_kdf/blake2b \
$(LSRC)/crypto_kdf \
$(LSRC)/crypto_kx \
$(LSRC)/crypto_onetimeauth \
$(LSRC)/crypto_onetimeauth/poly1305 \
$(LSRC)/crypto_onetimeauth/poly1305/donna \
$(LSRC)/crypto_pwhash/argon2 \
$(LSRC)/crypto_pwhash \
$(LSRC)/crypto_pwhash/scryptsalsa208sha256 \
$(LSRC)/crypto_pwhash/scryptsalsa208sha256/nosse \
$(LSRC)/crypto_scalarmult \
$(LSRC)/crypto_scalarmult/curve25519 \
$(LSRC)/crypto_scalarmult/curve25519/ref10 \
$(LSRC)/crypto_secretbox \
$(LSRC)/crypto_secretbox/xsalsa20poly1305 \
$(LSRC)/crypto_shorthash \
$(LSRC)/crypto_shorthash/siphash24 \
$(LSRC)/crypto_shorthash/siphash24/ref \
$(LSRC)/crypto_sign \
$(LSRC)/crypto_sign/ed25519 \
$(LSRC)/crypto_sign/ed25519/ref10 \
$(LSRC)/crypto_stream/chacha20 \
$(LSRC)/crypto_stream/chacha20/ref \
$(LSRC)/crypto_stream \
$(LSRC)/crypto_stream/salsa20 \
$(LSRC)/crypto_stream/salsa20/ref \
$(LSRC)/crypto_stream/xsalsa20 \
$(LSRC)/crypto_verify/sodium \
$(LSRC)/randombytes \
$(LSRC)/sodium
ifdef CONFIG_LIBSODIUM_USE_MBEDTLS_SHA
COMPONENT_SRCDIRS += port/crypto_hash_mbedtls
else
COMPONENT_SRCDIRS += \
$(LSRC)/crypto_hash/sha256/cp \
$(LSRC)/crypto_hash/sha512/cp
endif
# Fix some warnings in current libsodium source files
# (not applied to whole component as we compile some of our own files, also.)
$(LSRC)/crypto_pwhash/argon2/argon2-fill-block-ref.o: CFLAGS += -Wno-unknown-pragmas
$(LSRC)/crypto_pwhash/argon2/pwhash_argon2i.o: CFLAGS += -Wno-type-limits
$(LSRC)/crypto_pwhash/argon2/argon2-core.o: CFLAGS += -Wno-type-limits
$(LSRC)/crypto_pwhash/scryptsalsa208sha256/pwhash_scryptsalsa208sha256.o: CFLAGS += -Wno-type-limits
$(LSRC)/sodium/utils.o: CFLAGS += -Wno-unused-variable
COMPONENT_ADD_INCLUDEDIRS := $(LSRC)/include port_include
COMPONENT_PRIV_INCLUDEDIRS := $(LSRC)/include/sodium port_include/sodium port
# Not using autoconf, but this needs to be set
CFLAGS += -DCONFIGURED
# Add the options from configure.ac (this needs checking if new versions are added )
CFLAGS += -DNATIVE_LITTLE_ENDIAN -DHAVE_WEAK_SYMBOLS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS
# randombytes.c needs to pull in platform-specific implementation
$(LSRC)/randombytes/randombytes.o: CFLAGS+=-DRANDOMBYTES_DEFAULT_IMPLEMENTATION
ifeq ($(GCC_NOT_5_2_0), 1)
# Temporary suppress "fallthrough" warnings until they are fixed in libsodium repo
$(LSRC)/crypto_shorthash/siphash24/ref/shorthash_siphashx24_ref.o: CFLAGS += -Wno-implicit-fallthrough
$(LSRC)/crypto_shorthash/siphash24/ref/shorthash_siphash24_ref.o: CFLAGS += -Wno-implicit-fallthrough
endif