|
|
#/*------------------------------------------------------------------------------
|
|
|
#-- This file is a part of the libuc, microcontroler library
|
|
|
#-- Copyright (C) 2011, Alexis Jeandet
|
|
|
#--
|
|
|
#-- 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
|
|
|
#-------------------------------------------------------------------------------
|
|
|
#-- Author : Alexis Jeandet
|
|
|
#-- Mail : alexis.jeandet@gmail.com
|
|
|
#-------------------------------------------------------------------------------*/
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# GCC EXECUTABLES
|
|
|
#---------------------------------------------------------------------------------
|
|
|
LIBUC_PREFIX = arm-none-eabi-
|
|
|
LIBUC_CC = $(LIBUC_PREFIX)gcc
|
|
|
LIBUC_CXX = $(LIBUC_PREFIX)g++
|
|
|
LIBUC_AR = $(LIBUC_PREFIX)ar
|
|
|
LIBUC_RANLIB = $(LIBUC_PREFIX)ranlib
|
|
|
LIBUC_AS = $(LIBUC_PREFIX)as
|
|
|
LIBUC_LD = $(LIBUC_PREFIX)ld
|
|
|
LIBUC_SIZE = $(LIBUC_PREFIX)size
|
|
|
LIBUC_STRIP = $(LIBUC_PREFIX)strip -s
|
|
|
LIBUC_READELF = $(LIBUC_PREFIX)readelf
|
|
|
LIBUC_OBJCOPY=$(LIBUC_PREFIX)objcopy
|
|
|
LIBUC_OBJDUMP=$(LIBUC_PREFIX)objdump
|
|
|
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# GCC FLAGS
|
|
|
#---------------------------------------------------------------------------------
|
|
|
LIBUC_FMCU = -mcpu=arm7tdmi
|
|
|
LIBUC_CFLAGS = $(LIBUC_FMCU)
|
|
|
LIBUC_CFLAGS += -g -gdwarf-2 -fomit-frame-pointer
|
|
|
LIBUC_CFLAGS += -Wall -Wextra -Wundef -Wcast-align -DROM_RUN
|
|
|
LIBUC_LDFLAGS = -nostartfiles
|
|
|
LIBUC_ODFLAGS = -x --syms
|
|
|
LIBUC_CPFLAGS =
|
|
|
LIBUC_CFLAGS_WARN_ON = -Wall
|
|
|
LIBUC_CFLAGS_WARN_OFF = -w
|
|
|
LIBUC_CFLAGS_RELEASE = -O2
|
|
|
LIBUC_CFLAGS_DEBUG = -g
|
|
|
LIBUC_CFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -g
|
|
|
LIBUC_CFLAGS_STATIC_LIB = -fPIC
|
|
|
LIBUC_CFLAGS_SOFT_FPU = -msoft-float
|
|
|
LIBUC_CFLAGS_HARD_FPU =
|
|
|
|
|
|
LIBUC_CXXFLAGS = $(LIBUC_FMCU)
|
|
|
LIBUC_CXXFLAGS += -g -gdwarf-2 $(LIBUC_FMCU)
|
|
|
LIBUC_CXXFLAGS += -Wall -Wextra -Wundef -Wcast-align
|
|
|
LIBUC_CXXFLAGS_WARN_ON = -Wall
|
|
|
LIBUC_CXXFLAGS_WARN_OFF = -w
|
|
|
LIBUC_CXXFLAGS_RELEASE = -O2
|
|
|
LIBUC_CXXFLAGS_DEBUG = -g
|
|
|
LIBUC_CXXFLAGS_RELEASE_WITH_DEBUGINFO += -O2 -g
|
|
|
LIBUC_CXXFLAGS_STATIC_LIB = -fPIC
|
|
|
LIBUC_CXXFLAGS_SOFT_FPU = -msoft-float
|
|
|
LIBUC_CXXFLAGS_HARD_FPU =
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# LIBRARY DEFINITIONS
|
|
|
#---------------------------------------------------------------------------------
|
|
|
LIBUC_LIBS_DIR = $(LIBUC)/lib/bin/lpc21XX
|
|
|
LIBUC_INC_DIR = $(LIBUC)/lib/includes/lpc21XX
|
|
|
include $(LIBUC)/rules/common/libsrules.mk
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# BOARD SUPORT PACKAGES
|
|
|
#---------------------------------------------------------------------------------
|
|
|
LIBUC_BSP_DIR=$(LIBUC)/bsp
|
|
|
LIBUC_BSP_BIN_DIR= $(LIBUC_BSP_DIR)/bin
|
|
|
LIBUC_BSP_INC_DIR= $(LIBUC_BSP_DIR)/includes
|
|
|
LIBUC_BSP = -L $(LIBUC_BSP_BIN_DIR)/$(BSP) -static -lbsp
|
|
|
LIBUC_BSP_INC = -I $(LIBUC_BSP_INC_DIR)/$(BSP)
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# DEVICE SPECIAL FILES
|
|
|
#---------------------------------------------------------------------------------
|
|
|
LINKER_SCRIPT = $(ARCHFOLDER)/LPC2378-ROM.ld
|
|
|
DEVSOURCES +=
|
|
|
DEVSOURCESND = $(notdir $(DEVSOURCES))
|
|
|
DEVOBJECTFILES += $(DEVSOURCESND:.c=.o)
|
|
|
DEVOBJECTFILES := $(addprefix $(OBJDIR)/,$(DEVOBJECTFILES))
|
|
|
OBJECTFILES += $(DEVOBJECTFILES)
|
|
|
|
|
|
ASMDEVSOURCES += $(ARCHFOLDER)/crt0.S
|
|
|
ASMDEVSOURCESND = $(notdir $(ASMDEVSOURCES))
|
|
|
ASMDEVOBJECTFILES += $(ASMDEVSOURCESND:.S=.o)
|
|
|
ASMDEVOBJECTFILES := $(addprefix $(OBJDIR)/,$(ASMDEVOBJECTFILES))
|
|
|
ASMOBJECTFILES += $(ASMDEVOBJECTFILES)
|
|
|
|
|
|
#RUN_MODE=ROM_RUN
|
|
|
#LIBUC_CFLAGS += -D$(RUN_MODE)
|
|
|
|
|
|
LPC23XX_INCDIR=$(ARCHFOLDER)
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# RULES
|
|
|
#---------------------------------------------------------------------------------
|
|
|
|
|
|
all:
|
|
|
@echo "lpc23XX-arm-noabi-gcc rules"
|
|
|
|
|
|
|
|
|
bin: $(ASMDEVSOURCESND) $(DEVSOURCESND) $(BINDIR)/$(TARGET).bin $(BINDIR)/$(TARGET).hex
|
|
|
@echo "compile bin"
|
|
|
|
|
|
$(DEVSOURCESND): $(DEVSOURCES)
|
|
|
cp -f $(DEVSOURCES) ./
|
|
|
|
|
|
$(ASMDEVSOURCESND): $(ASMDEVSOURCES)
|
|
|
cp -f $(ASMDEVSOURCES) ./
|
|
|
|
|
|
lib: $(TARGETINSTALLPATH)/$(TARGET).a
|
|
|
@echo "compile lib"
|
|
|
|
|
|
%.a: $(OBJECTFILES)
|
|
|
mkdir -p $(TARGETINSTALLPATH)
|
|
|
@if [ -z $(HEADERSINSTALLPATH) ] ; then echo "No headers to install" ; else mkdir -p $(HEADERSINSTALLPATH) ; fi
|
|
|
$(LIBUC_AR) rcs $@ $(OBJECTFILES) #$(LIBUC_AR) rcs $(TARGETINSTALLPATH)/$@ $(OBJECTFILES)
|
|
|
@if [ -z $(HEADERS) ] ; then echo "No headers to install" ; else cp -f $(HEADERS) $(HEADERSINSTALLPATH)/ ; fi
|
|
|
#cp -f $(HEADERS) $(HEADERSINSTALLPATH)/
|
|
|
|
|
|
|
|
|
#%.o: %.c
|
|
|
# $(LIBUC_CC) -O3 -I $(LPC17XX_INCDIR) $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -MM $< -MF $*.d -MP
|
|
|
# $(LIBUC_CC) -O3 -I $(LPC17XX_INCDIR) $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -c $(LIBUC_CFLAGS) $< -o $@
|
|
|
|
|
|
$(OBJECTFILES) : $(OBJDIR)/%.o : %.c $(INC_LIBS_DEPS) $(HEADERS)
|
|
|
mkdir -p $(OBJDIR)
|
|
|
$(LIBUC_CC) -O3 -I $(LPC23XX_INCDIR) $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -MM $< -MF $*.d -MP
|
|
|
$(LIBUC_CC) -O3 -I $(LPC23XX_INCDIR) $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -c $(LIBUC_CFLAGS) $< -o $@
|
|
|
|
|
|
|
|
|
|
|
|
$(ASMOBJECTFILES) : $(OBJDIR)/%.o : %.S $(INC_LIBS_DEPS) $(HEADERS)
|
|
|
mkdir -p $(OBJDIR)
|
|
|
$(LIBUC_CC) -O3 -I $(LPC23XX_INCDIR) $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -c $(LIBUC_CFLAGS) $< -o $@
|
|
|
|
|
|
|
|
|
%.elf: $(LINKER_SCRIPT) $(ASMOBJECTFILES) $(OBJECTFILES)
|
|
|
mkdir -p $(BINDIR)
|
|
|
$(LIBUC_CC) $(LIBUC_LDFLAGS) $(LIBUC_CFLAGS) -T $^ -o $@ $(LIBUC_BSP) $(LIBUC_LIBRARIES)
|
|
|
$(LIBUC_OBJDUMP) $(LIBUC_ODFLAGS) $@ > $(@:.elf=.dump)
|
|
|
$(LIBUC_SIZE) $@
|
|
|
|
|
|
|
|
|
|
|
|
%.bin: %.elf $(BIN_LIBS_DEPS)
|
|
|
$(LIBUC_OBJCOPY) $(LIBUC_CPFLAGS) -O binary $< $*.bin
|
|
|
@echo "BIN_LIBS_DEPS"
|
|
|
@echo $(BIN_LIBS_DEPS)
|
|
|
|
|
|
%.hex: %.elf
|
|
|
$(LIBUC_OBJCOPY) $(LIBUC_CPFLAGS) -O ihex $< $*.hex
|
|
|
|
|
|
|
|
|
clean:
|
|
|
rm -f *.o *.d *.bin *.hex *.dump *.map *.a *.elf
|
|
|
rm -f $(OBJECTFILES)
|
|
|
rm -f $(BINDIR)/*.bin
|
|
|
rm -f $(BINDIR)/*.hex
|
|
|
rm -f $(BINDIR)/*.dump
|
|
|
rm -f $(BINDIR)/*.map
|
|
|
rm -f $(BINDIR)/*.a
|
|
|
rm -f $(BINDIR)/*.elf
|
|
|
rm -f $(DEVSOURCESND)
|
|
|
|
|
|
distclean: clean libclean
|
|
|
rm -f $(TARGETINSTALLPATH)/*.bin
|
|
|
rm -f $(TARGETINSTALLPATH)/*.a
|
|
|
|
|
|
|
|
|
|
|
|
libclean:
|
|
|
@echo "not a library"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|