-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
87 lines (63 loc) · 2.12 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
# Project sources
SRCS = main.c stm32f4xx_it.c system_stm32f4xx.c syscalls.c utils.c
SRCS += Audio.c adc.c synth.c seq.c accel.c stm32f4_discovery_lis302dl.c
# all the files will be generated with this name (main.elf, main.bin, main.hex, etc)
PROJ_NAME=synth
OUTPATH=build
LOADADDR=0x8000000
###################################################
# Check for valid float argument
# NOTE that you have to run make clan after
# changing these as hardfloat and softfloat are not
# binary compatible
ifneq ($(FLOAT_TYPE), hard)
ifneq ($(FLOAT_TYPE), soft)
override FLOAT_TYPE = hard
#override FLOAT_TYPE = soft
endif
endif
###################################################
BINPREFIX=arm-none-eabi-
CC=$(BINPREFIX)gcc
OBJCOPY=$(BINPREFIX)objcopy
SIZE=$(BINPREFIX)size
STFLASH=st-flash
CFLAGS = -std=gnu99 -g -O2 -Wall -Wextra -Wno-unused-parameter -Tstm32_flash.ld
CFLAGS += -mlittle-endian -mthumb -mthumb-interwork -nostartfiles -mcpu=cortex-m4
ifeq ($(FLOAT_TYPE), hard)
CFLAGS += -fsingle-precision-constant -Wdouble-promotion
CFLAGS += -mfpu=fpv4-sp-d16 -mfloat-abi=hard
#CFLAGS += -mfpu=fpv4-sp-d16 -mfloat-abi=softfp
else
CFLAGS += -msoft-float
endif
###################################################
vpath %.c src
vpath %.a lib
ROOT=$(shell pwd)
CFLAGS += -Iinc -Ilib -Ilib/inc
CFLAGS += -Ilib/inc/core -Ilib/inc/peripherals -DHSE_VALUE=8000000
# add startup file to build
SRCS += lib/startup_stm32f4xx.s
# Libraries to use
LIBS = -Llib -lstm32f4 -lm
OBJS = $(SRCS:.c=.o)
###################################################
.PHONY: lib proj
all: lib proj
$(SIZE) $(OUTPATH)/$(PROJ_NAME).elf
flash: proj
$(STFLASH) write $(OUTPATH)/$(PROJ_NAME).bin $(LOADADDR)
lib:
$(MAKE) -C lib FLOAT_TYPE=$(FLOAT_TYPE) BINPREFIX=$(BINPREFIX)
proj: $(OUTPATH)/$(PROJ_NAME).elf
$(OUTPATH)/$(PROJ_NAME).elf: $(SRCS) | lib
$(CC) $(CFLAGS) $^ -o $@ $(LIBS)
$(OBJCOPY) -O ihex $(OUTPATH)/$(PROJ_NAME).elf $(OUTPATH)/$(PROJ_NAME).hex
$(OBJCOPY) -O binary $(OUTPATH)/$(PROJ_NAME).elf $(OUTPATH)/$(PROJ_NAME).bin
clean:
rm -f *.o
rm -f $(OUTPATH)/$(PROJ_NAME).elf
rm -f $(OUTPATH)/$(PROJ_NAME).hex
rm -f $(OUTPATH)/$(PROJ_NAME).bin
$(MAKE) clean -C lib