-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMakefile
executable file
·120 lines (93 loc) · 2.72 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
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
#######################################
# Options
#######################################
PROJECT_NAME := main
OUTPUT_DIR := build
CC := arm-none-eabi-gcc
CXX := arm-none-eabi-g++
LD := arm-none-eabi-g++
AS := arm-none-eabi-gcc
OBJCOPY := arm-none-eabi-objcopy
SIZE := arm-none-eabi-size
INCLUDE := \
-Iinc \
-Ilib/CMSIS/Device/Include \
-Ilib/CMSIS/Include \
-Ilib/FreeRTOS/include \
-Ilib/FreeRTOS/portable \
-Ilib/STM32F4xx_StdPeriph_Driver/inc
DEFINE_MACRO := \
-DSTM32F40_41xxx \
-DSTM32F407xx \
-DARM_MATH_CM4 \
-D__FPU_PRESENT \
-DHSE_VALUE=8000000 \
-DUSE_STDPERIPH_DRIVER \
-DDEBUG
TARGET_ARCH := \
-mcpu=cortex-m4 \
-mthumb \
-mfloat-abi=hard \
-mfpu=fpv4-sp-d16
CFLAGS := $(TARGET_ARCH) $(DEFINE_MACRO) \
-O0 -g3 -Wall \
-fmessage-length=0 \
-fsigned-char \
-ffunction-sections \
-fdata-sections \
-mslow-flash-data
CXXFLAGS := $(CFLAGS) \
-fno-use-cxa-atexit \
-fno-exceptions \
-fno-rtti \
-fno-threadsafe-statics \
-std=c++11 \
-include stdint.h
ASFLAGS := -x assembler-with-cpp -c $(CFLAGS)
LDFLAGS := $(TARGET_ARCH) -T LinkerScript.ld -Wl,--gc-sections
LDLIBS := -lm
#######################################
# Dependencies
#######################################
C_SRCS := $(wildcard src/*.c) \
$(wildcard lib/CMSIS/DSP_Lib/Source/*/*.c) \
$(wildcard lib/FreeRTOS/*.c) \
$(wildcard lib/FreeRTOS/portable/*.c) \
lib/FreeRTOS/portable/MemMang/heap_3.c \
$(wildcard lib/STM32F4xx_StdPeriph_Driver/src/*.c)
C_SRCS := $(filter-out %/stm32f4xx_fmc.c, $(C_SRCS))
#CPP_SRCS := $(wildcard src/*.cpp)
ASM_SRCS := $(wildcard src/*.s) \
lib/CMSIS/Device/Source/startup_stm32f407xx.s
OBJS := $(patsubst %,$(OUTPUT_DIR)/%, $(C_SRCS:.c=.o) $(CPP_SRCS:.cpp=.o) $(ASM_SRCS:.s=.o))
DEPS := $(OBJS:.o=.d)
#######################################
# Targets
#######################################
.PHONY: all clean
all: $(OUTPUT_DIR) $(OUTPUT_DIR)/$(PROJECT_NAME).elf
$(OUTPUT_DIR):
@mkdir $(OUTPUT_DIR)
$(OUTPUT_DIR)/$(PROJECT_NAME).elf: $(OBJS)
@echo "LD $@"
@$(LD) $(LDFLAGS) $(LDLIBS) -Wl,-Map,$(@:.elf=.map) -o $@ $^
@$(OBJCOPY) -O ihex $@ $(@:.elf=.hex)
@$(OBJCOPY) -O binary $@ $(@:.elf=.bin)
@$(SIZE) $@
$(OUTPUT_DIR)/%.o: %.c
@echo "CC $<"
@if [ ! -d $(dir $@) ]; then mkdir -p $(dir $@); fi
@$(CC) $(CFLAGS) $(INCLUDE) -MMD -MP -MF$(@:.o=.d) -MT$@ -o $@ -c $<
#$(OUTPUT_DIR)/%.o: %.cpp
# @echo "CXX $<"
# @if [ ! -d $(dir $@) ]; then mkdir -p $(dir $@); fi
# @$(CXX) $(CXXFLAGS) $(INCLUDE) -MMD -MP -MF$(@:.o=.d) -MT$@ -o $@ -c $<
$(OUTPUT_DIR)/%.o: %.s
@echo "AS $<"
@if [ ! -d $(dir $@) ]; then mkdir -p $(dir $@); fi
@$(AS) $(ASFLAGS) -MMD -MP -MF$(@:.o=.d) -MT$@ -o $@ -c $<
.clang_complete: Makefile
@echo $(INCLUDE) $(DEFINE_MACRO) | tr " " "\n" > $@
clean:
@rm -rf $(OUTPUT_DIR)/*
-include $(DEPS)