wideband/firmware/Makefile

262 lines
6.7 KiB
Makefile
Raw Normal View History

2020-09-19 02:49:20 -07:00
##############################################################################
# Build global options
# NOTE: Can be overridden externally.
#
ifeq ($(BOARD),)
BOARD = f0_module
endif
BOARDDIR = boards/$(BOARD)
2020-09-19 02:49:20 -07:00
# Compiler options here.
ifeq ($(USE_OPT),)
2020-11-27 19:58:38 -08:00
USE_OPT = -O2 -ggdb -fomit-frame-pointer -falign-functions=16 -fsingle-precision-constant
2020-09-19 02:49:20 -07:00
endif
2023-08-09 13:24:21 -07:00
USE_OPT += -DWB_PROD=1
2020-09-19 02:49:20 -07:00
# C specific options here (added to USE_OPT).
ifeq ($(USE_COPT),)
USE_COPT =
endif
# C++ specific options here (added to USE_OPT).
ifeq ($(USE_CPPOPT),)
USE_CPPOPT = -fno-rtti -fno-exceptions -ffast-math -funsafe-math-optimizations -fno-threadsafe-statics -fno-use-cxa-atexit -std=c++17
2020-09-19 02:49:20 -07:00
endif
# Enable this if you want the linker to remove unused code and data.
ifeq ($(USE_LINK_GC),)
2020-12-10 21:46:57 -08:00
USE_LINK_GC = yes
2020-09-19 02:49:20 -07:00
endif
# Linker extra options here.
ifeq ($(USE_LDOPT),)
2021-02-25 22:35:26 -08:00
USE_LDOPT =
2020-09-19 02:49:20 -07:00
endif
# Enable this if you want link time optimizations (LTO).
ifeq ($(USE_LTO),)
USE_LTO = yes
endif
# Enable this if you want to see the full log while compiling.
ifeq ($(USE_VERBOSE_COMPILE),)
USE_VERBOSE_COMPILE = no
endif
# If enabled, this option makes the build process faster by not compiling
# modules not used in the current configuration.
ifeq ($(USE_SMART_BUILD),)
USE_SMART_BUILD = yes
endif
2021-02-25 22:10:53 -08:00
ifeq ($(USE_BOOTLOADER),)
USE_BOOTLOADER = no
endif
2020-09-19 02:49:20 -07:00
#
# Build global options
##############################################################################
##############################################################################
# Architecture or project specific options
#
# Stack size to be allocated to the Cortex-M process stack. This stack is
# the stack used by the main() thread.
ifeq ($(USE_PROCESS_STACKSIZE),)
USE_PROCESS_STACKSIZE = 0x400
2020-09-19 02:49:20 -07:00
endif
# Stack size to the allocated to the Cortex-M main/exceptions stack. This
# stack is used for processing interrupts and exceptions.
ifeq ($(USE_EXCEPTIONS_STACKSIZE),)
USE_EXCEPTIONS_STACKSIZE = 0x400
2020-09-19 02:49:20 -07:00
endif
# Enables the use of FPU (no, softfp, hard).
ifeq ($(USE_FPU),)
USE_FPU = no
endif
# FPU-related options.
ifeq ($(USE_FPU_OPT),)
USE_FPU_OPT = -mfloat-abi=$(USE_FPU) -mfpu=fpv4-sp-d16
endif
#
# Architecture or project specific options
##############################################################################
##############################################################################
# Project, target, sources and paths
#
# Define project name here
2020-09-20 02:35:48 -07:00
PROJECT = wideband
2020-09-19 02:49:20 -07:00
# Imported source files and paths.
CHIBIOS := ChibiOS
CONFDIR := $(BOARDDIR)
2020-09-19 02:49:20 -07:00
BUILDDIR := ./build
DEPDIR := ./.dep
2023-08-09 12:40:01 -07:00
FIRMWARE_DIR = .
2020-09-19 02:49:20 -07:00
2021-04-28 14:41:58 -07:00
ifeq ("$(wildcard $(CHIBIOS)/os/license/license.mk)","")
# submodules probably aren't checked out, complain to the user about it!
# make is not happy about newly checked out module for some reason but next invocation would work
$(error Please run 'git submodule update --init --recursive' before trying to build!)
endif
# Configure libfirmware Paths/Includes
RUSEFI_LIB = libfirmware
include $(RUSEFI_LIB)/util/util.mk
2020-09-19 02:49:20 -07:00
# Licensing files.
include $(CHIBIOS)/os/license/license.mk
# HAL-OSAL files (optional).
include $(CHIBIOS)/os/hal/hal.mk
include $(CHIBIOS)/os/hal/osal/rt-nil/osal.mk
# RTOS files (optional).
include $(CHIBIOS)/os/rt/rt.mk
# Other files (optional).
2020-10-29 02:55:55 -07:00
include $(CHIBIOS)/os/hal/lib/streams/streams.mk
include $(CHIBIOS)/os/various/cpp_wrappers/chcpp.mk
include $(CHIBIOS)/os/hal/lib/complex/mfs/hal_mfs.mk
2020-09-19 02:49:20 -07:00
# include board.mk that sets per-board options
include $(BOARDDIR)/board.mk
2023-08-09 12:34:37 -07:00
include wideband.mk
2020-09-19 02:49:20 -07:00
# Define linker script file here
LDSCRIPT=app.ld
2020-09-19 02:49:20 -07:00
# C sources that can be compiled in ARM or THUMB mode depending on the global
# setting.
CSRC = $(ALLCSRC) $(BOARDDIR)/board.c
2020-09-19 02:49:20 -07:00
# C++ sources that can be compiled in ARM or THUMB mode depending on the global
# setting.
CPPSRC = $(ALLCPPSRC) \
2021-02-25 22:39:51 -08:00
$(BOARDDIR)/port.cpp \
2021-12-27 20:56:55 -08:00
$(BOARDDIR)/port_shared.cpp \
$(RUSEFI_LIB_CPP) \
2023-08-09 12:34:37 -07:00
$(WIDEBANDSRC) \
2020-12-09 00:24:06 -08:00
shared/flash.cpp \
2020-09-19 16:51:13 -07:00
can.cpp \
can_helper.cpp \
2020-12-10 21:03:59 -08:00
fault.cpp \
2020-11-01 01:17:13 -08:00
lambda_conversion.cpp \
2020-09-19 21:39:29 -07:00
pwm.cpp \
dac.cpp \
2020-10-27 16:33:32 -07:00
pump_dac.cpp \
2020-10-31 16:59:35 -07:00
pump_control.cpp \
max3185x.cpp \
2020-12-10 23:48:47 -08:00
uart.cpp \
auxout.cpp \
livedata.cpp \
indication.cpp \
console/binary/tunerstudio.cpp \
console/binary/tunerstudio_io.cpp \
console/binary/tunerstudio_io_serial.cpp \
console/binary/tunerstudio_commands.cpp \
2023-08-09 12:40:01 -07:00
sampling_thread.cpp \
2023-11-13 13:30:23 -08:00
heater_thread.cpp \
2020-09-19 02:49:20 -07:00
main.cpp
# List ASM source files here.
ASMSRC = $(ALLASMSRC)
# List ASM with preprocessor source files here.
2023-01-05 16:56:28 -08:00
ASMXSRC = $(ALLXASMSRC) main_hardfault_asm.S
2020-09-19 02:49:20 -07:00
# Inclusion directories.
INCDIR = $(CONFDIR) \
$(ALLINC) \
$(RUSEFI_LIB_INC) \
util/ \
util/math/ \
console/binary/ \
boards/ \
shared/ \
$(BOARDDIR)/io/
2020-09-19 02:49:20 -07:00
# Define C warning options here.
CWARN = -Wall -Wextra -Wundef -Wstrict-prototypes
# Define C++ warning options here.
CPPWARN = -Wall -Wextra -Wundef -Werror=switch
2020-09-19 02:49:20 -07:00
#
# Project, target, sources and paths
##############################################################################
##############################################################################
# Compiler settings
#
# OpenBLT flasher expects srec files
SREC = $(CP) -O srec
#
# Compiler settings
##############################################################################
2020-09-19 02:49:20 -07:00
##############################################################################
# Start of user section
#
# List all user C define here, like -D_DEBUG=1
2020-12-11 00:24:14 -08:00
#UDEFS = -DCHPRINTF_USE_FLOAT=1
2020-10-29 02:55:55 -07:00
2020-09-19 02:49:20 -07:00
# Define ASM defines here
UADEFS =
# List all user directories here
UINCDIR =
# List the user directory to look for the libraries here
ULIBDIR = $(BOARDDIR)
2020-09-19 02:49:20 -07:00
2021-02-25 22:10:53 -08:00
ifeq ($(USE_BOOTLOADER),yes)
ULIBS = boards/f0_module/bootloader/build/wideband_bootloader.o
USE_OPT += -Wl,--defsym=USE_BOOTLOADER=1
endif
2020-09-19 02:49:20 -07:00
ifeq ($(USE_OPENBLT),yes)
# Reserve start of flash for OpenBLT
USE_OPT += -Wl,--defsym=USE_BOOTLOADER=1
DDEFS += -DUSE_OPENBLT=TRUE
# Shared params
INCDIR += boards/f1_common/openblt
CSRC += boards/f1_common/openblt/shared_params.c
endif
2020-09-19 02:49:20 -07:00
#
# End of user section
##############################################################################
##############################################################################
# Common rules
#
RULESPATH = $(CHIBIOS)/os/common/startup/ARMCMx/compilers/GCC/mk
include $(RULESPATH)/arm-none-eabi.mk
include $(RULESPATH)/rules.mk
#
# Common rules
##############################################################################
##############################################################################
# Custom rules
#
#
# Custom rules
##############################################################################