1
0
mirror of https://github.com/rene-dev/stmbl.git synced 2024-12-24 17:42:10 +00:00
stmbl/stmsp/stm32f303/Makefile

279 lines
7.6 KiB
Makefile
Raw Permalink Normal View History

2018-04-18 23:21:56 +00:00
# Optimization level, can be [0, 1, 2, 3, s].
# 0 = turn off optimization. s = optimize for size.
#
2018-04-20 01:43:43 +00:00
OPT = -O3 -flto
2018-04-18 23:21:56 +00:00
# OPT = -O1 # for debugging
# Object files directory
# Warning: this will be removed by make clean!
#
2018-04-20 01:43:43 +00:00
OBJDIR = obj_hvf3
2018-04-18 23:21:56 +00:00
# Target file name (without extension)
2018-04-20 01:43:43 +00:00
TARGET = $(OBJDIR)/hvf3
2018-04-18 23:21:56 +00:00
# Define all C source files (dependencies are generated automatically)
INCDIRS += stmsp/stm32f303/inc
SOURCES += stmsp/stm32f303/src/main.c
SOURCES += stmsp/stm32f303/src/adc.c
SOURCES += stmsp/stm32f303/src/opamp.c
2018-04-20 01:43:43 +00:00
SOURCES += stmsp/stm32f303/src/setup.c
2018-04-18 23:21:56 +00:00
SOURCES += stmsp/stm32f303/src/stm32f3xx_hal_msp.c
2018-04-20 01:43:43 +00:00
# SOURCES += stmsp/stm32f303/src/tim.c
2018-04-18 23:21:56 +00:00
SOURCES += stmsp/stm32f303/src/stm32f3xx_it.c
SOURCES += stmsp/stm32f303/src/usb_device.c
SOURCES += stmsp/stm32f303/src/usbd_cdc_if.c
SOURCES += stmsp/stm32f303/src/usbd_conf.c
SOURCES += stmsp/stm32f303/src/usbd_desc.c
SOURCES += stmsp/stm32f303/src/version.c
SOURCES += stmsp/stm32f303/src/hal_tbl.c
CFLAGS += -DHAL_MAX_CTX=1024
COMPS += stmsp/stm32f303/src/comps/hv.c
COMPS += stmsp/stm32f303/src/comps/io.c
COMPS += stmsp/stm32f303/src/comps/tle.c
COMPS += shared/comps/sim.c
COMPS += shared/comps/term.c
COMPS += shared/comps/curpid.c
COMPS += shared/comps/svm.c
2018-04-20 02:40:45 +00:00
COMPS += shared/comps/dq_sp.c
2018-04-18 23:21:56 +00:00
COMPS += shared/comps/idq.c
COMPS += shared/comps/pole.c
COMPS += shared/comps/map.c
COMPS += shared/comps/vel.c
# COMPS += shared/comps/trc.c
COMPS += shared/comps/rl.c
COMPS += shared/comps/ypid.c
SOURCES += $(COMPS)
INCDIRS += shared
SOURCES += shared/ringbuf.c
SOURCES += shared/crc8.c
SOURCES += shared/angle.c
SOURCES += shared/hal.c
SOURCES += shared/commands.c
SOURCES += shared/flashconf.c
#USB Driver
USB_DEVICE_DIR = lib/STM32_USB_Device_Library-2.4.2
#USB class
INCDIRS += $(USB_DEVICE_DIR)/Class/CDC/Inc/
SOURCES += $(USB_DEVICE_DIR)/Class/CDC/Src/usbd_cdc.c
#USB core
INCDIRS += $(USB_DEVICE_DIR)/Core/Inc/
SOURCES += $(USB_DEVICE_DIR)/Core/Src/usbd_core.c
SOURCES += $(USB_DEVICE_DIR)/Core/Src/usbd_ctlreq.c
SOURCES += $(USB_DEVICE_DIR)/Core/Src/usbd_ioreq.c
#CMSIS
CPPFLAGS += -DSTM32F303xC
INCDIRS += lib/CMSIS/Include/
INCDIRS += lib/CMSIS/Device/ST/STM32F3xx/Include/
SOURCES += lib/CMSIS/Device/ST/STM32F3xx/Source/Templates/gcc/startup_stm32f303xc.s
SOURCES += lib/CMSIS/Device/ST/STM32F3xx/Source/Templates/system_stm32f3xx.c
#stm32f3 HAL Driver
HAL_DRV_DIR = lib/STM32F3xx_HAL_Driver/
INCDIRS += $(HAL_DRV_DIR)/Inc
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_adc.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_adc_ex.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_cortex.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_crc.c
# SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_dac.c
# SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_dac_ex.c
2018-04-20 01:43:43 +00:00
# SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_dma.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_flash.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_flash_ex.c
2018-04-18 23:21:56 +00:00
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_gpio.c
2018-04-20 01:43:43 +00:00
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_spi.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_spi_ex.c
2018-04-18 23:21:56 +00:00
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_opamp.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_opamp_ex.c
2018-04-20 01:43:43 +00:00
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_pcd.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_pcd_ex.c
# SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_pwr.c
# SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_pwr_ex.c
2018-04-18 23:21:56 +00:00
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_rcc.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_rcc_ex.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_tim.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_tim_ex.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_uart.c
SOURCES += $(HAL_DRV_DIR)/Src/stm32f3xx_hal_uart_ex.c
LDSCRIPT = stmsp/stm32f303/STM32F303CBTx_FLASH.ld
#============================================================================
OBJECTS += $(addprefix $(OBJDIR)/,$(addsuffix .o,$(basename $(SOURCES))))
CPPFLAGS += $(addprefix -I,$(INCDIRS))
#---------------- Preprocessor Options ----------------
# -fsingle... make better use of the single-precision FPU
# -g generate debugging information
# -save-temps preserve .s and .i-files
#
#CPPFLAGS +=
# CPPFLAGS += -g
# CPPFLAGS += -save-temps=obj
#---------------- C Compiler Options ----------------
# -O* optimization level
# -f... tuning, see GCC documentation
# -Wall... warning level
#
CFLAGS += $(OPT)
CFLAGS += -std=gnu11
CFLAGS += -ffunction-sections
CFLAGS += -fdata-sections
CFLAGS += -Wall
CFLAGS += -fno-builtin ## from old
CFLAGS += -nostartfiles
CFLAGS += -Wfatal-errors
CFLAGS += -Wno-pointer-sign #for usb lib...
#CFLAGS += -Wdouble-promotion
CFLAGS += -Wfloat-conversion
CFLAGS += -fsingle-precision-constant
# CFLAGS += -ffast-math
CFLAGS += -ffinite-math-only
CFLAGS += -fno-trapping-math
CFLAGS += -fno-signaling-nans
CFLAGS += -fno-rounding-math
CFLAGS += -fno-signed-zeros
CFLAGS += -fno-math-errno
#CFLAGS += -Wstrict-prototypes
#CFLAGS += -Wextra
#CFLAGS += -Wpointer-arith
#CFLAGS += -Winline
#CFLAGS += -Wunreachable-code
#CFLAGS += -Wundef
# Use a friendly C dialect
CPPFLAGS += -fno-strict-aliasing
CPPFLAGS += -fwrapv
#---------------- C++ Compiler Options ----------------
#
CXXFLAGS += $(OPT)
CXXFLAGS += -ffunction-sections
CXXFLAGS += -fdata-sections
CXXFLAGS += -Wall
#---------------- Assembler Options ----------------
# -Wa,... tell GCC to pass this to the assembler
#
#---------------- Linker Options ----------------
# -Wl,... tell GCC to pass this to linker
# -Map create map file
# --cref add cross reference to map file
#
LDFLAGS += $(OPT)
LDFLAGS += -lm
LDFLAGS += -Wl,-Map=$(TARGET).map,--cref
LDFLAGS += -Wl,--gc-sections
# LDFLAGS += -specs=nano.specs -u _printf_float -u _scanf_float
LDFLAGS += -lc -specs=nosys.specs #fixes sbrk missing? present in eclipse?
LDFLAGS += -T$(LDSCRIPT)
#============================================================================
2018-04-20 01:43:43 +00:00
POSTLD = tools/add_version_info.py # -q
2018-04-18 23:21:56 +00:00
# Compiler flags to generate dependency files
#
GENDEPFLAGS = -MMD -MP
# Combine all necessary flags and optional flags
# Add target processor to flags.
#
CPU = -mthumb -mcpu=cortex-m4 -mfloat-abi=hard -mfpu=fpv4-sp-d16
CFLAGS += $(CPU)
CXXFLAGS += $(CPU)
ASFLAGS += $(CPU)
LDFLAGS += $(CPU)
ADDRESS = 0x8004000
# Default target
#
all: gccversion build showsize
build: tbl elf hex bin lss sym
elf: $(TARGET).elf
hex: $(TARGET).hex
2018-04-20 01:43:43 +00:00
bin: $(TARGET).bin
2018-04-18 23:21:56 +00:00
lss: $(TARGET).lss
sym: $(TARGET).sym
# Display compiler version information
#
stmsp/stm32f303/inc/commandslist.h: tbl
stmsp/stm32f303/inc/hal_tbl.h: tbl
stmsp/stm32f303/src/hal_tbl.c: tbl
tbl:
@echo Generating tables
2018-04-20 01:43:43 +00:00
@tools/create_hal_tbl.py stmsp/stm32f303/ $(COMPS)
2018-04-18 23:21:56 +00:00
#shared/comps/*.c src/comps/hw/*.c src/comps/*.c
2018-04-20 01:43:43 +00:00
@tools/create_cmd.py $(SOURCES) > stmsp/stm32f303/inc/commandslist.h
# gccversion:
# @$(CC) --version
# # Show the final program size
# #
# showsize: build
# @echo
# @$(SIZE) $(TARGET).elf 2>/dev/null
# # Flash the device
# #
# btburn: build showsize $(TARGET).dfu
# @tools/bootloader.py
# @sleep 1
# @dfu-util -d 0483:df11 -a 0 -s 0x8004000:leave -D $(TARGET).dfu
# flash: $(TARGET).bin
# st-flash --reset write $(TARGET).bin 0x8004000
# Create a DFU file from bin file
%.dfu: %.bin
@cp $< $@
@dfu-suffix -v 0483 -p df11 -a $@
2018-04-18 23:21:56 +00:00
# Target: clean project
#
clean:
@echo Cleaning project:
rm -rf $(OBJDIR)
rm -rf stmsp/stm32f303/inc/commandslist.h
rm -rf stmsp/stm32f303/inc/hal_tbl.h
rm -rf stmsp/stm32f303/src/hal_tbl.c
# Include the base rules
#
include base.mak
2018-04-20 01:43:43 +00:00
include toolchain.mak
2018-04-18 23:21:56 +00:00
# Include the dependency files
#
-include $(OBJECTS:.o=.d)
# Listing of phony targets
#
.PHONY: all build flash clean \
boot boot_clean boot_flash btburn boot_btflash boot_flash\
elf lss sym \
showsize gccversion tbl