-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
109 lines (91 loc) · 2.94 KB
/
Makefile
File metadata and controls
109 lines (91 loc) · 2.94 KB
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
# Project name
PROJECT := main
# Architecture
MCU := cortex-m4
FPU := -mfpu=fpv4-sp-d16
FLOAT_ABI := -mfloat-abi=hard
# Toolchains
TOOLCHAINS_PATH := /home/bdang/toolchains/gcc-arm-none-eabi-14.3
PREFIX_TOOLCHAINS := arm-none-eabi
GCC := $(PREFIX_TOOLCHAINS)-gcc
CP := $(PREFIX_TOOLCHAINS)-objcopy
ASM := $(PREFIX_TOOLCHAINS)-as
# ============================== Directories ==============================
SRC_DIR := src
INC_CUS_DIR := inc
INC_STL_DIR := StandardPeripheralLib/inc
SRC_INC_DIR := StandardPeripheralLib/src
BUILD_DIR := build
BUILD_INC_DIR := $(BUILD_DIR)/inc
LINKER_DIR := linker
# Linker script and startup
LD_SCRIPT := stm32f4_flash.ld
STARTUP_FILE := startup_stm32f40xx.s
# Source & objects
SRC_FILES := $(wildcard $(SRC_DIR)/*.c)
SRC_INC_FILES := $(wildcard $(SRC_INC_DIR)/*.c)
OBJECTS := $(SRC_INC_FILES:$(SRC_INC_DIR)/%.c=$(BUILD_INC_DIR)/%.o)
OBJECTS_MAIN := $(SRC_FILES:$(SRC_DIR)/%.c=$(BUILD_DIR)/%.o)
# Compiler flags
CFLAGS := -mcpu=$(MCU) -mthumb $(FPU) $(FLOAT_ABI) -Wall -O0 -g \
-I$(INC_CUS_DIR) -I$(SRC_INC_DIR) -I$(INC_STL_DIR)\
-DSTM32F40XX \
-DUSE_STDPERIPH_DRIVER \
-ffunction-sections -fdata-sections
LDFLAGS := -T$(LINKER_DIR)/$(LD_SCRIPT) \
--specs=nosys.specs \
--specs=nano.specs \
-Wl,--gc-sections \
-Wl,-Map=$(BUILD_DIR)/$(PROJECT).map \
-Wl,--no-warn-rwx-segments
# Rules
.PHONY: all clean flash bin hex
all: $(BUILD_DIR)/$(PROJECT).bin
@echo "Build complete! Flash file ready: $(BUILD_DIR)/$(PROJECT).bin"
bin: $(BUILD_DIR)/$(PROJECT).bin
hex: $(BUILD_DIR)/$(PROJECT).hex
# Build ELF
$(BUILD_DIR)/$(PROJECT).elf: $(OBJECTS) $(OBJECTS_MAIN) $(SRC_DIR)/$(STARTUP_FILE)
@mkdir -p $(BUILD_DIR)
@echo "Linking..."
$(TOOLCHAINS_PATH)/bin/$(GCC) $(CFLAGS) $(OBJECTS) $(OBJECTS_MAIN) $(SRC_DIR)/$(STARTUP_FILE) $(LDFLAGS) -o $@
@echo "Created: $@"
@$(TOOLCHAINS_PATH)/bin/$(PREFIX_TOOLCHAINS)-size $@
# Compile .c to .o
$(BUILD_DIR)/%.o: $(SRC_DIR)/%.c
@mkdir -p $(BUILD_DIR)
@echo "Compiling: $<"
$(TOOLCHAINS_PATH)/bin/$(GCC) $(CFLAGS) -c $< -o $@
$(BUILD_INC_DIR)/%.o: $(SRC_INC_DIR)/%.c
@mkdir -p $(BUILD_INC_DIR)
@echo "Compiling (lib): $<"
$(TOOLCHAINS_PATH)/bin/$(GCC) $(CFLAGS) -c $< -o $@
# Convert ELF to BIN
$(BUILD_DIR)/$(PROJECT).bin: $(BUILD_DIR)/$(PROJECT).elf
@echo "Creating BIN file..."
$(TOOLCHAINS_PATH)/bin/$(CP) -O binary $< $@
@echo "Created: $@"
@ls -lh $@
# Convert ELF to HEX
$(BUILD_DIR)/$(PROJECT).hex: $(BUILD_DIR)/$(PROJECT).elf
@echo "Creating HEX file..."
$(TOOLCHAINS_PATH)/bin/$(CP) -O ihex $< $@
@echo "Created: $@"
# Clean
clean:
@echo "Cleaning build files..."
@rm -rf $(BUILD_DIR)
@echo "Clean complete!"
# Flash
flash: $(BUILD_DIR)/$(PROJECT).bin
@echo "Flashing to STM32..."
st-flash write $< 0x8000000
@echo "Flash complete!"
# Debug
debug:
gdb-multiarch build/main.elf \
-ex "target extended-remote localhost:3333" \
-ex "monitor reset halt" \
-ex "load" \
-ex "break main" \
-ex "continue"