-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathMakefile
More file actions
149 lines (113 loc) · 4.25 KB
/
Makefile
File metadata and controls
149 lines (113 loc) · 4.25 KB
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
#------------------------------------------------------------------------------
#------------------------------------------------------------ configuration ---
#--------------------------------
# Hardware specific configuration
#--------------------------------
DEVICE = attiny824
CLOCK = 1250000
#------
# Tools
#------
PYMCUPROG_WRITE = pymcuprog write -t uart -u /dev/ttyUSB0 -d $(DEVICE) -c 125k
CC = avr-gcc
OBJCOPY = avr-objcopy
AVR-SIZE = avr-size
OBJDUMP = avr-objdump
#------------------------------------------------------------------------------
#----------------------------------------- no user serviceable parts inside ---
.PHONY: all all-chem all-one all-LTO all-NAION clean flash eeprom flash_isp dirs
OUTDIR := ./build
# Create FW version number from the latest git tag.
FW_VERSION ?= dev
CHEMISTRY ?= LTO
ifeq ($(filter $(CHEMISTRY),LTO NAION),)
$(error CHEMISTRY must be LTO or NAION)
endif
OBJDIR := $(OUTDIR)/obj-$(CHEMISTRY)-$(FW_VERSION)
TARGET = $(OUTDIR)/main-$(CHEMISTRY)-$(FW_VERSION)
EEPROM_BIN = $(OUTDIR)/eeprom-$(CHEMISTRY)-$(FW_VERSION).bin
EEPROM_HEX = $(OUTDIR)/eeprom-$(CHEMISTRY)-$(FW_VERSION).hex
SRC_DIR := ./ ../config $(sort $(dir $(wildcard ../libs/*/))) $(sort $(dir $(wildcard ../libs/*/*/)))
SOURCES := $(foreach sdir,$(SRC_DIR),$(wildcard $(sdir)*.c))
OBJECTS := $(addprefix $(OBJDIR)/,$(notdir $(SOURCES:.c=.o)))
INCLUDES := -I. $(addprefix -I,$(SRC_DIR))
LDFLAGS += -Wl,--relax
LDFLAGS += -Wl,--gc-sections
CFLAGS += -std=gnu99
CFLAGS += -Os
CFLAGS += -mmcu=$(DEVICE)
CFLAGS += -DF_CPU=$(CLOCK) $(if $(DEBUG),-DDEBUG_ENABLE)
CFLAGS += -DFW_VERSION=\"$(FW_VERSION)\"
CFLAGS += -DCELL_$(CHEMISTRY)
CFLAGS += -Wall
CFLAGS += -Winline
CFLAGS += -Wstrict-prototypes
CFLAGS += -ffunction-sections
CFLAGS += -fdata-sections
CFLAGS += $(INCLUDES)
CFLAGS += -funsigned-char
CFLAGS += -fdiagnostics-color=always
# default target
all: all-chem
all-chem: all-LTO all-NAION
all-LTO:
$(MAKE) all-one CHEMISTRY=LTO FW_VERSION=$(FW_VERSION)
all-NAION:
$(MAKE) all-one CHEMISTRY=NAION FW_VERSION=$(FW_VERSION)
all-one: dirs hex bin
help:
@echo
@echo Help:
@echo make ....................... compile
@echo make flash ................. write firmware to the device
@echo make fuses ................. write fuses to the device
@echo make eeprom ................ write eeprom config to the device
@echo make lst ................... export assembly from elf
@echo make size .................. print used memory
@echo make clean ................. clean all
clean:
rm -rf $(OUTDIR)
dirs:
mkdir -p $(OUTDIR) $(OBJDIR)
release: all
@cp $(TARGET).bin $(CNF)-$(FW_VERSION).bin
@cp $(TARGET).hex $(CNF)-$(FW_VERSION).hex
@cp $(TARGET).elf $(CNF)-$(FW_VERSION).elf
flash:
ifeq ($(FW_FILE),)
$(MAKE) all-one
$(PYMCUPROG_WRITE) -f $(TARGET).hex --erase
else
@echo "Flashing provided firmware: $(FW_FILE)"
$(PYMCUPROG_WRITE) -f $(FW_FILE) --erase
endif
fuses: fuses.hex
$(PYMCUPROG_WRITE) -f $<
eeprom: $(EEPROM_HEX)
$(PYMCUPROG_WRITE) -f $<
hex: $(TARGET).hex
bin: $(TARGET).bin
lst: $(TARGET).elf
$(OBJDUMP) -d $(TARGET).elf > $(TARGET).lst
$(TARGET).elf: $(OBJECTS)
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
$(TARGET).hex: $(TARGET).elf
$(OBJCOPY) -R eeprom -O ihex $(TARGET).elf $(TARGET).hex
$(TARGET).bin: $(TARGET).elf
$(OBJCOPY) -R eeprom -O binary $(TARGET).elf $(TARGET).bin
$(EEPROM_HEX): FORCE
@if [ -z "$(SN)" ]; then echo "Missing SN variable!"; exit 1; fi
python tools/eeprom.py --chemistry $(CHEMISTRY) --sn $(SN) $(if $(TO),--temp-offset $(TO)) --file $(EEPROM_BIN)
@objcopy --input-target=binary --output-target=ihex --change-addresses=0x810000 $(EEPROM_BIN) $@
$(OBJDIR)/%.o: %.c
$(CC) $(CFLAGS) -c -o $@ $<
$(OBJDIR)/%.o: ../libs/*/%.c
$(CC) $(CFLAGS) -c -o $@ $<
$(OBJDIR)/%.o: ../libs/*/*/%.c
$(CC) $(CFLAGS) -c -o $@ $<
size: dirs $(TARGET).elf
@echo " SIZES"
@$(OBJDUMP) -h $(TARGET).elf | perl -MPOSIX -ne '/.(text)\s+([0-9a-f]+)/ && do { $$a += eval "0x$$2" }; END { printf " FLASH : %5d bytes\n", $$a }'
@$(OBJDUMP) -h $(TARGET).elf | perl -MPOSIX -ne '/.(data|bss)\s+([0-9a-f]+)/ && do { $$a += eval "0x$$2" }; END { printf " RAM : %5d bytes\n", $$a }'
@$(OBJDUMP) -h $(TARGET).elf | perl -MPOSIX -ne '/.(eeprom)\s+([0-9a-f]+)/ && do { $$a += eval "0x$$2" }; END { printf " EEPROM: %5d bytes\n", $$a }'
FORCE: ;