~ruther/vhdl-spi-2

vhdl-spi-2/stm_spi_funduino/Makefile -rw-r--r-- 1.4 KiB
330f5837 — Rutherther docs: add readme 2 months ago
                                                                                
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
DEVICE?=STM32F401xE
TARGET?=stm32f4x
CPU?=cortex-m7

APP=spi-num-receiver.elf

BINDIR=bin
SRCDIR=src
INCDIR=include
OBJDIR=obj
DEPDIR=$(OBJDIR)/.deps

DEVICEDIR=devices/$(DEVICE)
GENERALDIR=devices/general

PROJSRCS=$(wildcard $(SRCDIR)/*.c)
GENERALSRCS=$(wildcard $(GENERALDIR)/*.c)
DEVICESRCS=$(wildcard $(DEVICEDIR)/*.c)

SRCS=$(PROJSRCS) $(GENERALSRCS) $(DEVICESRCS)
OBJS=$(patsubst %.c,$(OBJDIR)/%.o,$(SRCS))
DEPFILES=$(patsubst %.c,$(DEPDIR)/%.d,$(SRCS))

DEPFLAGS = -MT $@ -MMD -MP -MF $(DEPDIR)/$*.d
CFLAGS=-I$(INCDIR) \
				-I$(DEVICEDIR)/$(INCDIR) \
				-Ilibs/CMSIS_6/CMSIS/Core/Include \
				-Ilibs/cmsis_device_f4/Include \
				-mthumb -mcpu=$(CPU) --specs=nano.specs -g \
				-D$(DEVICE)
LDFLAGS=-T$(DEVICEDIR)/linker_script.ld

CC=arm-none-eabi-gcc
LD=arm-none-eabi-ld
OPENOCD=openocd

$(BINDIR)/$(APP): $(OBJS) | $(BINDIR)
	$(CC) $^ -o $@ $(CFLAGS) $(LDFLAGS) $(DEPFLAGS)

%.o : %.c
$(OBJDIR)/%.o: %.c | $(DEPDIR) $(OBJDIR)
	mkdir -p "$(dir $@)"
	mkdir -p $(dir $(DEPDIR)/$*.d)
	$(CC) -c $< -o $@ $(CFLAGS) $(DEPFLAGS)

.PHONY: openocd flash clean
openocd:
	$(OPENOCD) -f interface/stlink.cfg -f target/$(TARGET).cfg

flash: $(BINDIR)/$(APP)
	$(OPENOCD) -f interface/stlink.cfg -f target/$(TARGET).cfg -c "program $(BINDIR)/$(APP) verify reset exit"

clean:
	rm -rf $(OBJDIR) $(BINDIR) $(DEPDIR)

$(BINDIR): ; mkdir -p $@
$(OBJDIR): ; mkdir -p $@
$(DEPDIR): ; mkdir -p $@

$(DEPFILES):
include $(wildcard $(DEPFILES))
Do not follow this link