-
Notifications
You must be signed in to change notification settings - Fork 32
/
Copy pathMakefile
187 lines (144 loc) · 4.48 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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
# Basic configuration
BOARD?=WZ10
PYTHON?=python
BUILD?=RELEASE
MOD?=DEFAULT
# Board-specific configuration
MCU_WZ10:=atmega88p
F_CPU_WZ10:=20000000
PROG_WZ10:=usbasp
AVRDUDE_FLAGS_WZ10:=-B1
MCU_ARDUINO_UNO:=atmega328p
F_CPU_ARDUINO_UNO:=16000000
PROG_ARDUINO_UNO:=arduino
AVRDUDE_FLAGS_ARDUINO_UNO:=-P /dev/ttyACM0
MCU?=$(MCU_$(BOARD))
F_CPU?=$(F_CPU_$(BOARD))
PROG?=$(PROG_$(BOARD))
AVRDUDE_FLAGS=$(AVRDUDE_FLAGS_$(BOARD))
# Binary utils
CC=avr-gcc
CXX=avr-g++
LD=avr-ld
AR=avr-ar
AS=avr-gcc -c
OBJCOPY=avr-objcopy
OBJDUMP=avr-objdump
SIZE=avr-size
RM=rm -f --
IMAGE2C=$(UTILS_DIR)/image2c.py
EEPROM_UTIL=$(UTILS_DIR)/eeprom_util.py
CALCULATE_NEEDLE_COORDINATES=$(UTILS_DIR)/calculate_needle_coordinates.py
# Directories
TARGET=main
SRC_DIR=src
UTILS_DIR=utils
BUILD_DIR?=build/$(BUILD)
ifeq "$(MOD)" "DEFAULT"
IMAGES_DIR=src/images/
else
IMAGES_DIR=src/mods/$(MOD)/
endif
# Sources and object files
C_SRC= \
$(SRC_DIR)/utils.c \
$(SRC_DIR)/fault.c \
$(SRC_DIR)/benchmark.c \
$(SRC_DIR)/ring_buffer.c \
$(SRC_DIR)/i2c_hw.c \
$(SRC_DIR)/i2c.c \
$(SRC_DIR)/oled.c \
$(SRC_DIR)/display.c \
$(SRC_DIR)/progmem_image_sprite.c \
$(SRC_DIR)/needle_coordinates.c \
$(SRC_DIR)/needle_sprite.c \
$(SRC_DIR)/adc.c \
$(SRC_DIR)/calibration.c \
$(SRC_DIR)/$(TARGET).c
C_OBJS=$(patsubst $(SRC_DIR)/%.c,$(BUILD_DIR)/%.o,$(C_SRC))
IMAGES=$(wildcard $(IMAGES_DIR)/*.bmp)
IMAGE_SRC=$(patsubst $(IMAGES_DIR)/%.bmp,$(BUILD_DIR)/%.c,$(IMAGES))
IMAGE_OBJS=$(patsubst $(IMAGES_DIR)/%.bmp,$(BUILD_DIR)/%.o,$(IMAGES))
OBJS=$(C_OBJS) $(IMAGE_OBJS)
# Compilation flags
CFLAGS+=-mmcu=$(MCU)
CFLAGS+=-DF_CPU="$(F_CPU)UL"
CFLAGS+=-MD -MP
CFLAGS+=-Wall
CFLAGS+=-Werror
CFLAGS+=-std=c99
CFLAGS+=-ffunction-sections -fdata-sections
CFLAGS+=-funsigned-char -funsigned-bitfields
CFLAGS+=-fpack-struct -fshort-enums
CFLAGS+=-frename-registers
CFLAGS+=-g
CFLAGS+=-Wa,-ahlmsd=$(@:.o=.lst)
ifneq "$(MOD)" "DEFAULT"
CFLAGS+=-include src/mods/$(MOD)/config.h
endif
CFLAGS_DEBUG=-O0
CFLAGS_RELEASE=-O2 -DNDEBUG
CFLAGS+=$(CFLAGS_$(BUILD))
LDFLAGS+=-mmcu=$(MCU)
LDFLAGS+=-static
LDFLAGS+=-Wl,-Map=$(BUILD_DIR)/map.map,--cref
LDFLAGS+=-Wl,--section-start=.eefixed=0x810080
LDFLAGS+=-Wl,-gc-sections
#LDFLAGS += -Wl,-u,vfprintf -lprintf_min
#LDFLAGS += -Wl,-u,vfprintf -lprintf_flt
#LDFLAGS+=-g
#LDLIBS+=-lm
ASFLAGS+=-mmcu=$(MCU)
ASFLAGS+=-DF_CPU="$(F_CPU)UL"
ASFLAGS+=-x assembler-with-cpp
ASFLAGS+=-Wa,-ahlms=$(<:.s=.lst),-g,--gstabs
# Default target
all: $(BUILD_DIR)/$(TARGET).hex $(BUILD_DIR)/$(TARGET).eep
# Compilation targets
$(BUILD_DIR)/$(TARGET): $(OBJS)
$(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) $(TARGET_ARCH) $^ $(LOADLIBES) $(LDLIBS) -o $@
$(BUILD_DIR)/$(TARGET).hex: $(BUILD_DIR)/$(TARGET)
$(OBJCOPY) -R .eeprom -R .eefixed -O ihex $< $@
$(BUILD_DIR)/$(TARGET).eep: $(BUILD_DIR)/$(TARGET)
$(OBJCOPY) -j .eeprom --change-section-lma .eeprom=0 -j .eefixed --change-section-lma .eefixed=0x80 -O ihex $< $@
$(BUILD_DIR)/%.o: $(SRC_DIR)/%.c Makefile
$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c -o $@ $<
# Generated files
$(IMAGE_SRC): $(BUILD_DIR)/%.c : $(IMAGES_DIR)/%.bmp $(IMAGE2C) Makefile
$(PYTHON) $(IMAGE2C) $< $@ IMG_$(basename $(notdir $@)) inverted
$(IMAGE_OBJS): $(BUILD_DIR)/%.o: $(BUILD_DIR)/%.c Makefile
$(CC) $(CFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c -o $@ $<
# Phony targets
summary: $(BUILD_DIR)/$(TARGET)
@echo "FLASH (.text)"
@nm --print-size --size-sort --radix=d $(BUILD_DIR)/main | grep -i ' t '
@echo
@echo "RAM uninitialized (.bss)"
@nm --print-size --size-sort --radix=d $(BUILD_DIR)/main | grep -i ' b '
@echo
@echo "RAM / EEPROM initialized (.data)"
@nm --print-size --size-sort --radix=d $(BUILD_DIR)/main | grep -i ' d '
@echo
@echo "Summary"
@$(SIZE) $(BUILD_DIR)/$(TARGET)
dump_eeprom: utils/eeprom_util.py
avrdude -p $(MCU) -c $(PROG) $(AVRDUDE_FLAGS) -U eeprom:r:-:i 2>/dev/null | $(PYTHON) $(EEPROM_UTIL)
install: install_fuse_bytes install_flash install_eeprom
install_flash: $(BUILD_DIR)/$(TARGET).hex
avrdude -p $(MCU) -c $(PROG) $(AVRDUDE_FLAGS) -U flash:w:$(BUILD_DIR)/$(TARGET).hex
install_eeprom: $(BUILD_DIR)/$(TARGET).eep
avrdude -p $(MCU) -c $(PROG) $(AVRDUDE_FLAGS) -U eeprom:w:$(BUILD_DIR)/$(TARGET).eep
install_fuse_bytes:
avrdude -p $(MCU) -c $(PROG) -B1000 -U lfuse:w:0xE6:m -U hfuse:w:0xD4:m
clean:
$(RM) $(BUILD_DIR)/$(TARGET)
$(RM) $(BUILD_DIR)/*.c
$(RM) $(BUILD_DIR)/*.o
$(RM) $(BUILD_DIR)/*.d
$(RM) $(BUILD_DIR)/*.lst
$(RM) $(BUILD_DIR)/*.map
$(RM) $(BUILD_DIR)/*.hex
$(RM) $(BUILD_DIR)/*.eep
.PHONY: all summary install_fuse_bytes install clean dump_eeprom
# Dependencies
-include $(C_OBJS:.o=.d)