-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
55 lines (42 loc) · 1.03 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
# Generic Makefile
OUT ?= build
BIN ?= main
# c source file
INPUT_C_SRC ?= src/main.c
C_SRC = src/syscalls.c \
src/usart.c \
src/startup.c \
$(INPUT_C_SRC)
INPUT_C_INC ?=
C_INC = -Iinc \
$(INPUT_C_INC)
# linker script
LDSCRIPT = src/link.ld
VPATH = $(dir $(C_SRC))
# object file
OBJS = $(patsubst %.c, $(OUT)/%.o, $(notdir $(C_SRC)))
# toolchain
TOOLCHAIN = arm-none-eabi-
CC = $(TOOLCHAIN)gcc
SZ = $(TOOLCHAIN)size
# toolchain options
MCU = -mcpu=cortex-m4
CFLAGS = $(MCU) -mthumb $(C_INC) -O0 -Wall -g
LDFLAGS = $(MCU) -specs=nano.specs -T$(LDSCRIPT) -lc -lm -lnosys
all: $(OUT)/$(BIN)
# compile
$(OUT)/%.o: %.c
$(CC) -c $(CFLAGS) $< -o $@
# link
$(OUT)/$(BIN): $(OUT) $(OBJS)
$(CC) $(OBJS) $(LDFLAGS) -o $@
$(SZ) $@
$(OUT):
mkdir $@
.PHONY: disassembly load upload clean
disassembly: $(OUT)/$(BIN)
$(TOOLCHAIN)objdump -d $^ > $(OUT)/$(BIN).S
upload:
openocd -f interface/stlink-v2-1.cfg -f target/stm32f3x.cfg -c " program $(OUT)/$(BIN) verify exit "
clean:
-@rm -r $(OUT)