blob: 8ca11a9b27fc544888cb27cf068239e9c0a8e23c (
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
101
|
# 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
# TODO: move debug.h and test-helpers.h here
|