-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathMakefile
95 lines (76 loc) · 2.45 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
84
85
86
87
88
89
90
91
92
93
94
95
# regbits: C++ templates for type-safe bit manipulation
# Copyright (C) 2019,2020 Mark R. Rubin
#
# This file is part of regbits.
#
# The regbits program is free software: you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# The regbits program is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public
# License (LICENSE.txt) along with the regbits program. If not, see
# <https://www.gnu.org/licenses/gpl.html>
CXX_STANDARD ?= c++11
OPTIMIZE ?= -O1
DEBUG ?= -g3
GCC_ARM_BUG ?= -DGCC_ARM_BUG
EXTRA_CC ?=
EXTRA_CXX ?=
PERIPH_BASE ?= 0x700000
BRK ?= 0x800000
BRK_MALLOC ?= -DUSE_BRK
C_ELFS = $(subst ../,,$(wildcard ../*.c))
CXX_ELFS = $(subst ../,,$(wildcard ../*.cxx))
ELFS = $(subst .c,.elf,$(C_ELFS)) $(subst .cxx,.elf,$(CXX_ELFS))
DMPS = $(subst .elf,.elf.dmp,$(ELFS)) $(subst .elf,.o.dmp,$(ELFS))
OUTS = $(subst .elf,.out,$(ELFS))
unittest: main.o ../do_tests.inl $(ELFS) $(DMPS) $(OUTS)
@ ../unittest.py intel '$(OPTIMIZE) $(DEBUG) $(GCC_ARM_BUG) $(EXTRA_CXX) $(CXX_STANDARD)' ../do_tests.inl *.out *.o.dmp > results.txt
# manual check that all tests change at least one tracked register
uniq: regbits.out
uniq -f 1 --group regbits.out
.PHONY: clean cleanbin
clean: cleanbin
@ rm -f *.dmp *.out results.txt
cleanbin:
@ rm -f *.o *.elf
.PRECIOUS: %.o %.elf
INCLUDES = -I.. -I../..
vpath %c ..
vpath %cxx ..
CCOPTS = -Wall \
-Wno-unused-const-variable \
$(OPTIMIZE) \
$(DEBUG) \
$(INCLUDES) \
$(EXTRA_CC) \
-DBRK=$(BRK) \
$(BRK_MALLOC) \
-DREGBITS_PERIPH_BASE=$(PERIPH_BASE)
CXXOPTS = -Wall \
-std=$(CXX_STANDARD) \
$(OPTIMIZE) \
$(DEBUG) \
$(INCLUDES) \
$(GCC_ARM_BUG) \
$(EXTRA_CXX) \
-DREGBITS_PERIPH_BASE=$(PERIPH_BASE)
%.elf: %.o main.o
@ $(CXX) -o $@ $^
%.elf.dmp: %.elf
@ objdump -dC -j.text -j.rodata -j.data $< > $@
%.out: %.elf
@ rm -f $@
@ gdb -q -x ../$(subst .elf,.gdb,$^) -x unittest.gdb $< > /dev/null
%.o.dmp: %.o
@ objdump -dC -j.text -j.rodata -j.data $< > $@
%.o: %.c
@ $(CC) -c $(CCOPTS) $< -o $@
%.o: %.cxx
@ $(CXX) -c $(CXXOPTS) $< -o $@