-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
67 lines (52 loc) · 1.71 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
# Tool names
PREFIX=arm-none-eabi-
CC := $(PREFIX)gcc
OBJCOPY := $(PREFIX)objcopy
SIZE := $(PREFIX)size
REVISION := $(shell git log -1 --format="%h" || echo "(NONE)")
ARCH_FLAGS = -mthumb -mcpu=cortex-m3
LTO_FLAGS = -O2 -flto -fuse-linker-plugin -ffunction-sections -fdata-sections -fverbose-asm -ffat-lto-objects
WARN_FLAGS = -Werror -Wfatal-errors -Wall -Wextra -Wunsafe-loop-optimizations -Wdouble-promotion -Wundef -Wno-pedantic -Wno-enum-conversion
DEBUG_FLAGS = -ggdb3 -DNDEBUG -D__REVISION__='"$(REVISION)"'
CFLAGS = -std=gnu99 $(ARCH_FLAGS) $(LTO_FLAGS) $(WARN_FLAGS) $(DEBUG_FLAGS)
LDFLAGS = -nostartfiles -lnosys -static $(ARCH_FLAGS) $(LTO_FLAGS) $(WARN_FLAGS) $(DEBUG_FLAGS) -Wl,-gc-sections,-Map,main.map -Wl,--cref
.DEFAULT_GOAL := main.hex
LD_SCRIPT = stm32_flash_f103_128k.ld
OBJS = \
vectors.o \
boot.o \
clock.o \
gpio2.o \
usart.o \
printf.o \
usb.o \
main.o \
$(OBJS): Makefile
# Compile
%.o: %.c
$(CC) -c -o $@ $(CFLAGS) $<
%.elf: $(LD_SCRIPT)
%.elf: $(OBJS)
$(CC) -o $@ $^ $(LDFLAGS) -T$(LD_SCRIPT)
%.hex: %.elf
$(SIZE) $<
$(OBJCOPY) -O ihex --set-start 0x08000000 $< $@
flash: main.hex
st-flash --reset --format ihex write main.hex
debug: main.elf
st-util &
$(PREFIX)gdb $^
killall st-util
clean:
rm -f *~ *.o *.hex *.bin *.elf *.map
depend:
makedepend -Y. -w150 *.c
# DO NOT DELETE
boot.o: stm32f103_md.h core_cm3.h
clock.o: stm32f103_md.h core_cm3.h clock.h
gpio2.o: gpio2.h stm32f103_md.h core_cm3.h
main.o: stm32f103_md.h core_cm3.h clock.h gpio2.h printf.h usart.h usb.h
printf.o: printf.h stb_sprintf.h
usart.o: usart.h stm32f103_md.h core_cm3.h printf.h
usb.o: usb.h stm32f103usb.h gpio2.h stm32f103_md.h core_cm3.h
vectors.o: stm32f103_md.h core_cm3.h