-
Notifications
You must be signed in to change notification settings - Fork 121
/
Copy pathMakefile
83 lines (68 loc) · 1.61 KB
/
Makefile
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
.POSIX:
BITS = 32
CC = gcc
CFLAGS = -ggdb3 -m$(BITS) -O0 -pedantic-errors -std=c99 -Wall -Wextra -pedantic
# To match nasm.
DISAS_FLAVOR = intel
GAS_EXT = .S
LIB_DIR = lib/
NASM = nasm -f elf$(BITS) -gdwarf -w+all
NASM_EXT = .asm
OBJ_EXT = .o
OUT_EXT = .out
PHONY_MAKES =
RUN = main
TEST = test
export
ifeq ($(TRAVIS),)
CFLAGS += -fno-pie -no-pie
endif
-include params.makefile
OUTS := $(foreach IN_EXT,$(GAS_EXT) $(NASM_EXT),$(patsubst %$(IN_EXT),%$(OUT_EXT),$(wildcard *$(IN_EXT))))
.PRECIOUS: %$(OBJ_EXT)
.PHONY: all clean driver run test $(PHONY_MAKES)
all: driver $(OUTS) $(PHONY_MAKES)
for phony in $(PHONY_MAKES); do \
$(MAKE) -C $${phony}; \
done
%$(OUT_EXT): %$(OBJ_EXT)
$(CC) $(CFLAGS) -o '$@' '$<' $(LIB_DIR)*$(OBJ_EXT)
%$(OBJ_EXT): %$(NASM_EXT)
$(NASM) -o '$@' '$<'
%$(OBJ_EXT): %$(GAS_EXT)
$(CC) $(CFLAGS) -c -o '$@' '$<'
clean:
rm -f *$(OBJ_EXT) *$(OUT_EXT)
$(MAKE) -C $(LIB_DIR) '$@'
for phony in $(PHONY_MAKES); do \
$(MAKE) -C $${phony} clean; \
done
driver:
$(MAKE) -C $(LIB_DIR)
gdb-%: %$(OUT_EXT)
gdb -q --nh -ex 'set disassembly-flavor $(DISAS_FLAVOR)' -ex 'layout split' -ex 'break asm_main' -ex 'run' '$<'
gdb2-%: %$(OUT_EXT)
gdb -q -ex 'break asm_main' -ex 'run' '$<'
run-%: %$(OUT_EXT)
./'$<'
test: all
@\
if [ -x $(TEST) ]; then \
./$(TEST) '$(OUT_EXT)' ;\
else\
fail=false ;\
for t in *"$(OUT_EXT)"; do\
if ! ./"$$t"; then \
fail=true ;\
break ;\
fi ;\
done ;\
if $$fail; then \
echo "TEST FAILED: $$t" ;\
exit 1 ;\
fi ;\
fi; \
for phony in $(PHONY_MAKES); do \
$(MAKE) -C $${phony} test; \
done; \
echo 'ALL TESTS PASSED'