-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
55 lines (38 loc) · 1.13 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
#
# Nikita Ermoshkin (ne75)
# Eric Dai (emd88)
#
# September 2017
#
# put a config.mk file in same directory as makefile
include config.mk
CC = $(XC32)/xc32-gcc
BIN2HEX = $(XC32)/xc32-bin2hex
OBJDIR = ./build
TARGET = capacitance_meter
PROCESSOR = 32MX250F128B
LOADTOOL = PKOB
TFT_DIR = $(UTILS_DIR)/tft
PT_DIR = $(UTILS_DIR)/protothreads
INCLUDES = -I$(UTILS_DIR) -I$(PT_DIR) -I$(TFT_DIR)
CFLAGS = -g -x c -c -mprocessor=$(PROCESSOR) -no-legacy-libc -D_SUPPRESS_PLIB_WARNING=1 -D_DISABLE_OPENADC10_CONFIGPORT_WARNING
LFLAGS = -no-legacy-libc -mprocessor=$(PROCESSOR)
LOADFLAGS = -TP$(LOADTOOL) -P$(PROCESSOR) -OL -M
.PHONY: all setup load clean
all: setup $(OBJDIR)/$(TARGET).hex load clean-output
setup:
mkdir -p $(OBJDIR)
$(OBJDIR)/$(TARGET).hex: $(OBJDIR)/$(TARGET).elf
$(BIN2HEX) $<
$(OBJDIR)/$(TARGET).elf: $(OBJDIR)/tft.o $(OBJDIR)/main.o
$(CC) $(LFLAGS) -o $@ $^
$(OBJDIR)/main.o: main.c
$(CC) $(INCLUDES) $(CFLAGS) -o $@ $<
$(OBJDIR)/tft.o: $(TFT_DIR)/tft_unity.c
$(CC) $(INCLUDES) $(CFLAGS) -o $@ $<
load: $(OBJDIR)/$(TARGET).hex
$(LOADER) $(LOADFLAGS) -F$<
clean-output:
rm *.xml && rm log.*
clean:
rm -rf $(OBJDIR)/*