-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
103 lines (77 loc) · 2.87 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
96
97
98
99
100
101
102
# =============== Makefile ===============
# This file wasn't written by the group. It was
# however slightly modified to fit the project
# and work style of the group.
#
# Source: https://github.com/is1200-example-projects/hello-temperature
#
# Modifications:
# 1. An additional flag (-std=c99) was added to CFLAGS to enable more modern C
# 2. An additional flag (-mn) was added to LDFLAGS to enable compiling with the math.h library
#
# Modifiers: Fridh, William & Åhlin, Pontus
# PIC32 device number
DEVICE = 32MX320F128H
# UART settings for programmer
TTYDEV ?=/dev/ttyUSB0
TTYBAUD ?=115200
# Name of the project
PROGNAME = outfile
# Linkscript
LINKSCRIPT := p$(shell echo "$(DEVICE)" | tr '[:upper:]' '[:lower:]').ld
# Compiler and linker flags
CFLAGS += -ffreestanding -march=mips32r2 -msoft-float -Wa,-msoft-float -std=c99
ASFLAGS += -msoft-float
LDFLAGS += -T $(LINKSCRIPT) -lm
# Filenames
ELFFILE = $(PROGNAME).elf
HEXFILE = $(PROGNAME).hex
# Find all source files automatically
CFILES = $(wildcard *.c)
ASFILES = $(wildcard *.S)
SYMSFILES = $(wildcard *.syms)
# Object file names
OBJFILES = $(CFILES:.c=.c.o)
OBJFILES +=$(ASFILES:.S=.S.o)
OBJFILES +=$(SYMSFILES:.syms=.syms.o)
# Hidden directory for dependency files
DEPDIR = .deps
df = $(DEPDIR)/$(*F)
.PHONY: all clean install envcheck
.SUFFIXES:
all: $(HEXFILE)
clean:
$(RM) $(HEXFILE) $(ELFFILE) $(OBJFILES)
$(RM) -R $(DEPDIR)
envcheck:
@echo "$(TARGET)" | grep mcb32 > /dev/null || (\
echo ""; \
echo " **************************************************************"; \
echo " * Make sure you have sourced the cross compiling environment *"; \
echo " * Do this by issuing: *"; \
echo " * . /path/to/crosscompiler/environment *"; \
echo " **************************************************************"; \
echo ""; \
exit 1)
install: envcheck
$(TARGET)avrdude -v -p $(shell echo "$(DEVICE)" | tr '[:lower:]' '[:upper:]') -c stk500v2 -P "$(TTYDEV)" -b $(TTYBAUD) -U "flash:w:$(HEXFILE)"
$(ELFFILE): $(OBJFILES) envcheck
$(CC) $(CFLAGS) -o $@ $(OBJFILES) $(LDFLAGS)
$(HEXFILE): $(ELFFILE) envcheck
$(TARGET)bin2hex -a $(ELFFILE)
$(DEPDIR):
@mkdir -p $@
# Compile C files
%.c.o: %.c envcheck | $(DEPDIR)
$(CC) $(CFLAGS) -c -MD -o $@ $<
@cp $*.c.d $(df).c.P; sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' -e '/^$$/ d' -e 's/$$/ :/' < $*.c.d >> $(df).c.P; $(RM) $*.c.d
# Compile ASM files with C pre-processor directives
%.S.o: %.S envcheck | $(DEPDIR)
$(CC) $(CFLAGS) $(ASFLAGS) -c -MD -o $@ $<
@cp $*.S.d $(df).S.P; sed -e 's/#.*//' -e 's/^[^:]*: *//' -e 's/ *\\$$//' -e '/^$$/ d' -e 's/$$/ :/' < $*.S.d >> $(df).S.P; $(RM) $*.S.d
# Link symbol lists to object files
%.syms.o: %.syms
$(LD) -o $@ -r --just-symbols=$<
# Check dependencies
-include $(CFILES:%.c=$(DEPDIR)/%.c.P)
-include $(ASFILES:%.S=$(DEPDIR)/%.S.P)