X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=toolchain%2FMakefile;h=36c6ed328a349a9848f8afc65f9294c34e3766f8;hb=a2970d1abf59ddfe8b6bd93ea93612cdd10d0243;hp=161b139d74a399dccee22db6ef85b18869742fe9;hpb=2c30f8199ae332749284a1cd381d7e449b7d03bd;p=openwrt%2Fsvn-archive%2Farchive.git diff --git a/toolchain/Makefile b/toolchain/Makefile index 161b139d74..36c6ed328a 100644 --- a/toolchain/Makefile +++ b/toolchain/Makefile @@ -9,54 +9,68 @@ # Steps: # 1) toolchain/binutils/install # build & install binutils -# 2) toolchain/gcc/prepare +# 2) toolchain/gcc/minimal/install # build & install a minimal gcc, needed for steps 3 & 4 # 3) toolchain/kernel-headers/install # install kernel headers, needed for step 4 -# 4) toolchain/libc/prepare +# 4) toolchain/libc/headers/install # build & install libc headers & support files, needed for step 5 -# 5) toolchain/gcc/compile +# 5) toolchain/gcc/initial/install # build & install an initial gcc, needed for step 6 -# 6) toolchain/libc/compile +# 6) toolchain/libc/install # build & install the final libc -# 7) toolchain/gcc/install +# 7) toolchain/gcc/final/install # build & install the final gcc -# 8) toolchain/libc/install +# 8) toolchain/libc/utils/install # build & install libc utilities # curdir:=toolchain # subdirectories to descend into -$(curdir)/builddirs := $(if $(CONFIG_GDB),gdb) $(if $(CONFIG_INSIGHT),insight) $(if $(CONFIG_EXTERNAL_TOOLCHAIN),,kernel-headers binutils gcc $(LIBC) $(if $(CONFIG_GLIBC_PORTS),glibc-ports)) +$(curdir)/builddirs := $(if $(CONFIG_GDB),gdb) $(if $(CONFIG_INSIGHT),insight) $(if $(CONFIG_EXTERNAL_TOOLCHAIN),wrapper,kernel-headers binutils gcc/minimal gcc/initial gcc/final $(LIBC)/headers $(LIBC)) +ifdef CONFIG_USE_UCLIBC + $(curdir)/builddirs += $(LIBC)/utils +endif $(curdir)/builddirs-compile:=$($(curdir)/builddirs-prepare) $(curdir)/builddirs-install:=$($(curdir)/builddirs-compile) # builddir dependencies ifeq ($(CONFIG_EXTERNAL_TOOLCHAIN),) - $(curdir)/$(LIBC)/prepare:=$(curdir)/kernel-headers/install - $(curdir)/gcc/prepare:=$(curdir)/binutils/install - $(curdir)/kernel-headers/install:=$(curdir)/gcc/prepare - $(curdir)/gcc/compile:=$(curdir)/$(LIBC)/prepare - $(curdir)/$(LIBC)/compile:=$(curdir)/gcc/compile - $(curdir)/gcc/install:=$(curdir)/$(LIBC)/compile - $(curdir)/$(LIBC)/install:=$(curdir)/gcc/install - ifneq ($(CONFIG_GLIBC_PORTS),) - $(curdir)/glibc/prepare:=$(curdir)/glibc-ports/prepare - endif + $(curdir)/gcc/minimal/compile:=$(curdir)/binutils/install + $(curdir)/kernel-headers/install:=$(curdir)/gcc/minimal/install + $(curdir)/gcc/initial/prepare:=$(curdir)/gcc/minimal/prepare + $(curdir)/gcc/final/prepare:=$(curdir)/gcc/initial/prepare + + $(curdir)/$(LIBC)/headers/compile:=$(curdir)/kernel-headers/install + $(curdir)/gcc/initial/compile:=$(curdir)/$(LIBC)/headers/install + $(curdir)/$(LIBC)/compile:=$(curdir)/gcc/initial/install + $(curdir)/gcc/final/compile:=$(curdir)/$(LIBC)/install + $(curdir)/$(LIBC)/utils/compile:=$(curdir)/gcc/final/install + $(curdir)/$(LIBC)/prepare:=$(curdir)/$(LIBC)/headers/prepare + $(curdir)/$(LIBC)/utils/prepare:=$(curdir)/$(LIBC)/headers/prepare +endif + +ifdef CONFIG_GCC_VERSION_LLVM + $(curdir)/builddirs += llvm + $(curdir)/gcc/minimal/compile += $(curdir)/llvm/install endif +ifndef DUMP_TARGET_DB ifneq ($(ARCH),) $(TOOLCHAIN_DIR)/info.mk: .config @for dir in $(TOOLCHAIN_DIR); do ( \ - set -x; \ + $(if $(QUIET),,set -x;) \ mkdir -p "$$dir"; \ cd "$$dir"; \ + ln -nsf lib lib64; \ + ln -nsf lib lib32; \ mkdir -p stamp lib usr/include usr/lib ; \ ); done @grep GCC_VERSION $@ >/dev/null 2>&1 || $(INSTALL_DATA) $(TOPDIR)/toolchain/info.mk $@ @touch $@ endif +endif # prerequisites for the individual targets $(curdir)/ := .config prereq @@ -64,7 +78,9 @@ $(curdir)//prepare = $(STAGING_DIR)/.prepared $(TOOLCHAIN_DIR)/info.mk $(curdir)//compile = $(1)/prepare $(curdir)//install = $(1)/compile +ifndef DUMP_TARGET_DB $(TOOLCHAIN_DIR)/stamp/.gcc-initial_installed: +endif $(eval $(call stampfile,$(curdir),toolchain,install,$(TOOLCHAIN_DIR)/stamp/.gcc-initial_installed,,$(TOOLCHAIN_DIR))) $(eval $(call subdir,$(curdir)))