UNPKG

fourq

Version:

99 lines (71 loc) 2.39 kB
#### Makefile for compilation using GNU GCC or clang on 32-bit processors #### OPT=-O3 # Optimization option by default CC=gcc ifeq "$(CC)" "gcc" COMPILER=gcc else ifeq "$(CC)" "clang" COMPILER=clang endif ifeq "$(ARCH)" "x86" ARCHITECTURE=_X86_ else ifeq "$(ARCH)" "ARM" ARCHITECTURE=_ARM_ endif ADDITIONAL_SETTINGS=-fwrapv -fomit-frame-pointer -funroll-loops -march=native ifeq "$(EXTENDED_SET)" "FALSE" ADDITIONAL_SETTINGS= endif ifeq "$(ARCH)" "ARM" ARM_SETTING=-lrt endif USE_ENDOMORPHISMS=-D USE_ENDO ifeq "$(USE_ENDO)" "FALSE" USE_ENDOMORPHISMS= endif INLINING_SETTINGS= ifeq "$(CC)" "gcc" INLINING_SETTINGS=-finline-functions -finline-limit=100 endif MEM=-D _CACHE_MEM_ ifeq "$(CACHE_MEM)" "FALSE" MEM=-D _NO_CACHE_MEM_ endif CFLAGS=-c $(OPT) -D $(ARCHITECTURE) $(ADDITIONAL_SETTINGS) -D __LINUX__ $(USE_ENDOMORPHISMS) $(MEM) $(INLINING_SETTINGS) LDFLAGS= OBJECTS=eccp2.o eccp2_no_endo.o crypto_util.o schnorrq.o kex.o sha512.o random.o OBJECTS_ECC_TEST=ecc_tests.o test_extras.o $(OBJECTS) OBJECTS_FP_TEST=$(OBJECTS) fp_tests.o test_extras.o OBJECTS_CRYPTO_TEST=crypto_tests.o $(OBJECTS) test_extras.o OBJECTS_ALL=$(OBJECTS) $(OBJECTS_ECC_TEST) $(OBJECTS_FP_TEST) $(OBJECTS_CRYPTO_TEST) all: crypto_test ecc_test fp_test crypto_test: $(OBJECTS_CRYPTO_TEST) $(CC) -o crypto_test $(OBJECTS_CRYPTO_TEST) $(ARM_SETTING) ecc_test: $(OBJECTS_ECC_TEST) $(CC) -o ecc_test $(OBJECTS_ECC_TEST) $(ARM_SETTING) fp_test: $(OBJECTS_FP_TEST) $(CC) -o fp_test $(OBJECTS_FP_TEST) $(ARM_SETTING) eccp2.o: eccp2.c $(CC) $(CFLAGS) eccp2.c eccp2_no_endo.o: eccp2_no_endo.c $(CC) $(CFLAGS) eccp2_no_endo.c schnorrq.o: schnorrq.c $(CC) $(CFLAGS) schnorrq.c kex.o: kex.c $(CC) $(CFLAGS) kex.c crypto_util.o: crypto_util.c $(CC) $(CFLAGS) crypto_util.c sha512.o: ../sha512/sha512.c $(CC) $(CFLAGS) ../sha512/sha512.c random.o: ../random/random.c $(CC) $(CFLAGS) ../random/random.c test_extras.o: tests/test_extras.c $(CC) $(CFLAGS) tests/test_extras.c crypto_tests.o: tests/crypto_tests.c $(CC) $(CFLAGS) tests/crypto_tests.c ecc_tests.o: tests/ecc_tests.c $(CC) $(CFLAGS) tests/ecc_tests.c fp_tests.o: tests/fp_tests.c $(CC) $(CFLAGS) tests/fp_tests.c .PHONY: clean clean: rm -f crypto_test ecc_test fp_test $(OBJECTS_ALL)