-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathcommon.mk
102 lines (75 loc) · 1.99 KB
/
common.mk
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
##
# Common settings for Makefiles
#
# Stefan Wendler, sw@kaltpost.de
##
# compiler prefix
PREFIX ?= msp430-
CC = $(PREFIX)gcc
LD = $(PREFIX)gcc
OBJCOPY = $(PREFIX)objcopy
OBJDUMP = $(PREFIX)objdump
INCDIR += -I./include
CFLAGS += -Os -mmcu=msp430g2231 -g -Wall -Wextra $(INCDIR)
LIBDIR =
LIBS =
LDFLAGS += -mmcu=msp430g2231 $(LIBDIR) $(LIBS)
# where to put generated binaries to
BINDIR ?= ../bin
# doxygen executable
DOXYGEN = doxygen
# doxygen flags
DOXYGENFLAGS = ../doxygen.conf
# styler to use
STYLER = astyle
# which c-style to use
# - see man astyle
STYLERFLAGS = --style=stroustrup
# cpp checker
CHECKER = cppcheck
# flags for checker
# CHECKERFLAGS = --error-exitcode=1 --enable=all
CHECKERFLAGS = --enable=all --error-exitcode=1
.SUFFIXES: .elf .bin .hex .srec .list .images
.SECONDEXPANSION:
.SECONDARY:
all: images
images: $(BINARY).images
%.images: %.bin %.hex %.srec %.list
@#echo "*** $* images generated ***"
%.bin: %.elf
@#printf " OBJCOPY $(*).bin\n"
$(OBJCOPY) -Obinary $(*).elf $(*).bin && cp $(*).bin $(BINDIR)/.
%.hex: %.elf
@#printf " OBJCOPY $(*).hex\n"
$(OBJCOPY) -Oihex $(*).elf $(*).hex && cp $(*).hex $(BINDIR)/.
%.srec: %.elf
@#printf " OBJCOPY $(*).srec\n"
$(OBJCOPY) -Osrec $(*).elf $(*).srec && cp $(*).srec $(BINDIR)/.
%.list: %.elf
@#printf " OBJDUMP $(*).list\n"
$(OBJDUMP) -S $(*).elf > $(*).list && cp $(*).list $(BINDIR)/.
%.elf: $(OBJS) $(LDSCRIPT)
@#printf " LD $(subst $(shell pwd)/,,$(@))\n"
$(LD) $(OBJS) $(LDFLAGS) -o $(*).elf && cp $(*).elf $(BINDIR)/.
%.o: %.c Makefile
@#printf " CC $(subst $(shell pwd)/,,$(@))\n"
$(CC) $(CFLAGS) -o $@ -c $<
%.o: %.cpp Makefile
@#printf " CC $(subst $(shell pwd)/,,$(@))\n"
$(CC) $(CFLAGS) -o $@ -c $<
SRC = $(wildcard *.c)
HDR = $(wildcard include/*.h)
style:
$(STYLER) $(STYLERFLAGS) $(SRC)
$(STYLER) $(STYLERFLAGS) $(HDR)
clean:
rm -f *.o
rm -f *.d
rm -f *.elf
rm -f *.bin
rm -f *.hex
rm -f *.srec
rm -f *.list
rm -f *.orig
.PHONY: images clean