# # 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) \ $(CHIBIOS)/os/various/evtimer.c # C++ sources that can be compiled in ARM or THUMB mode depending on the global # setting. CPPSRC = main.cpp \ irq_ipc.cpp \ irq_lcd_frame.cpp \ irq_controls.cpp \ event.cpp \ message_queue.cpp \ hackrf_hal.cpp \ portapack.cpp \ portapack_shared_memory.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 \ baseband_sgpio.cpp \ tuning.cpp \ rf_path.cpp \ rffc507x.cpp \ rffc507x_spi.cpp \ max2837.cpp \ max5864.cpp \ debounce.cpp \ touch.cpp \ touch_adc.cpp \ encoder.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_rds.cpp \ ui_lcr.cpp \ ui_whistle.cpp \ ui_jammer.cpp \ ui_afsksetup.cpp \ ui_console.cpp \ ui_receiver.cpp \ ui_spectrum.cpp \ receiver_model.cpp \ transmitter_model.cpp \ spectrum_color_lut.cpp \ ../common/utility.cpp \ ../common/debug.cpp \ ../common/gcc.cpp \ m4_startup.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 # 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 # 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