mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-09 20:46:07 +01:00
142 lines
4.5 KiB
Makefile
142 lines
4.5 KiB
Makefile
#
|
|
# Copyright (C) 2015, The LibrePilot Project, http://www.librepilot.org
|
|
# Copyright (c) 2009-2013, The OpenPilot Team, http://www.openpilot.org
|
|
#
|
|
# 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 3 of the License, 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; if not, write to the Free Software Foundation, Inc.,
|
|
# 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
#
|
|
|
|
ifndef FLIGHT_MAKEFILE
|
|
$(error Top level Makefile must be used to build this target)
|
|
endif
|
|
|
|
# Paths
|
|
TOPDIR = .
|
|
OPSYSTEM = $(TOPDIR)
|
|
BOARDINC = $(TOPDIR)/..
|
|
OPSYSTEMINC = $(OPSYSTEM)/inc
|
|
PIOSINC = $(PIOS)/inc
|
|
PIOSCOMMON = $(PIOS)/common
|
|
FLIGHTLIBINC = $(FLIGHTLIB)/inc
|
|
|
|
# ARM DSP library
|
|
override USE_DSP_LIB := NO
|
|
|
|
## PIOS Hardware
|
|
ifneq (,$(findstring STM32F10,$(CHIP)))
|
|
include $(PIOS)/stm32f10x/library.mk
|
|
else ifneq (,$(findstring STM32F4,$(CHIP)))
|
|
include $(PIOS)/stm32f4xx/library.mk
|
|
else ifneq (,$(findstring STM32F30,$(CHIP)))
|
|
include $(PIOS)/stm32f30x/library.mk
|
|
else ifneq (,$(findstring STM32F0,$(CHIP)))
|
|
include $(PIOS)/stm32f0x/library.mk
|
|
else
|
|
$(error Unsupported CHIP: $(CHIP))
|
|
endif
|
|
|
|
# List C source files here (C dependencies are automatically generated).
|
|
# Use file-extension c for "c-only"-files
|
|
|
|
## Bootloader Core
|
|
|
|
SRC += $(OPSYSTEM)/main.c
|
|
SRC += $(OPSYSTEM)/pios_board.c
|
|
|
|
## PIOS Hardware (Common)
|
|
SRC += $(PIOSCOMMON)/pios_board_info.c
|
|
SRC += $(PIOSCOMMON)/pios_com_msg.c
|
|
SRC += $(PIOSCOMMON)/pios_iap.c
|
|
ifneq ($(PIOS_OMITS_USB),YES)
|
|
SRC += ../pios_usb_board_data.c
|
|
SRC += $(PIOSCOMMON)/pios_usb_desc_hid_only.c
|
|
SRC += $(PIOSCOMMON)/pios_usb_util.c
|
|
endif
|
|
SRC += $(PIOSCOMMON)/pios_led.c
|
|
|
|
## Misc library functions
|
|
SRC += $(FLIGHTLIB)/op_dfu.c
|
|
SRC += $(FLIGHTLIB)/printf-stdarg.c
|
|
|
|
## CPP support
|
|
ifeq ($(USE_CXX),YES)
|
|
CPPSRC += $(FLIGHTLIB)/mini_cpp.cpp
|
|
endif
|
|
|
|
# List C source files here which must be compiled in ARM-Mode (no -mthumb).
|
|
# Use file-extension c for "c-only"-files
|
|
SRCARM +=
|
|
|
|
# List C++ source files here.
|
|
# Use file-extension .cpp for C++-files (not .C)
|
|
CPPSRC +=
|
|
|
|
# List C++ source files here which must be compiled in ARM-Mode.
|
|
# Use file-extension .cpp for C++-files (not .C)
|
|
CPPSRCARM +=
|
|
|
|
# List Assembler source files here.
|
|
# Make them always end in a capital .S. Files ending in a lowercase .s
|
|
# will not be considered source files but generated files (assembler
|
|
# output from the compiler), and will be deleted upon "make clean"!
|
|
# Even though the DOS/Win* filesystem matches both .s and .S the same,
|
|
# it will preserve the spelling of the filenames, and gcc itself does
|
|
# care about how the name is spelled on its command-line.
|
|
ASRC +=
|
|
|
|
# List Assembler source files here which must be assembled in ARM-Mode.
|
|
ASRCARM +=
|
|
|
|
# List any extra directories to look for include files here.
|
|
# Each directory must be seperated by a space.
|
|
EXTRAINCDIRS += $(PIOS)
|
|
EXTRAINCDIRS += $(PIOSINC)
|
|
EXTRAINCDIRS += $(BOARDINC)
|
|
EXTRAINCDIRS += $(FLIGHTLIBINC)
|
|
EXTRAINCDIRS += $(PIOSCOMMON)
|
|
EXTRAINCDIRS += $(OPSYSTEMINC)
|
|
|
|
# List any extra directories to look for library files here.
|
|
# Also add directories where the linker should search for
|
|
# includes from linker-script to the list
|
|
# Each directory must be seperated by a space.
|
|
EXTRA_LIBDIRS +=
|
|
|
|
# Extra Libraries
|
|
# Each library-name must be seperated by a space.
|
|
# i.e. to link with libxyz.a, libabc.a and libefsl.a:
|
|
# EXTRA_LIBS = xyz abc efsl
|
|
# for newlib-lpc (file: libnewlibc-lpc.a):
|
|
# EXTRA_LIBS = newlib-lpc
|
|
EXTRA_LIBS +=
|
|
|
|
# Compiler flags
|
|
CDEFS +=
|
|
# enable bootloader specific stuffs
|
|
CDEFS += -DBOOTLOADER
|
|
|
|
# Set linker-script name depending on selected submodel name
|
|
ifeq ($(MCU),cortex-m3)
|
|
LDFLAGS += -T$(LINKER_SCRIPTS_PATH)/link_$(BOARD)_memory.ld
|
|
LDFLAGS += -T$(LINKER_SCRIPTS_PATH)/link_$(BOARD)_BL_sections.ld
|
|
else ifeq ($(MCU),cortex-m4)
|
|
LDFLAGS += $(addprefix -T,$(LINKER_SCRIPTS_BL))
|
|
else ifeq ($(MCU),cortex-m0)
|
|
LDFLAGS += -T$(LINKER_SCRIPTS_PATH)/link_$(BOARD)_memory.ld
|
|
LDFLAGS += -T$(LINKER_SCRIPTS_PATH)/link_$(BOARD)_BL_sections.ld
|
|
endif
|
|
|
|
# Add jtag targets (program and wipe)
|
|
$(eval $(call JTAG_TEMPLATE,$(OUTDIR)/$(TARGET).bin,$(BL_BANK_BASE),$(BL_BANK_SIZE),$(OPENOCD_JTAG_CONFIG),$(OPENOCD_CONFIG)))
|