summaryrefslogtreecommitdiff
path: root/test/common.mk
blob: 615543fbf3065769fda719fa8fb27173417dcbf8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# use "make VERBOSE=1" to have full commands printed out.
VERBOSE = 0
ifeq ($(VERBOSE),1)
Q =
else
Q = @
endif


tests = $(basename $(wildcard test-*.c))
traces = $(basename $(wildcard traces-*.c))


test_dir = $(dir $(lastword $(MAKEFILE_LIST)))
root_dir = $(test_dir)..
results_dir = $(root_dir)/results/$(mode)-$(keylen)
src_dir = $(root_dir)/src
variant_dir = $(src_dir)/$(mode)-$(keylen)


nist_flags = -std=c99 -Wall -Wextra -Wshadow -fsanitize=address,undefined -O2
CFLAGS += -I$(src_dir) -I$(variant_dir) -I$(test_dir) $(nist_flags) -Werror
LDFLAGS += $(nist_flags)


.PHONY: clean test $(tests) traces $(traces)


clean:
	- rm -r $(results_dir)

$(results_dir) $(results_dir)/src $(results_dir)/test:
	@ mkdir -p $@

test: $(tests)
trace: $(traces)

$(tests): test-%: $(results_dir)/test-%
	@ echo "TEST $@"
	$(Q) $<

$(traces): traces-%: $(results_dir)/traces-%
	@ echo "TRACES $@"
	$(Q) $< $(results_dir) $*-$(mode)-$(keylen)

$(results_dir)/test-%: $(results_dir)/test/test-%.o
	@ echo "LD $@"
	$(Q) gcc $^ $(LDFLAGS) -o $@

$(results_dir)/traces-%: $(results_dir)/test/traces-%.o
	@ echo "LD $@"
	$(Q) gcc $^ $(LDFLAGS) -o $@

$(results_dir)/test/%.o: %.c $(test_dir)/test-helpers.h | $(results_dir)/test
	@ echo "CC $@"
	$(Q) gcc -c $< $(CFLAGS) -o $@

$(results_dir)/src/%.o: $(src_dir)/%.c | $(results_dir)/src
	@ echo "CC $@"
	$(Q) gcc -c $< $(CFLAGS) -o $@


# Program => additional objects dependencies

$(results_dir)/test-tbc-decrypt $(results_dir)/test-tbc-encrypt $(results_dir)/traces-tbc:      \
$(results_dir)/src/cipher.o $(results_dir)/src/tweakey.o                                        \
$(results_dir)/src/constants.o

$(results_dir)/test-ae-decrypt $(results_dir)/test-ae-encrypt $(results_dir)/test-ae-roundtrip $(results_dir)/traces-ae: \
$(results_dir)/src/lilliput-ae-$(mode).o $(results_dir)/src/cipher.o                                                     \
$(results_dir)/src/tweakey.o $(results_dir)/src/constants.o

$(results_dir)/test-tweakey:                                    \
$(results_dir)/src/tweakey.o $(results_dir)/src/constants.o

# Object => headers dependencies

$(results_dir)/$(src_dir)/cipher.o: $(src_dir)/cipher.h                 \
$(src_dir)/tweakey.h $(src_dir)/constants.h $(src_dir)/parameters.h     \
$(variant_dir)/_parameters.h

$(results_dir)/$(src_dir)/constants.o: $(src_dir)/constants.h

$(results_dir)/$(src_dir)/lilliput-ae-i.o $(results_dir)/$(src_dir)/lilliput-ae-ii.o:   \
$(src_dir)/lilliput-ae.h $(src_dir)/cipher.h $(src_dir)/parameters.h                    \
$(variant_dir)/_parameters.h

$(results_dir)/$(src_dir)/tweakey.o: $(src_dir)/tweakey.h       \
$(src_dir)/constants.h $(src_dir)/parameters.h                  \
$(variant_dir)/_parameters.h

$(results_dir)/test/test-tbc-encrypt.o $(results_dir)/test/test-tbc-decrypt.o $(results_dir)/test/traces-tbc.o: \
$(src_dir)/cipher.h

$(results_dir)/test/test-ae-encrypt.o $(results_dir)/test/test-ae-decrypt.o $(results_dir)/test/test-ae-roundtrip.o $(results_dir)/test/traces-ae.o: \
$(src_dir)/lilliput-ae.h


# TODO: add valgrind, although it does not seem to play well with ASAN
# TODO: should use gcc -M... to generate .o -> .h dependencies