X-Git-Url: https://git.openpandora.org/cgi-bin/gitweb.cgi?p=pandora-x-loader.git;a=blobdiff_plain;f=Makefile;h=0916bd8f4580729a62e0aa03da3d18973d99005e;hp=81b54deefe8215518bc34c5aad9d9e4a4b9caedf;hb=7b6b834d547b0721e9eeeb75e66376c288f8ad48;hpb=5eae9fb96b90370c7e11b757e6de3ac0df4dfd51 diff --git a/Makefile b/Makefile index 81b54de..0916bd8 100644 --- a/Makefile +++ b/Makefile @@ -41,13 +41,74 @@ export HOSTARCH VENDOR= ######################################################################### +# +# X-loader build supports producing a object files to the separate external +# directory. Two use cases are supported: +# +# 1) Add O= to the make command line +# 'make O=/tmp/build all' +# +# 2) Set environement variable BUILD_DIR to point to the desired location +# 'export BUILD_DIR=/tmp/build' +# 'make' +# +# Command line 'O=' setting overrides BUILD_DIR environent variable. +# +# When none of the above methods is used the local build is performed and +# the object files are placed in the source directory. +# + +ifdef O +ifeq ("$(origin O)", "command line") +BUILD_DIR := $(O) +endif +endif + +ifneq ($(BUILD_DIR),) +saved-output := $(BUILD_DIR) + +# Attempt to create a output directory. +$(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR}) + +# Verify if it was successful. +BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd) +$(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist)) +endif # ifneq ($(BUILD_DIR),) -TOPDIR := $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi) -export TOPDIR +OBJTREE := $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR)) +SRCTREE := $(CURDIR) +TOPDIR := $(SRCTREE) +LNDIR := $(OBJTREE) +export TOPDIR SRCTREE OBJTREE -ifeq (include/config.mk,$(wildcard include/config.mk)) +MKCONFIG := $(SRCTREE)/mkconfig +export MKCONFIG + +ifneq ($(OBJTREE),$(SRCTREE)) +REMOTE_BUILD := 1 +export REMOTE_BUILD +endif + +# $(obj) and (src) are defined in config.mk but here in main Makefile +# we also need them before config.mk is included which is the case for +# some targets like unconfig, clean, clobber, distclean, etc. +ifneq ($(OBJTREE),$(SRCTREE)) +obj := $(OBJTREE)/ +src := $(SRCTREE)/ +else +obj := +src := +endif +export obj src + +# Make sure CDPATH settings don't interfere +unexport CDPATH + +######################################################################### + +ifeq ($(obj)include/config.mk,$(wildcard $(obj)include/config.mk)) # load ARCH, BOARD, and CPU configuration -include include/config.mk +include $(obj)include/config.mk export ARCH CPU BOARD VENDOR # load other configuration include $(TOPDIR)/config.mk @@ -63,6 +124,7 @@ endif OBJS = cpu/$(CPU)/start.o +OBJS := $(addprefix $(obj),$(OBJS)) LIBS += board/$(BOARDDIR)/lib$(BOARD).a LIBS += cpu/$(CPU)/lib$(CPU).a @@ -71,44 +133,58 @@ LIBS += fs/fat/libfat.a LIBS += disk/libdisk.a LIBS += drivers/libdrivers.a LIBS += common/libcommon.a + +LIBS := $(addprefix $(obj),$(sort $(LIBS))) .PHONY : $(LIBS) # Add GCC lib PLATFORM_LIBS += -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc SUBDIRS = + +__OBJS := $(subst $(obj),,$(OBJS)) +__LIBS := $(subst $(obj),,$(LIBS)) + ######################################################################### ######################################################################### -ALL = x-load.bin System.map +ALL = $(obj)x-load.bin.ift $(obj)System.map -all: $(ALL) +all ift: $(ALL) +$(obj)x-load.bin.ift: $(obj)signGP $(obj)System.map $(obj)x-load.bin + $(obj)./signGP $(obj)x-load.bin $(TEXT_BASE) $(CONFIG_HEADER) + cp $(obj)x-load.bin.ift $(obj)MLO -x-load.bin: x-load +$(obj)x-load.bin: $(obj)x-load $(OBJCOPY) ${OBJCFLAGS} -O binary $< $@ -x-load: $(OBJS) $(LIBS) $(LDSCRIPT) +$(obj)x-load: $(OBJS) $(LIBS) $(LDSCRIPT) UNDEF_SYM=`$(OBJDUMP) -x $(LIBS) |sed -n -e 's/.*\(__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\ - $(LD) $(LDFLAGS) $$UNDEF_SYM $(OBJS) \ - --start-group $(LIBS) --end-group $(PLATFORM_LIBS) \ + cd $(LNDIR) && $(LD) $(LDFLAGS) $$UNDEF_SYM $(__OBJS) \ + --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \ -Map x-load.map -o x-load - -$(LIBS): - $(MAKE) -C `dirname $@` +$(OBJS): + $(MAKE) -C cpu/$(CPU) $(if $(REMOTE_BUILD),$@,$(notdir $@)) + +$(LIBS): + $(MAKE) -C $(dir $(subst $(obj),,$@)) -System.map: x-load +$(obj)System.map: $(obj)x-load @$(NM) $< | \ grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \ - sort > System.map + sort > $(obj)System.map -oneboot: x-load.bin +oneboot: $(obj)x-load.bin scripts/mkoneboot.sh +$(obj)signGP: scripts/signGP.c + $(HOSTCC) $(HOSTCFLAGS) -o $(obj)signGP $< + ######################################################################### else -all install x-load x-load.srec oneboot depend dep: +all $(obj)x-load $(obj)x-load.bin oneboot depend dep $(obj)System.map: @echo "System not configured - see README" >&2 @ exit 1 endif @@ -116,66 +192,80 @@ endif ######################################################################### unconfig: - rm -f include/config.h include/config.mk + rm -f $(obj)include/config.h $(obj)include/config.mk #======================================================================== # ARM #======================================================================== -######################################################################### -## OMAP1 (ARM92xT) Systems -######################################################################### - -omap1710h3_config : unconfig - @./mkconfig $(@:_config=) arm arm926ejs omap1710h3 - ######################################################################### ## OMAP2 (ARM1136) Systems ######################################################################### -omap2420h4_config : unconfig - @./mkconfig $(@:_config=) arm arm1136 omap2420h4 - -omap2430sdp_config : unconfig - @./mkconfig $(@:_config=) arm arm1136 omap2430sdp - ######################################################################### ## OMAP3 (ARM-CortexA8) Systems ######################################################################### omap3430sdp_config : unconfig - @./mkconfig $(@:_config=) arm omap3 omap3430sdp + @$(MKCONFIG) $(@:_config=) arm omap3 omap3430sdp omap3430labrador_config : unconfig - @./mkconfig $(@:_config=) arm omap3 omap3430labrador + @$(MKCONFIG) $(@:_config=) arm omap3 omap3430labrador omap3evm_config : unconfig - @./mkconfig $(@:_config=) arm omap3 omap3evm + @$(MKCONFIG) $(@:_config=) arm omap3 omap3evm overo_config : unconfig - @./mkconfig $(@:_config=) arm omap3 overo + @$(MKCONFIG) $(@:_config=) arm omap3 overo omap3530beagle_config : unconfig - @./mkconfig $(@:_config=) arm omap3 omap3530beagle + @$(MKCONFIG) $(@:_config=) arm omap3 omap3530beagle + +igep00x0_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap3 igep00x0 + +tam3517_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap3 tam3517 + +tao3530_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap3 tao3530 + +tdm3730_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap3 tdm3730 + +pandora_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap3 pandora + +######################################################################### +## OMAP4 (ARM-CortexA9) Systems +######################################################################### +omap4430panda_config : unconfig + @$(MKCONFIG) $(@:_config=) arm omap4 omap4430panda 1 ######################################################################### clean: - find . -type f \ + find $(OBJTREE) -type f \ \( -name 'core' -o -name '*.bak' -o -name '*~' \ -o -name '*.o' -o -name '*.a' \) -print \ | xargs rm -f clobber: clean - find . -type f \ + find $(OBJTREE) -type f \ \( -name .depend -o -name '*.srec' -o -name '*.bin' \) \ -print \ | xargs rm -f - rm -f $(OBJS) *.bak tags TAGS - rm -fr *.*~ - rm -f x-load x-load.map $(ALL) - rm -f include/asm/proc include/asm/arch + rm -f $(OBJS) $(obj)*.bak $(obj)tags $(obj)TAGS + rm -fr $(obj)*.*~ + rm -f $(obj)x-load $(obj)x-load.map $(ALL) $(obj)x-load.bin.ift $(obj)signGP $(obj)MLO + rm -f $(obj)include/asm/proc $(obj)include/asm/arch +ifeq ($(OBJTREE),$(SRCTREE)) mrproper \ distclean: clobber unconfig +else +mrproper \ +distclean: clobber unconfig + rm -rf $(obj)* +endif backup: F=`basename $(TOPDIR)` ; cd .. ; \