2022-01-12 15:08:19 +00:00
|
|
|
# CLANG_VERSION is empty if the compiler is not clang-based
|
2022-05-30 09:13:09 +00:00
|
|
|
CLANG_VERSION = $(shell $(CC) --version | sed -nr 's/^.*clang version ([0-9.]+).*$$/\1/p')
|
2022-01-12 15:08:19 +00:00
|
|
|
CLANG_VERSION_MAJOR = $(shell echo $(CLANG_VERSION) | cut -f1 -d.)
|
|
|
|
|
|
|
|
# determine specific version ranges
|
|
|
|
ifneq ($(CLANG_VERSION),)
|
|
|
|
$(if $(shell [ $(CLANG_VERSION_MAJOR) -ge 13 ] && echo "OK"), \
|
|
|
|
$(eval CLANG_AT_LEAST_13 := true), \
|
|
|
|
$(eval CLANG_AT_LEAST_13 := false))
|
|
|
|
endif
|
|
|
|
|
2020-07-01 12:04:02 +00:00
|
|
|
ifeq ($(FUZZER),1)
|
|
|
|
CC ?= clang
|
|
|
|
LD ?= $(CC)
|
|
|
|
SANFLAGS += -fsanitize=fuzzer
|
2021-11-13 13:25:32 +00:00
|
|
|
|
2022-01-12 15:08:19 +00:00
|
|
|
# only clang versions >= 13 support this feature
|
|
|
|
ifeq ($(CLANG_AT_LEAST_13),true)
|
2022-01-01 13:04:56 +00:00
|
|
|
$(info "info: using -fsanitize-ignorelist")
|
2022-01-12 15:08:19 +00:00
|
|
|
SANFLAGS += -fsanitize-ignorelist=fuzzer/sanitizer_ignorelist.txt
|
|
|
|
else
|
|
|
|
$(info "info: not using -fsanitize-ignorelist")
|
|
|
|
endif
|
2022-01-01 13:04:56 +00:00
|
|
|
|
2021-11-13 13:25:32 +00:00
|
|
|
# TODO is there a better solution, for example by disabling a specific optimization technique?
|
2022-01-01 13:04:56 +00:00
|
|
|
# there is a clang optimization issue in relation with the blake2 code at -fsanitize=undefined
|
2022-01-12 15:08:19 +00:00
|
|
|
$(warning "warning: disabling optimization on blake2 code as workaround")
|
2021-11-13 13:25:32 +00:00
|
|
|
blake2b.o: OPTFLAGS += -O0
|
|
|
|
blake2s.o: OPTFLAGS += -O0
|
|
|
|
|
2022-01-05 16:11:19 +00:00
|
|
|
else ifeq ($(ADDRESS_SANITIZER),1)
|
2022-01-13 10:33:58 +00:00
|
|
|
SANFLAGS += -fsanitize=address,undefined
|
2020-07-01 12:04:02 +00:00
|
|
|
endif
|
|
|
|
|
2022-04-27 10:04:35 +00:00
|
|
|
CC ?= cc
|
2014-07-07 19:34:54 +00:00
|
|
|
|
2017-04-01 23:07:00 +00:00
|
|
|
OPTFLAGS ?= -O3 -g
|
2014-07-07 19:34:54 +00:00
|
|
|
|
|
|
|
CFLAGS += $(OPTFLAGS) \
|
2022-01-05 16:11:19 +00:00
|
|
|
$(SANFLAGS) \
|
2016-05-12 14:16:01 +00:00
|
|
|
-std=gnu99 \
|
2014-07-07 19:34:54 +00:00
|
|
|
-W \
|
|
|
|
-Wall \
|
|
|
|
-Wextra \
|
|
|
|
-Wimplicit-function-declaration \
|
|
|
|
-Wredundant-decls \
|
|
|
|
-Wstrict-prototypes \
|
2018-04-04 17:28:42 +00:00
|
|
|
-Wundef \
|
2018-04-04 20:13:16 +00:00
|
|
|
-Wshadow \
|
2014-07-07 19:34:54 +00:00
|
|
|
-Wpointer-arith \
|
|
|
|
-Wformat \
|
|
|
|
-Wreturn-type \
|
|
|
|
-Wsign-compare \
|
|
|
|
-Wmultichar \
|
|
|
|
-Wformat-nonliteral \
|
|
|
|
-Winit-self \
|
|
|
|
-Wuninitialized \
|
|
|
|
-Wformat-security \
|
2019-10-11 07:59:32 +00:00
|
|
|
-Wno-missing-braces \
|
2018-04-04 20:13:16 +00:00
|
|
|
-Werror
|
2014-07-07 19:34:54 +00:00
|
|
|
|
2024-04-05 13:44:05 +00:00
|
|
|
ifneq ($(FUZZER),1) # This can be removed once the fuzzer machine uses at least clang 16
|
|
|
|
CFLAGS += -ftrivial-auto-var-init=zero
|
|
|
|
endif
|
|
|
|
|
2021-06-15 14:47:02 +00:00
|
|
|
ZKP_CFLAGS = \
|
|
|
|
-DECMULT_GEN_PREC_BITS=4 \
|
2024-08-02 13:16:48 +00:00
|
|
|
-DECMULT_WINDOW_SIZE=2 \
|
2021-06-17 10:40:50 +00:00
|
|
|
-DENABLE_MODULE_GENERATOR \
|
2021-06-17 15:33:15 +00:00
|
|
|
-DENABLE_MODULE_RECOVERY \
|
|
|
|
-DENABLE_MODULE_SCHNORRSIG \
|
2024-08-02 14:46:43 +00:00
|
|
|
-DENABLE_MODULE_EXTRAKEYS \
|
|
|
|
-DENABLE_MODULE_ECDH
|
2021-06-15 14:47:02 +00:00
|
|
|
ZKP_PATH = ../vendor/secp256k1-zkp
|
2022-08-12 12:04:15 +00:00
|
|
|
# this is specific for 64-bit builds
|
2021-11-03 20:57:07 +00:00
|
|
|
CFLAGS += -DSECP256K1_CONTEXT_SIZE=208
|
2021-06-15 14:47:02 +00:00
|
|
|
|
2018-07-11 19:26:07 +00:00
|
|
|
VALGRIND ?= 1
|
2021-12-20 14:19:14 +00:00
|
|
|
ifeq ($(VALGRIND),1)
|
|
|
|
CFLAGS += -DVALGRIND
|
|
|
|
endif
|
2018-07-11 19:26:07 +00:00
|
|
|
|
2017-05-11 11:27:34 +00:00
|
|
|
CFLAGS += -I.
|
2021-06-15 14:47:02 +00:00
|
|
|
CFLAGS += -I..
|
2016-06-13 21:13:37 +00:00
|
|
|
CFLAGS += -DUSE_ETHEREUM=1
|
2018-07-31 12:20:18 +00:00
|
|
|
CFLAGS += -DUSE_KECCAK=1
|
2018-05-16 00:12:17 +00:00
|
|
|
CFLAGS += -DUSE_MONERO=1
|
2018-07-31 12:20:18 +00:00
|
|
|
CFLAGS += -DUSE_NEM=1
|
2018-06-19 09:50:59 +00:00
|
|
|
CFLAGS += -DUSE_CARDANO=1
|
2023-03-21 14:17:24 +00:00
|
|
|
CFLAGS += -DUSE_INSECURE_PRNG=1
|
2023-06-26 19:17:51 +00:00
|
|
|
CFLAGS += -DAES_128
|
2024-03-18 16:49:20 +00:00
|
|
|
CFLAGS += -DAES_192
|
2024-03-15 14:53:30 +00:00
|
|
|
CFLAGS += -DAES_VAR
|
2018-04-03 15:58:19 +00:00
|
|
|
CFLAGS += $(shell pkg-config --cflags openssl)
|
2014-07-07 19:34:54 +00:00
|
|
|
|
|
|
|
# disable certain optimizations and features when small footprint is required
|
2014-07-03 14:59:41 +00:00
|
|
|
ifdef SMALL
|
2017-01-11 14:33:46 +00:00
|
|
|
CFLAGS += -DUSE_PRECOMPUTED_CP=0
|
2014-07-03 14:59:41 +00:00
|
|
|
endif
|
2014-07-07 19:34:54 +00:00
|
|
|
|
2022-05-31 13:58:34 +00:00
|
|
|
SRCS = bignum.c ecdsa.c curves.c secp256k1.c nist256p1.c rand.c hmac.c bip32.c bip39.c bip39_english.c pbkdf2.c base58.c base32.c
|
2016-10-10 09:22:03 +00:00
|
|
|
SRCS += address.c
|
2016-05-16 12:43:09 +00:00
|
|
|
SRCS += script.c
|
2015-08-05 14:16:24 +00:00
|
|
|
SRCS += ripemd160.c
|
|
|
|
SRCS += sha2.c
|
2016-04-26 09:09:29 +00:00
|
|
|
SRCS += sha3.c
|
2017-12-09 17:59:20 +00:00
|
|
|
SRCS += hasher.c
|
2024-03-15 14:53:30 +00:00
|
|
|
SRCS += aes/aesccm.c aes/aescrypt.c aes/aesgcm.c aes/aeskey.c aes/aestab.c aes/aes_modes.c aes/gf128mul.c
|
2017-07-31 14:40:09 +00:00
|
|
|
SRCS += ed25519-donna/curve25519-donna-32bit.c ed25519-donna/curve25519-donna-helpers.c ed25519-donna/modm-donna-32bit.c
|
|
|
|
SRCS += ed25519-donna/ed25519-donna-basepoint-table.c ed25519-donna/ed25519-donna-32bit-tables.c ed25519-donna/ed25519-donna-impl-base.c
|
|
|
|
SRCS += ed25519-donna/ed25519.c ed25519-donna/curve25519-donna-scalarmult-base.c ed25519-donna/ed25519-sha3.c ed25519-donna/ed25519-keccak.c
|
2018-07-05 00:10:34 +00:00
|
|
|
SRCS += monero/base58.c
|
|
|
|
SRCS += monero/serialize.c
|
|
|
|
SRCS += monero/xmr.c
|
2017-12-09 22:51:16 +00:00
|
|
|
SRCS += blake256.c
|
2017-02-28 17:14:54 +00:00
|
|
|
SRCS += blake2b.c blake2s.c
|
2020-02-29 17:08:19 +00:00
|
|
|
SRCS += chacha_drbg.c
|
2018-03-11 04:35:45 +00:00
|
|
|
SRCS += groestl.c
|
2017-05-11 11:27:34 +00:00
|
|
|
SRCS += chacha20poly1305/chacha20poly1305.c chacha20poly1305/chacha_merged.c chacha20poly1305/poly1305-donna.c chacha20poly1305/rfc7539.c
|
2017-08-12 11:43:49 +00:00
|
|
|
SRCS += rc4.c
|
2017-05-19 17:17:24 +00:00
|
|
|
SRCS += nem.c
|
2018-04-05 09:15:05 +00:00
|
|
|
SRCS += segwit_addr.c cash_addr.c
|
2018-01-18 14:18:09 +00:00
|
|
|
SRCS += memzero.c
|
2019-04-17 15:28:34 +00:00
|
|
|
SRCS += shamir.c
|
2019-06-06 16:48:39 +00:00
|
|
|
SRCS += hmac_drbg.c
|
2019-06-07 10:16:24 +00:00
|
|
|
SRCS += rfc6979.c
|
2019-06-23 10:18:24 +00:00
|
|
|
SRCS += slip39.c
|
2023-05-04 12:14:58 +00:00
|
|
|
SRCS += slip39_english.c
|
2021-06-17 10:37:07 +00:00
|
|
|
SRCS += zkp_context.c
|
2021-06-17 10:40:50 +00:00
|
|
|
SRCS += zkp_ecdsa.c
|
2021-10-19 19:09:59 +00:00
|
|
|
SRCS += zkp_bip340.c
|
2021-10-14 10:41:16 +00:00
|
|
|
SRCS += cardano.c
|
2023-07-20 18:13:51 +00:00
|
|
|
SRCS += tls_prf.c
|
2023-09-15 17:09:54 +00:00
|
|
|
SRCS += hash_to_curve.c
|
2023-11-24 07:38:59 +00:00
|
|
|
SRCS += buffer.c der.c
|
2023-11-29 16:41:28 +00:00
|
|
|
SRCS += elligator2.c
|
2015-08-05 14:16:24 +00:00
|
|
|
|
|
|
|
OBJS = $(SRCS:.c=.o)
|
2021-06-15 14:47:02 +00:00
|
|
|
OBJS += secp256k1-zkp.o
|
2022-01-26 16:49:48 +00:00
|
|
|
OBJS += precomputed_ecmult.o
|
|
|
|
OBJS += precomputed_ecmult_gen.o
|
2013-08-18 15:30:23 +00:00
|
|
|
|
2018-01-12 16:24:47 +00:00
|
|
|
TESTLIBS = $(shell pkg-config --libs check) -lpthread -lm
|
2018-04-03 15:58:19 +00:00
|
|
|
TESTSSLLIBS = $(shell pkg-config --libs openssl)
|
2014-07-04 19:11:27 +00:00
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
all: tools tests
|
2013-08-17 12:20:15 +00:00
|
|
|
|
2014-07-07 18:14:15 +00:00
|
|
|
%.o: %.c %.h options.h
|
2013-08-17 12:20:15 +00:00
|
|
|
$(CC) $(CFLAGS) -o $@ -c $<
|
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
tests: tests/test_check tests/test_openssl tests/test_speed tests/libtrezor-crypto.so tests/aestst
|
2018-04-05 09:15:05 +00:00
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
tests/aestst: aes/aestst.o aes/aescrypt.o aes/aeskey.o aes/aestab.o
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) $^ -o $@
|
2017-08-14 12:25:35 +00:00
|
|
|
|
2018-07-05 00:10:34 +00:00
|
|
|
tests/test_check.o: tests/test_check_cardano.h tests/test_check_monero.h tests/test_check_cashaddr.h tests/test_check_segwit.h
|
2013-09-11 17:02:22 +00:00
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
tests/test_check: tests/test_check.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tests/test_check.o $(OBJS) $(TESTLIBS) -o tests/test_check
|
2016-04-26 00:14:47 +00:00
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
tests/test_speed: tests/test_speed.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tests/test_speed.o $(OBJS) -o tests/test_speed
|
2013-08-17 12:20:15 +00:00
|
|
|
|
2018-04-05 11:26:59 +00:00
|
|
|
tests/test_openssl: tests/test_openssl.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tests/test_openssl.o $(OBJS) $(TESTSSLLIBS) -o tests/test_openssl
|
2018-04-05 11:26:59 +00:00
|
|
|
|
2022-01-26 16:49:48 +00:00
|
|
|
tests/libtrezor-crypto.so: $(SRCS) secp256k1-zkp.o precomputed_ecmult.o precomputed_ecmult_gen.o
|
2024-03-15 14:53:30 +00:00
|
|
|
$(CC) $(CFLAGS) -fPIC -shared $(SRCS) secp256k1-zkp.o precomputed_ecmult.o precomputed_ecmult_gen.o -o tests/libtrezor-crypto.so
|
2015-08-05 14:16:24 +00:00
|
|
|
|
2016-04-28 12:34:36 +00:00
|
|
|
tools: tools/xpubaddrgen tools/mktable tools/bip39bruteforce
|
|
|
|
|
|
|
|
tools/xpubaddrgen: tools/xpubaddrgen.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tools/xpubaddrgen.o $(OBJS) -o tools/xpubaddrgen
|
2016-04-28 12:34:36 +00:00
|
|
|
|
|
|
|
tools/mktable: tools/mktable.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tools/mktable.o $(OBJS) -o tools/mktable
|
2016-04-28 12:34:36 +00:00
|
|
|
|
|
|
|
tools/bip39bruteforce: tools/bip39bruteforce.o $(OBJS)
|
2022-01-05 16:11:19 +00:00
|
|
|
$(CC) $(CFLAGS) tools/bip39bruteforce.o $(OBJS) -o tools/bip39bruteforce
|
2016-04-28 12:34:36 +00:00
|
|
|
|
2020-07-01 12:04:02 +00:00
|
|
|
fuzzer: fuzzer/fuzzer.o $(OBJS)
|
|
|
|
$(CC) $(CFLAGS) fuzzer/fuzzer.o $(OBJS) -o fuzzer/fuzzer
|
|
|
|
|
2022-01-26 16:49:48 +00:00
|
|
|
precomputed_ecmult.o:
|
|
|
|
$(CC) $(CFLAGS) -Wno-unused-function $(ZKP_CFLAGS) -fPIC -c $(ZKP_PATH)/src/precomputed_ecmult.c -o precomputed_ecmult.o
|
2021-10-21 15:35:28 +00:00
|
|
|
|
2022-01-26 16:49:48 +00:00
|
|
|
precomputed_ecmult_gen.o:
|
|
|
|
$(CC) $(CFLAGS) -Wno-unused-function $(ZKP_CFLAGS) -fPIC -c $(ZKP_PATH)/src/precomputed_ecmult_gen.c -o precomputed_ecmult_gen.o
|
|
|
|
|
|
|
|
secp256k1-zkp.o:
|
2021-11-09 12:35:25 +00:00
|
|
|
$(CC) $(CFLAGS) -Wno-unused-function $(ZKP_CFLAGS) -fPIC -I$(ZKP_PATH) -I$(ZKP_PATH)/src -c $(ZKP_PATH)/src/secp256k1.c -o secp256k1-zkp.o
|
2021-06-15 14:47:02 +00:00
|
|
|
|
2013-08-17 12:20:15 +00:00
|
|
|
clean:
|
2020-12-16 23:07:41 +00:00
|
|
|
rm -f *.o aes/*.o chacha20poly1305/*.o ed25519-donna/*.o monero/*.o
|
|
|
|
rm -f tests/*.o tests/test_check tests/test_speed tests/test_openssl tests/libtrezor-crypto.so tests/aestst
|
2016-04-28 12:34:36 +00:00
|
|
|
rm -f tools/*.o tools/xpubaddrgen tools/mktable tools/bip39bruteforce
|
2020-07-01 12:04:02 +00:00
|
|
|
rm -f fuzzer/*.o fuzzer/fuzzer
|
2022-01-26 16:49:48 +00:00
|
|
|
rm -f secp256k1-zkp.o precomputed_ecmult.o precomputed_ecmult_gen.o
|
2020-07-01 12:04:02 +00:00
|
|
|
|
|
|
|
clean-fuzzer: clean
|
|
|
|
rm -f crash-* fuzz-*.log slow-unit-* timeout-*
|