X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=blobdiff_plain;f=tools%2FMakefile;h=5169eb749cede1b0da302c73c8fc620801ffa427;hp=c8fad2323683df3d62275ea3981b38fbebe41e08;hb=d49c1af4fedb2fe1a50bcd58a30b4db6d350322a;hpb=39ed9eab85c390e575242b9d170f290272b6f582 diff --git a/tools/Makefile b/tools/Makefile index c8fad23236..5169eb749c 100644 --- a/tools/Makefile +++ b/tools/Makefile @@ -1,60 +1,99 @@ -# -# Copyright (C) 2006 OpenWrt.org +# +# Copyright (C) 2007 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # # Main makefile for the host tools # -include $(TOPDIR)/rules.mk -TARGETS-y:=sed sstrip ipkg-utils ext2fs squashfs mtd-utils lzma mkimage +curdir:=tools + +# subdirectories to descend into +tools-y := +ifeq ($(CONFIG_EXTERNAL_TOOLCHAIN),) +tools-$(CONFIG_GCC_VERSION_4_3)$(CONFIG_GCC_VERSION_4_4)$(CONFIG_GCC_VERSION_4_5) += gmp mpfr +tools-$(CONFIG_GCC_VERSION_4_5) += mpc libelf +endif +tools-y += m4 autoconf automake bison pkg-config sed mklibs +tools-y += sstrip ipkg-utils genext2fs libuuid mtd-utils mkimage +tools-y += firmware-utils patch-cmdline quilt yaffs2 +tools-$(CONFIG_TARGET_orion) += wrt350nv2-builder upslug2 +ifneq ($(CONFIG_LINUX_2_4)$(CONFIG_LINUX_2_6_25),) +tools-y += squashfs lzma-old +else +ifneq ($(CONFIG_TARGET_ar71xx),) +tools-y += squashfs lzma-old +endif +tools-y += squashfs4 lzma +endif +tools-$(CONFIG_CCACHE) += ccache -TARGETS_DOWNLOAD:=$(patsubst %,%-download,$(TARGETS-y)) -TARGETS_PREPARE:=$(patsubst %,%-prepare,$(TARGETS-y)) -TARGETS_INSTALL:=$(patsubst %,%-install,$(TARGETS-y)) -TARGETS_CLEAN:=$(patsubst %,%-clean,$(TARGETS-y)) +ifdef CONFIG_GCC_USE_GRAPHITE + ifeq ($(CONFIG_GCC_USE_SYSTEM_PPL_CLOOG),) + tools-y += ppl cloog + $(curdir)/cloog/compile := $(curdir)/ppl/install + endif +endif -all: install -download: $(TARGETS_DOWNLOAD) -install: $(TARGETS_INSTALL) -clean: $(TARGETS_CLEAN) +# builddir dependencies +$(curdir)/pkg-config/compile := $(curdir)/sed/install +$(curdir)/squashfs/compile := $(curdir)/lzma-old/install +$(curdir)/squashfs4/compile := $(curdir)/lzma/install +$(curdir)/quilt/compile := $(curdir)/sed/install +$(curdir)/dtc/compile := $(curdir)/bison/install +$(curdir)/autoconf/compile := $(curdir)/m4/install +$(curdir)/automake/compile := $(curdir)/m4/install $(curdir)/autoconf/install +$(curdir)/mpc/compile := $(curdir)/gmp/install +$(curdir)/mpfr/compile := $(curdir)/gmp/install +$(curdir)/mtd-utils/compile := $(curdir)/libuuid/install +$(curdir)/mkimage/compile := $(curdir)/sed/install -squashfs-compile: lzma-install +$(curdir)/builddirs := $(tools-y) $(tools-dep) $(tools-) +$(curdir)/builddirs-default := $(tools-y) -TOOL_STAMP_DIR:=$(STAGING_DIR)/stampfiles +define PrepareStaging + @for dir in $(1); do ( \ + set -x; \ + mkdir -p "$$dir"; \ + cd "$$dir"; \ + mkdir -p bin lib include stamp; \ + ); done +endef -$(TOOL_STAMP_DIR): - mkdir -p $@ +# preparatory work +$(STAGING_DIR)/.prepared: $(TMP_DIR)/.build + $(call PrepareStaging,$(STAGING_DIR)) + mkdir -p $(BUILD_DIR)/stamp + touch $@ -$(STAGING_DIR)/include-host: - @mkdir -p $@ - @$(CP) ./include/*.h $@/ +$(STAGING_DIR_HOST)/.prepared: $(TMP_DIR)/.build + $(call PrepareStaging,$(STAGING_DIR_HOST)) + mkdir -p $(BUILD_DIR_HOST)/stamp + $(INSTALL_DATA) $(TOPDIR)/tools/include/*.h $(STAGING_DIR_HOST)/include/ + touch $@ -$(TOOL_BUILD_DIR): - @mkdir -p $@ -%-download: FORCE - $(MAKE) -C $(patsubst %-download,%,$@) download +define PrepareCommand +$(STAGING_DIR_HOST)/bin/$(1): $(STAGING_DIR)/.prepared + @mkdir -p "$$(dir $$@)"; rm -f "$$@" + @export FILE="$$$$(which $(2) 2>/dev/null | grep -v 'not found' | head -n1)"; [ -n "$$$$FILE" ] || { \ + echo "Command $(1) not found."; false; \ + }; ln -s "$$$$FILE" "$$@" -%-prepare: $(TOOL_STAMP_DIR) $(STAGING_DIR)/include-host $(TOOL_BUILD_DIR) FORCE - @[ -f $(TOOL_STAMP_DIR)/.tool_$@ ] || { \ - $(MAKE) -C $(patsubst %-prepare,%,$@) prepare; \ - } - @touch $(TOOL_STAMP_DIR)/.tool_$@ +endef -%-compile: %-prepare - @[ -f $(TOOL_STAMP_DIR)/.tool_$@ ] || { \ - $(MAKE) -C $(patsubst %-compile,%,$@) compile; \ - } - @touch $(TOOL_STAMP_DIR)/.tool_$@ +$(eval $(call PrepareCommand,find,gfind find)) +$(eval $(call PrepareCommand,md5sum,md5sum $(SCRIPT_DIR)/md5sum)) +$(eval $(call PrepareCommand,cp,gcp cp)) +$(eval $(call PrepareCommand,stat,gstat stat)) -%-install: %-compile - @[ -f $(TOOL_STAMP_DIR)/.tool_$@ ] || { \ - $(MAKE) -C $(patsubst %-install,%,$@) install; \ - } - @touch $(TOOL_STAMP_DIR)/.tool_$@ +$(curdir)/cmddeps = $(patsubst %,$(STAGING_DIR_HOST)/bin/%,find md5sum cp stat) +$(curdir)//prepare = $(STAGING_DIR)/.prepared $(STAGING_DIR_HOST)/.prepared $($(curdir)/cmddeps) +$(curdir)//compile = $(STAGING_DIR)/.prepared $(STAGING_DIR_HOST)/.prepared $($(curdir)/cmddeps) -%-clean: FORCE - @$(MAKE) -C $(patsubst %-clean,%,$@) clean - @rm -f $(TOOL_STAMP_DIR)/.tool_$(patsubst %-clean,%,$@)-* +# prerequisites for the individual targets +$(curdir)/ := .config prereq +$(curdir)//install = $(1)/compile +$(eval $(call stampfile,$(curdir),tools,install,,CONFIG_CCACHE CONFIG_powerpc CONFIG_GCC_VERSION_4_3 CONFIG_GCC_USE_GRAPHITE CONFIG_TARGET_orion)) +$(eval $(call subdir,$(curdir)))