-
Notifications
You must be signed in to change notification settings - Fork 21
/
compile.mk
234 lines (198 loc) · 7.5 KB
/
compile.mk
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
BUILDROOT ?= .
BUILD ?= $(BUILDROOT)/Build
ifeq ($(CONFIG),Debug)
CPPFLAGS ?= -g -Wall -Wcpp -Wunused-function -DDEBUG -DUSE_FULL_ASSERT
ASFLAGS = -g
endif
ifeq ($(CONFIG),Release)
CPPFLAGS ?= -O3 -ffast-math -DNDEBUG
endif
# Code Paths
SOURCE = $(BUILDROOT)/Source
LIBSOURCE = $(BUILDROOT)/LibSource
BUILDSOURCE = $(BUILD)/Source
TESTPATCHES = $(BUILDROOT)/TestPatches
DAISYSP = $(BUILDROOT)/Libraries/DaisySP/Source
CMSIS = $(BUILDROOT)/Libraries/CMSIS/Include/
DSPINC = $(BUILDROOT)/Libraries/CMSIS/DSP/Include
DSPLIB = $(BUILDROOT)/Libraries/CMSIS/DSP/Source
# Tool path
# TOOLROOT ?= Tools/gcc-arm-none-eabi-9-2020-q2-update/bin/
# Tools
CC=$(TOOLROOT)arm-none-eabi-gcc
LD=$(TOOLROOT)arm-none-eabi-gcc
AR=$(TOOLROOT)arm-none-eabi-gcc-ar
AS=$(TOOLROOT)arm-none-eabi-as
NM=$(TOOLROOT)arm-none-eabi-nm
CXX=$(TOOLROOT)arm-none-eabi-g++
GDB=$(TOOLROOT)arm-none-eabi-gdb
SIZE=$(TOOLROOT)arm-none-eabi-size
RANLIB=$(TOOLROOT)arm-none-eabi-ranlib
OBJCOPY=$(TOOLROOT)arm-none-eabi-objcopy
OBJDUMP=$(TOOLROOT)arm-none-eabi-objdump
# Compilation Flags
LDLIBS = -lm
LDFLAGS = -Wl,--gc-sections
LDFLAGS += -fpic
LDFLAGS += -fpie
LDFLAGS += -flto
CXXFLAGS = -fno-rtti
CXXFLAGS += -fno-exceptions
ifdef HEAVY
CPPFLAGS += -D__unix__ -DHV_SIMD_NONE
endif
ifdef FAUST
ifneq (,$(findstring soundfile,$(FAUSTOPTS)))
CPPFLAGS += -DSOUNDFILE
endif
endif
ifeq ($(PLATFORM),OWL0)
## Flags for F1
ARCH_FLAGS = -mcpu=cortex-m0 -mfloat-abi=soft -msoft-float
DEF_FLAGS = -DSTM32F1XX -DARM_MATH_CM0 -D__FPU_PRESENT=0 -D__FPU_USED=0U
LDSCRIPT ?= $(BUILDROOT)/Source/owl0.ld
else ifeq ($(PLATFORM),OWL1)
## Flags for F40x
ARCH_FLAGS = -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16
DEF_FLAGS = -DSTM32F4XX -DARM_MATH_CM4 -D__FPU_PRESENT=1 -D__FPU_USED=1U
LDSCRIPT ?= $(BUILDROOT)/Source/owl1.ld
else ifeq ($(PLATFORM),OWL2)
## Flags for F42x/F43x
ARCH_FLAGS = -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16
DEF_FLAGS = -DSTM32F4XX -DARM_MATH_CM4 -D__FPU_PRESENT=1 -D__FPU_USED=1U
LDSCRIPT ?= $(BUILDROOT)/Source/owl2.ld
else ifeq ($(PLATFORM),OWL3)
## Flags for H7
ARCH_FLAGS = -mcpu=cortex-m7 -mfloat-abi=hard -mfpu=fpv5-d16
DEF_FLAGS = -DSTM32H7XX -DARM_MATH_CM7 -D__FPU_PRESENT=1 -D__FPU_USED=1U
LDSCRIPT ?= $(BUILDROOT)/Source/owl3.ld
else
$(error PLATFORM="$(PLATFORM)" not recognized. Known platforms: OWL0, OWL1, OWL2, OWL3. See README)
endif
ARCH_FLAGS += -fsingle-precision-constant -mthumb
DEF_FLAGS += -DDSY_CORE_DSP -DDSY_CUSTOM_DSP
DEF_FLAGS += "-DPATCHNAME=\"$(PATCHNAME)\""
# DEF_FLAGS = -DSTM32F745xx -DARM_MATH_CM7 -D__FPU_PRESENT=1 -D__FPU_USED=1U
INC_FLAGS = -I$(BUILDROOT)/Libraries -I$(DEVICE) -I$(CMSIS) -I$(PERIPH_FILE)/inc -I$(SOURCE)
INC_FLAGS += -I$(DEVICE)/Include -I$(CMSIS)
INC_FLAGS += -I$(USB_DEVICE_FILE)/Core/inc -I$(USB_DEVICE_FILE)/Class/cdc/inc
INC_FLAGS += -I$(USB_OTG_FILE)/inc
CPPFLAGS += $(ARCH_FLAGS) $(INC_FLAGS) $(DEF_FLAGS)
CPPFLAGS += -D__PROGRAM_START=1 # prevent compilation of __cmsis_start function
CFLAGS += -std=gnu11
CXXFLAGS += -std=gnu++17
LDFLAGS += -T$(LDSCRIPT) $(ARCH_FLAGS)
CPPFLAGS += -I$(PATCHSOURCE)
CPPFLAGS += -I$(LIBSOURCE)
CPPFLAGS += -I$(BUILDSOURCE)
CPPFLAGS += -I$(TESTPATCHES)
CPPFLAGS += -I$(DSPINC)
CPPFLAGS += -I$(DAISYSP)
CPPFLAGS += -I$(DAISYSP)/Control
CPPFLAGS += -I$(DAISYSP)/Drums
CPPFLAGS += -I$(DAISYSP)/Dynamics
CPPFLAGS += -I$(DAISYSP)/Effects
CPPFLAGS += -I$(DAISYSP)/Filters
CPPFLAGS += -I$(DAISYSP)/Noise
CPPFLAGS += -I$(DAISYSP)/PhysicalModeling
CPPFLAGS += -I$(DAISYSP)/Synthesis
CPPFLAGS += -I$(DAISYSP)/Utility
CPPFLAGS += -DARM_CORTEX
CPPFLAGS += -DEXTERNAL_SRAM
CPPFLAGS += -nostdlib -nostartfiles -fno-builtin -ffreestanding
CPPFLAGS += -mtune=cortex-m4
# CPPFLAGS += -mtune=cortex-m7
CPPFLAGS += -fpic
CPPFLAGS += -fpie
CPPFLAGS += -fdata-sections
CPPFLAGS += -ffunction-sections
CPPFLAGS += -mno-unaligned-access
CPPFLAGS += -fno-omit-frame-pointer
CPPFLAGS += -flto
# CPPFLAGS += -munaligned-access
# CPPFLAGS += -mlong-calls
# CPPFLAGS += -mpic-data-is-text-relative
# source files
PATCH_S_SRC = $(SOURCE)/startup.s
PATCH_C_SRC = $(wildcard $(PATCHSOURCE)/*.c)
PATCH_CPP_SRC += $(wildcard $(PATCHSOURCE)/*.cpp)
PATCH_CPP_SRC += PatchProgram.cpp
PATCH_C_SRC += $(wildcard $(BUILDSOURCE)/*.c)
PATCH_CPP_SRC += $(wildcard $(BUILDSOURCE)/*.cpp)
ifdef MAXIMILIAN
PATCH_CPP_SRC := $(filter-out $(PATCHSOURCE)/$(MAXIMILIAN).cpp, $(PATCH_CPP_SRC))
endif
PATCH_OBJS += $(addprefix $(BUILD)/, $(notdir $(PATCH_S_SRC:.s=.o)))
PATCH_OBJS += $(addprefix $(BUILD)/, $(notdir $(PATCH_C_SRC:.c=.o)))
PATCH_OBJS += $(addprefix $(BUILD)/, $(notdir $(PATCH_CPP_SRC:.cpp=.o)))
DAISYSP_CPP_SRC = $(wildcard $(DAISYSP)/*/*.cpp)
DAISYSP_OBJS = $(addprefix $(BUILD)/, $(notdir $(DAISYSP_CPP_SRC:.cpp=.o)))
# include common make files
include $(BUILDROOT)/libs.mk
include $(BUILDROOT)/sources.mk
C_SRC += $(SOURCE)/heap_5.c
CPP_SRC += $(SOURCE)/Patch.cpp
CPP_SRC += $(SOURCE)/PatchProcessor.cpp
CPP_SRC += $(SOURCE)/main.cpp
CPP_SRC += $(SOURCE)/operators.cpp
CPP_SRC += $(SOURCE)/message.cpp
CPP_SRC += $(SOURCE)/system_tables.cpp
OBJS = $(addprefix $(BUILD)/,$(notdir $(C_SRC:.c=.o)))
OBJS += $(addprefix $(BUILD)/,$(notdir $(CPP_SRC:.cpp=.o)))
OBJS += $(addprefix $(BUILD)/,$(notdir $(S_SRC:.S=.o)))
# Set up search path
vpath %.S $(sort $(dir $(S_SRC)))
vpath %.s $(sort $(dir $(S_SRC) $(PATCH_S_SRC)))
vpath %.c $(sort $(dir $(C_SRC) $(PATCH_C_SRC)))
vpath %.cpp $(sort $(dir $(CPP_SRC) $(PATCH_CPP_SRC) $(DAISYSP_CPP_SRC)))
.PHONY: libs as map compile size
$(BUILD)/ShortPatchProgram.o: $(SOURCE)/ShortPatchProgram.cpp $(DEPS)
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) -I$(BUILD) $(SOURCE)/ShortPatchProgram.cpp -o $@
$(CXX) -MM -MT"$@" $(CPPFLAGS) $(CXXFLAGS) -I$(BUILD) $(SOURCE)/ShortPatchProgram.cpp > $(@:.o=.d)
$(BUILD)/PatchProgram.o: $(SOURCE)/PatchProgram.cpp $(DEPS)
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) -I$(BUILD) $(SOURCE)/PatchProgram.cpp -o $@
$(CXX) -MM -MT"$@" $(CPPFLAGS) $(CXXFLAGS) -I$(BUILD) $(SOURCE)/PatchProgram.cpp > $(@:.o=.d)
Libraries/libowlprg.a: $(OBJS)
$(AR) rcs $@ $^
Libraries/libdaisysp.a: $(DAISYSP_OBJS)
@$(AR) rcs $@ $^
$(BUILD)/$(TARGET).elf: $(PATCH_OBJS) $(LDSCRIPT)
@$(LD) $(LDFLAGS) -o $@ $(PATCH_OBJS) $(LDLIBS) Libraries/libdaisysp.a Libraries/libowlprg.a
libs: Libraries/libowlprg.a Libraries/libdaisysp.a
as: $(BUILD)/$(TARGET).elf
@$(OBJDUMP) -S $< > $(BUILD)/$(TARGET).s
map: $(PATCH_OBJS) $(LDSCRIPT)
@$(LD) $(LDFLAGS) -Wl,-Map=$(BUILD)/$(TARGET).map $(PATCH_OBJS) $(LDLIBS) Libraries/libdaisysp.a Libraries/libowlprg.a
compile: $(BUILD)/$(TARGET).bin
size:
$(NM) --print-size --size-sort $(BUILD)/$(TARGET).elf | tail -n 20
$(SIZE) $(BUILD)/$(TARGET).elf
ls -s $(BUILD)/$(TARGET).bin
# compile and generate dependency info
$(BUILD)/%.o: %.c
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
$(CC) -MM -MT"$@" $(CPPFLAGS) $(CFLAGS) $< > $(@:.o=.d)
$(BUILD)/%.o: %.cpp
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
$(CXX) -MM -MT"$@" $(CPPFLAGS) $(CXXFLAGS) $< > $(@:.o=.d)
$(BUILD)/%.o: %.cc
$(CXX) -c $(CPPFLAGS) $(CXXFLAGS) $< -o $@
$(CXX) -MM -MT"$@" $(CPPFLAGS) $(CXXFLAGS) $< > $(@:.o=.d)
$(BUILD)/%.o: %.s
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
$(BUILD)/%.o: %.S
$(CC) -c $(CPPFLAGS) $(CFLAGS) $< -o $@
$(BUILD)/%.s: %.c
$(CC) -S $(CPPFLAGS) $(CFLAGS) $< -o $@
$(BUILD)/%.s: %.cpp
@$(CXX) -S $(CPPFLAGS) $(CXXFLAGS) $< -o $@
$(BUILD)/%.s: %.cc
@$(CXX) -S $(CPPFLAGS) $(CXXFLAGS) $< -o $@
$(BUILD)/%.bin: $(BUILD)/%.elf
@$(OBJCOPY) -O binary $< $@
$(BUILD)/%.s: $(BUILD)/%.elf
@$(OBJDUMP) -S $< > $@
$(BUILD)/%.map: $(BUILD)/%.elf
@$(OBJDUMP) -S $< > $@
# pull in dependencies
-include $(OBJS:.o=.d) $(SOLO_OBJS:.o=.d) $(MULTI_OBJS:.o=.d)