mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2024-12-14 04:04:34 +00:00
7ec476cb79
Now that there is M0- and M4-related code.
322 lines
9.1 KiB
Makefile
Executable File
322 lines
9.1 KiB
Makefile
Executable File
#
|
|
# Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc.
|
|
#
|
|
# This file is part of PortaPack.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2, or (at your option)
|
|
# any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; see the file COPYING. If not, write to
|
|
# the Free Software Foundation, Inc., 51 Franklin Street,
|
|
# Boston, MA 02110-1301, USA.
|
|
#
|
|
|
|
##############################################################################
|
|
# Build global options
|
|
# NOTE: Can be overridden externally.
|
|
#
|
|
|
|
# Compiler options here.
|
|
ifeq ($(USE_OPT),)
|
|
USE_OPT = -mthumb \
|
|
-Os -ggdb3 \
|
|
-ffunction-sections \
|
|
-fdata-sections \
|
|
-fno-builtin \
|
|
-nostartfiles \
|
|
--specs=nano.specs
|
|
#-fomit-frame-pointer
|
|
endif
|
|
|
|
# C specific options here (added to USE_OPT).
|
|
ifeq ($(USE_COPT),)
|
|
USE_COPT = -std=gnu99
|
|
endif
|
|
|
|
# C++ specific options here (added to USE_OPT).
|
|
ifeq ($(USE_CPPOPT),)
|
|
USE_CPPOPT = -std=c++11 -fno-rtti -fno-exceptions
|
|
endif
|
|
|
|
# Enable this if you want the linker to remove unused code and data
|
|
ifeq ($(USE_LINK_GC),)
|
|
USE_LINK_GC = yes
|
|
endif
|
|
|
|
# Linker extra options here.
|
|
ifeq ($(USE_LDOPT),)
|
|
USE_LDOPT =
|
|
endif
|
|
|
|
# Enable this if you want link time optimizations (LTO)
|
|
ifeq ($(USE_LTO),)
|
|
USE_LTO = no
|
|
endif
|
|
|
|
# If enabled, this option allows to compile the application in THUMB mode.
|
|
ifeq ($(USE_THUMB),)
|
|
USE_THUMB = yes
|
|
endif
|
|
|
|
# Enable this if you want to see the full log while compiling.
|
|
ifeq ($(USE_VERBOSE_COMPILE),)
|
|
USE_VERBOSE_COMPILE = no
|
|
endif
|
|
|
|
#
|
|
# Build global options
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Architecture or project specific options
|
|
#
|
|
|
|
#
|
|
# Architecture or project specific options
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Project, sources and paths
|
|
#
|
|
|
|
# Define project name here
|
|
PROJECT = application
|
|
|
|
# Imported source files and paths
|
|
CHIBIOS = ../chibios
|
|
CHIBIOS_PORTAPACK = ../chibios-portapack
|
|
include $(CHIBIOS_PORTAPACK)/boards/GSG_HACKRF_ONE/board.mk
|
|
include $(CHIBIOS_PORTAPACK)/os/hal/platforms/LPC43xx_M0/platform.mk
|
|
include $(CHIBIOS)/os/hal/hal.mk
|
|
include $(CHIBIOS_PORTAPACK)/os/ports/GCC/ARMCMx/LPC43xx_M0/port.mk
|
|
include $(CHIBIOS)/os/kernel/kernel.mk
|
|
include $(CHIBIOS_PORTAPACK)/os/various/fatfs_bindings/fatfs.mk
|
|
include $(CHIBIOS)/test/test.mk
|
|
|
|
# Define linker script file here
|
|
LDSCRIPT= $(PORTLD)/LPC43xx_M0.ld
|
|
|
|
# C sources that can be compiled in ARM or THUMB mode depending on the global
|
|
# setting.
|
|
CSRC = $(PORTSRC) \
|
|
$(KERNSRC) \
|
|
$(TESTSRC) \
|
|
$(HALSRC) \
|
|
$(PLATFORMSRC) \
|
|
$(BOARDSRC) \
|
|
$(FATFSSRC)
|
|
|
|
|
|
# C++ sources that can be compiled in ARM or THUMB mode depending on the global
|
|
# setting.
|
|
CPPSRC = main.cpp \
|
|
irq_lcd_frame.cpp \
|
|
irq_controls.cpp \
|
|
irq_rtc.cpp \
|
|
event.cpp \
|
|
event_m0.cpp \
|
|
message_queue.cpp \
|
|
hackrf_hal.cpp \
|
|
portapack.cpp \
|
|
portapack_shared_memory.cpp \
|
|
baseband_api.cpp \
|
|
portapack_persistent_memory.cpp \
|
|
portapack_io.cpp \
|
|
i2c_pp.cpp \
|
|
spi_pp.cpp \
|
|
clock_manager.cpp \
|
|
si5351.cpp \
|
|
wm8731.cpp \
|
|
radio.cpp \
|
|
baseband_cpld.cpp \
|
|
tuning.cpp \
|
|
rf_path.cpp \
|
|
rffc507x.cpp \
|
|
rffc507x_spi.cpp \
|
|
max2837.cpp \
|
|
max5864.cpp \
|
|
debounce.cpp \
|
|
touch.cpp \
|
|
touch_adc.cpp \
|
|
encoder.cpp \
|
|
audio.cpp \
|
|
lcd_ili9341.cpp \
|
|
ui.cpp \
|
|
ui_text.cpp \
|
|
ui_widget.cpp \
|
|
ui_painter.cpp \
|
|
ui_focus.cpp \
|
|
ui_navigation.cpp \
|
|
ui_menu.cpp \
|
|
ui_rssi.cpp \
|
|
ui_channel.cpp \
|
|
ui_audio.cpp \
|
|
ui_font_fixed_8x16.cpp \
|
|
ui_setup.cpp \
|
|
ui_debug.cpp \
|
|
ui_baseband_stats_view.cpp \
|
|
ui_sd_card_status_view.cpp \
|
|
ui_console.cpp \
|
|
ui_receiver.cpp \
|
|
ui_spectrum.cpp \
|
|
recent_entries.cpp \
|
|
receiver_model.cpp \
|
|
spectrum_color_lut.cpp \
|
|
analog_audio_app.cpp \
|
|
ais_baseband.cpp \
|
|
../commom/ais_packet.cpp \
|
|
ais_app.cpp \
|
|
tpms_app.cpp \
|
|
ert_app.cpp \
|
|
../common/ert_packet.cpp \
|
|
sd_card.cpp \
|
|
file.cpp \
|
|
log_file.cpp \
|
|
manchester.cpp \
|
|
string_format.cpp \
|
|
temperature_logger.cpp \
|
|
../common/utility.cpp \
|
|
../common/chibios_cpp.cpp \
|
|
../common/debug.cpp \
|
|
../common/gcc.cpp \
|
|
core_control.cpp \
|
|
cpld_max5.cpp \
|
|
jtag.cpp \
|
|
cpld_update.cpp \
|
|
portapack_cpld_data.cpp
|
|
|
|
|
|
# C sources to be compiled in ARM mode regardless of the global setting.
|
|
# NOTE: Mixing ARM and THUMB mode enables the -mthumb-interwork compiler
|
|
# option that results in lower performance and larger code size.
|
|
ACSRC =
|
|
|
|
# C++ sources to be compiled in ARM mode regardless of the global setting.
|
|
# NOTE: Mixing ARM and THUMB mode enables the -mthumb-interwork compiler
|
|
# option that results in lower performance and larger code size.
|
|
ACPPSRC =
|
|
|
|
# C sources to be compiled in THUMB mode regardless of the global setting.
|
|
# NOTE: Mixing ARM and THUMB mode enables the -mthumb-interwork compiler
|
|
# option that results in lower performance and larger code size.
|
|
TCSRC =
|
|
|
|
# C sources to be compiled in THUMB mode regardless of the global setting.
|
|
# NOTE: Mixing ARM and THUMB mode enables the -mthumb-interwork compiler
|
|
# option that results in lower performance and larger code size.
|
|
TCPPSRC =
|
|
|
|
# List ASM source files here
|
|
ASMSRC = $(PORTASM)
|
|
|
|
INCDIR = ../common $(PORTINC) $(KERNINC) $(TESTINC) \
|
|
$(HALINC) $(PLATFORMINC) $(BOARDINC) \
|
|
$(FATFSINC) \
|
|
$(CHIBIOS)/os/various
|
|
|
|
#
|
|
# Project, sources and paths
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Compiler settings
|
|
#
|
|
|
|
# TODO: Entertain using MCU=cortex-m0.small-multiply for LPC43xx M0 core.
|
|
# However, on GCC-ARM-Embedded 4.9 2015q2, it seems to produce non-functional
|
|
# binaries.
|
|
MCU = cortex-m0
|
|
|
|
#TRGT = arm-elf-
|
|
TRGT = arm-none-eabi-
|
|
CC = $(TRGT)gcc
|
|
CPPC = $(TRGT)g++
|
|
# Enable loading with g++ only if you need C++ runtime support.
|
|
# NOTE: You can use C++ even without C++ support if you are careful. C++
|
|
# runtime support makes code size explode.
|
|
#LD = $(TRGT)gcc
|
|
LD = $(TRGT)g++
|
|
CP = $(TRGT)objcopy
|
|
AS = $(TRGT)gcc -x assembler-with-cpp
|
|
OD = $(TRGT)objdump
|
|
SZ = $(TRGT)size
|
|
HEX = $(CP) -O ihex
|
|
BIN = $(CP) -O binary
|
|
|
|
# ARM-specific options here
|
|
AOPT =
|
|
|
|
# THUMB-specific options here
|
|
TOPT = -mthumb -DTHUMB
|
|
|
|
# Define C warning options here
|
|
CWARN = -Wall -Wextra -Wstrict-prototypes
|
|
|
|
# Define C++ warning options here
|
|
CPPWARN = -Wall -Wextra
|
|
|
|
#
|
|
# Compiler settings
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Start of default section
|
|
#
|
|
|
|
# List all default C defines here, like -D_DEBUG=1
|
|
# TODO: Switch -DCRT0_INIT_DATA depending on load from RAM or SPIFI?
|
|
# NOTE: _RANDOM_TCC to kill a GCC 4.9.3 error with std::max argument types
|
|
DDEFS = -DLPC43XX -DLPC43XX_M0 -D__NEWLIB__ -DHACKRF_ONE \
|
|
-DTOOLCHAIN_GCC -DTOOLCHAIN_GCC_ARM -D_RANDOM_TCC=0 \
|
|
-DGIT_REVISION=\"$(GIT_REVISION)\"
|
|
|
|
# List all default ASM defines here, like -D_DEBUG=1
|
|
DADEFS =
|
|
|
|
# List all default directories to look for include files here
|
|
DINCDIR =
|
|
|
|
# List the default directory to look for the libraries here
|
|
DLIBDIR =
|
|
|
|
# List all default libraries here
|
|
DLIBS =
|
|
|
|
#
|
|
# End of default section
|
|
##############################################################################
|
|
|
|
##############################################################################
|
|
# Start of user section
|
|
#
|
|
|
|
# List all user C define here, like -D_DEBUG=1
|
|
UDEFS =
|
|
|
|
# Define ASM defines here
|
|
UADEFS =
|
|
|
|
# List all user directories here
|
|
UINCDIR =
|
|
|
|
# List the user directory to look for the libraries here
|
|
ULIBDIR =
|
|
|
|
# List all user libraries here
|
|
ULIBS =
|
|
|
|
#
|
|
# End of user defines
|
|
##############################################################################
|
|
|
|
RULESPATH = $(CHIBIOS)/os/ports/GCC/ARMCMx
|
|
include $(RULESPATH)/rules.mk
|