|
|
#/*------------------------------------------------------------------------------
|
|
|
#-- 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 = sparc-elf-
|
|
|
LIBUC_CC = $(LIBUC_PREFIX)gcc
|
|
|
LIBUC_CXX = $(LIBUC_PREFIX)g++
|
|
|
LIBUC_AR = $(LIBUC_PREFIX)ar
|
|
|
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 =
|
|
|
LIBUC_CFLAGS = $(LIBUC_FMCU)
|
|
|
LIBUC_CFLAGS = --std=gnu99 -fgnu89-inline
|
|
|
LIBUC_CFLAGS +=
|
|
|
LIBUC_LDFLAGS =
|
|
|
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_CXXFLAGS += -Wextra -Wundef -Wcast-align -msoft-float
|
|
|
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/LEON3
|
|
|
LIBUC_INC_DIR = $(LIBUC)/lib/includes/LEON3
|
|
|
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
|
|
|
#---------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
|
#---------------------------------------------------------------------------------
|
|
|
# RULES
|
|
|
#---------------------------------------------------------------------------------
|
|
|
|
|
|
all:
|
|
|
@echo "sparc-elf-gcc rules"
|
|
|
|
|
|
|
|
|
bin: $(BINDIR)/$(TARGET).bin $(BINDIR)/$(TARGET).hex
|
|
|
@echo "compile bin"
|
|
|
|
|
|
|
|
|
|
|
|
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)/
|
|
|
|
|
|
|
|
|
|
|
|
$(OBJECTFILES) : $(OBJDIR)/%.o : %.c $(INC_LIBS_DEPS) $(HEADERS)
|
|
|
mkdir -p $(OBJDIR)
|
|
|
$(LIBUC_CC) -O3 -I $(LIBUC_INCLUDES) $(LIBUC_BSP_INC) -c $(LIBUC_CFLAGS) $< -o $@
|
|
|
|
|
|
|
|
|
%.elf: $(OBJECTFILES)
|
|
|
mkdir -p $(BINDIR)
|
|
|
$(LIBUC_CC) $(LIBUC_LDFLAGS) $^ -o $@ $(LIBUC_BSP) $(LIBUC_LIBRARIES)
|
|
|
|
|
|
|
|
|
%.bin: %.elf $(BIN_LIBS_DEPS)
|
|
|
$(LIBUC_OBJCOPY) $(LIBUC_CPFLAGS) -O binary $< $*.bin
|
|
|
|
|
|
|
|
|
%.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"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|