2008-11-20 11:27:31 +00:00
|
|
|
# __________ __ ___.
|
|
|
|
# Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
# Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
# Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
# Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
# \/ \/ \/ \/ \/
|
2008-11-25 19:54:23 +00:00
|
|
|
# $Id$
|
2008-11-20 11:27:31 +00:00
|
|
|
#
|
|
|
|
|
|
|
|
# preprocess - run preprocessor on a file and return the result as a string
|
|
|
|
#
|
|
|
|
# The weird grep -v thing in here is due to Apple's stupidities and is needed
|
|
|
|
# to make this do right when used on Mac OS X.
|
|
|
|
#
|
|
|
|
# The sed line is to prepend the directory to all source files
|
|
|
|
|
|
|
|
preprocess = $(shell $(CC) $(PPCFLAGS) $(2) -E -P -x c -include config.h $(1) | \
|
|
|
|
grep -v '^\#' | \
|
2008-11-21 13:01:03 +00:00
|
|
|
sed -e 's:^..*:$(dir $(1))&:')
|
2008-11-20 11:27:31 +00:00
|
|
|
|
2010-08-21 18:07:12 +00:00
|
|
|
preprocess2file = $(SILENT)$(CC) $(PPCFLAGS) $(3) -E -P -x c -include config.h $(1) | \
|
|
|
|
grep -v '^\#' | grep -v "^$$" > $(2)
|
2008-11-20 11:27:31 +00:00
|
|
|
|
2010-08-21 18:07:12 +00:00
|
|
|
asmdefs2file = $(SILENT)$(CC) $(PPCFLAGS) $(3) -S -x c -o - -include config.h $(1) | \
|
|
|
|
perl -ne 'if(/^_?AD_(\w+):$$/){$$var=$$1}else{/^\W\.(?:word|long)\W(.*)$$/ && $$var && print "\#define $$var $$1\n";$$var=0}' > $(2)
|
2009-07-13 00:40:35 +00:00
|
|
|
|
2008-12-15 09:55:20 +00:00
|
|
|
c2obj = $(addsuffix .o,$(basename $(subst $(ROOTDIR),$(BUILDDIR),$(1))))
|
2008-11-20 11:27:31 +00:00
|
|
|
|
2012-03-26 20:24:57 +00:00
|
|
|
a2lnk = $(patsubst lib%.a,-l%,$(notdir $(1)))
|
|
|
|
|
2012-04-04 19:43:22 +00:00
|
|
|
# objcopy wrapper that keeps debug symbols in DEBUG builds
|
|
|
|
# handles the $(1) == $(2) case too
|
|
|
|
ifndef APP_TYPE
|
|
|
|
objcopy = $(OC) $(if $(filter yes, $(USE_ELF)), -S -x, -O binary) $(1) $(2) # objcopy native
|
|
|
|
else ifneq (,$(findstring sdl-sim,$(APP_TYPE)))
|
|
|
|
objcopy = cp $(1) $(1).tmp;mv -f $(1).tmp $(2) # objcopy simulator
|
|
|
|
else
|
|
|
|
ifdef DEBUG
|
|
|
|
objcopy = cp $(1) $(1).tmp;mv -f $(1).tmp $(2) # objcopy hosted (DEBUG)
|
|
|
|
else
|
|
|
|
objcopy = $(OC) -S -x $(1) $(2) # objcopy hosted (!DEBUG)
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2010-08-21 18:07:12 +00:00
|
|
|
# calculate dependencies for a list of source files $(2) and output them to $(1)
|
|
|
|
mkdepfile = $(SILENT)perl $(TOOLSDIR)/multigcc.pl $(CC) $(PPCFLAGS) $(OTHER_INC) -MG -MM -include config.h -- $(2) | \
|
2010-01-17 13:03:10 +00:00
|
|
|
sed -e "s: lang.h: lang/lang.h:" \
|
2009-07-13 00:40:35 +00:00
|
|
|
-e 's:_asmdefs.o:_asmdefs.h:' \
|
2009-07-12 22:02:09 +00:00
|
|
|
-e "s: max_language_size.h: lang/max_language_size.h:" | \
|
|
|
|
$(TOOLSDIR)/addtargetdir.pl $(ROOTDIR) $(BUILDDIR) \
|
2010-08-21 18:07:12 +00:00
|
|
|
>> $(1)
|
2008-11-20 11:27:31 +00:00
|
|
|
|
|
|
|
# function to create .bmp dependencies
|
2010-08-21 18:07:12 +00:00
|
|
|
bmpdepfile = $(SILENT) \
|
2008-11-20 11:27:31 +00:00
|
|
|
for each in $(2); do \
|
|
|
|
obj=`echo $$each | sed -e 's/\.bmp/.o/' -e 's:$(ROOTDIR):$(BUILDDIR):'`; \
|
|
|
|
src=`echo $$each | sed -e 's/\.bmp/.c/' -e 's:$(ROOTDIR):$(BUILDDIR):'`; \
|
|
|
|
echo $$obj: $$src; \
|
|
|
|
echo $$src: $$each; \
|
|
|
|
done \
|
2010-08-21 18:07:12 +00:00
|
|
|
>> $(1)
|
2008-11-20 11:27:31 +00:00
|
|
|
|
|
|
|
ifndef V
|
|
|
|
SILENT:=@
|
|
|
|
else
|
|
|
|
VERBOSEOPT:=-v
|
|
|
|
endif
|
|
|
|
PRINTS=$(SILENT)$(call info,$(1))
|
|
|
|
|
|
|
|
# old 'make' versions don't have the built-in 'info' function
|
|
|
|
info=old$(shell echo >&2 "Consider upgrading to GNU make 3.81+ for optimum build performance.")
|
|
|
|
ifeq ($(call info),old)
|
|
|
|
export info=echo "$$(1)";
|
|
|
|
endif
|
|
|
|
|