diff options
-rw-r--r-- | build-all.mk | 19 | ||||
-rw-r--r-- | test-build.mk | 381 |
2 files changed, 286 insertions, 114 deletions
diff --git a/build-all.mk b/build-all.mk index b2a0be2..d2818a3 100644 --- a/build-all.mk +++ b/build-all.mk @@ -15,7 +15,7 @@ TREE = devo NATIVE = native -DATE = 921117 +DATE = 921118 TAG = latest-$(DATE) @@ -104,6 +104,23 @@ all-cygnus: done @echo done at `date` +build-cygnus: + @echo build started at `date` + @for i in $(TARGETS) ; do \ + if [ "$$i" = "native" ] ; then \ + if [ ! -f $(canonhost)-3stage-done ] ; then \ + echo "3staging $(canonhost) native" ; \ + $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(host)-stamp-3stage-done $(log) && \ + echo " completed successfully" ; \ + fi \ + else \ + echo "building $(canonhost) cross to $$i" ; \ + $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-cygnus $(tlog) && \ + echo " completed successfully" ; \ + fi ; \ + done + @echo done at `date` + all-native: [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR) rm -f /usr/cygnus/$(TAG) diff --git a/test-build.mk b/test-build.mk index 52bc3e5..109203d 100644 --- a/test-build.mk +++ b/test-build.mk @@ -3,15 +3,21 @@ ### compile other bundles, first with cc, then with gcc. ### -### This file was written and is maintained by K. Richard Pixley, -### <rich@cygnus.com>. +### +### USE OF THIS FILE REQUIRES GNU MAKE!!! +### + +### The first versions of the file were written by Rich Pixley (rich@cygnus.com). +### Many subsequent additions (and current maintainance by) david d `zoo' zuhn, +### (zoo@cygnus.com). ### Every invocation of this Makefile needs to have a variable set (host), ### which is the named used for ./configure, and also the prefix for the ### various files and directories used in a three stage. ifndef host -error:; @echo You must set the variable \"host\" to use this Makefile ; exit 1 +error: + @echo You must set the variable \"host\" to use this Makefile ; exit 1 else ### from here to very near the end of the file is the real guts of this @@ -30,15 +36,14 @@ ROOTING := /usr/cygnus ### When working from a tagged set of source, this should be the tag. If not, ### then set the macro to be empty. -#CVS_TAG := -r emacs-920529 -CVS_TAG := +CVS_TAG := ### The name of the cvs module for this release. The intersection of ### CVS_MODULE and CVS_TAG defines the source files in this release. -CVS_MODULE := devo +CVS_MODULE := latest ### Historically, this was identical to CVS_TAG. This is changing. -RELEASE_TAG := latest-921102 +RELEASE_TAG := latest-921118 ### Historically, binaries were installed here. This is changing. release_root := $(ROOTING)/$(RELEASE_TAG) @@ -46,62 +51,198 @@ release_root := $(ROOTING)/$(RELEASE_TAG) ### STOP EDITTING HERE!!! ### With luck, eventually, nothing else will need to be editted. -TIME := time -GCC := gcc -O -GNU_MAKE := /usr/latest/bin/make -override MAKE := make -override MAKEFLAGS := -override MFLAGS := +TIME := time +GCC := gcc -O -g +GNUC := "CC=$(GCC)" +CFLAGS := -g +GNU_MAKE := /usr/latest/bin/make -w -SHELL := /bin/sh +override MAKE := make +override MFLAGS := +#override MAKEFLAGS := -.NOEXPORT: +SHELL := /bin/sh FLAGS_TO_PASS := \ "GCC=$(GCC)" \ + "CFLAGS=$(CFLAGS)" \ "TIME=$(TIME)" \ - "MF=$(MF)" + "MF=$(MF)" \ + "host=$(host)" + + +prefixes = -prefix=$(release_root) -exec_prefix=$(release_root)/H-$(host) +relbindir = $(release_root)/H-$(host)/bin + ### general config stuff -WORKING_DIR := $(host)-objdir -STAGE1DIR := $(WORKING_DIR).1 -STAGE2DIR := $(WORKING_DIR).2 -STAGE3DIR := $(WORKING_DIR).3 -INPLACEDIR := $(host)-in-place -HOLESDIR := $(host)-holes +WORKING_DIR := $(host)-objdir +STAGE1DIR := $(WORKING_DIR).1 +STAGE2DIR := $(WORKING_DIR).2 +STAGE3DIR := $(WORKING_DIR).3 +INPLACEDIR := $(host)-in-place +HOLESDIR := $(host)-holes .PHONY: all -all: in-place $(TREE)-stamp-co do1 do2 do3 comparison +ifdef target +## +## This is a cross compilation +## +arch = $(host)-x-$(target) +config = $(host) -target=$(target) +NATIVEDIR := $(arch)-native-objdir +CYGNUSDIR := $(arch)-cygnus-objdir +LATESTDIR := $(arch)-latest-objdir +FLAGS_TO_PASS := $(FLAGS_TO_PASS) "target=$(target)" + +all: do-native do-latest +build-all: build-native build-latest + +else +## +## This is a native compilation +## +all: $(host)-stamp-3stage-done +#all: in-place do1 do2 do3 comparison +endif + +everything: do-cross +#everything: in-place do1 do2 do3 comparison do-cygnus + +.PHONY: do-native +do-native: $(host)-stamp-holes $(arch)-stamp-native +do-native-config: $(arch)-stamp-native-configured +build-native: $(host)-stamp-holes $(arch)-stamp-native-checked +config-native: $(host)-stamp-holes $(arch)-stamp-native-configured + +$(arch)-stamp-native: + PATH=`pwd`/$(HOLESDIR) ; \ + export PATH ; \ + SHELL=sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) -f test-build.mk $(arch)-stamp-native-installed $(FLAGS_TO_PASS) + if [ -f CLEAN_ALL ] ; then rm -rf $(NATIVEDIR) ; else true ; fi + touch $(arch)-stamp-native + +$(arch)-stamp-native-installed: $(arch)-stamp-native-checked + cd $(NATIVEDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) install + cd $(NATIVEDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) install-info + touch $@ + +$(arch)-stamp-native-checked: $(arch)-stamp-native-built +# cd $(NATIVEDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) check + touch $@ + +$(arch)-stamp-native-built: $(arch)-stamp-native-configured + cd $(NATIVEDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) all + cd $(NATIVEDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) info + touch $@ + +$(arch)-stamp-native-configured: + [ -d $(NATIVEDIR) ] || mkdir $(NATIVEDIR) + (cd $(NATIVEDIR) ; \ + $(TIME) ../$(TREE)/configure $(config) -v -srcdir=../$(TREE) \ + $(prefixes)) + touch $@ + + +.PHONY: do-cygnus +do-cygnus: $(host)-stamp-holes $(arch)-stamp-cygnus +build-cygnus: $(host)-stamp-holes $(arch)-stamp-cygnus-checked +config-cygnus: $(host)-stamp-holes $(arch)-stamp-cygnus-configured + +$(arch)-stamp-cygnus: + [ -f $(relbindir)/gcc ] || (echo "must have gcc available"; exit 1) + PATH=$(relbindir):`pwd`/$(HOLESDIR) ; \ + export PATH ; \ + SHELL=sh ; export SHELL ; \ + echo ; gcc -v ; echo ; \ + $(TIME) $(GNU_MAKE) -f test-build.mk $(arch)-stamp-cygnus-installed $(FLAGS_TO_PASS) + if [ -f CLEAN_ALL ] ; then rm -rf $(CYGNUSDIR) ; else true ; fi + touch $(arch)-stamp-cygnus + +$(arch)-stamp-cygnus-installed: $(arch)-stamp-cygnus-checked + cd $(CYGNUSDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) install + cd $(CYGNUSDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) install-info + touch $@ + +$(arch)-stamp-cygnus-checked: $(arch)-stamp-cygnus-built +# cd $(CYGNUSDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) check + touch $@ + +$(arch)-stamp-cygnus-built: $(arch)-stamp-cygnus-configured + cd $(CYGNUSDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) all + cd $(CYGNUSDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) info + touch $@ + +$(arch)-stamp-cygnus-configured: + [ -d $(CYGNUSDIR) ] || mkdir $(CYGNUSDIR) + cd $(CYGNUSDIR) ; \ + $(TIME) ../$(TREE)/configure $(config) -v -srcdir=../$(TREE) $(prefixes) + touch $@ + +.PHONY: do-latest +do-latest: $(host)-stamp-holes $(arch)-stamp-latest +build-latest: $(host)-stamp-holes $(arch)-stamp-latest-checked + +$(arch)-stamp-latest: + PATH=/usr/latest/bin:`pwd`/$(HOLESDIR) ; \ + export PATH ; \ + SHELL=sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) -f test-build.mk $(arch)-stamp-latest-installed $(FLAGS_TO_PASS) + touch $(arch)-stamp-latest + +$(arch)-stamp-latest-installed: $(arch)-stamp-latest-checked + cd $(LATESTDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) install + cd $(LATESTDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) install-info + touch $@ + +$(arch)-stamp-latest-checked: $(arch)-stamp-latest-built +# cd $(LATESTDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) check + touch $@ + +$(arch)-stamp-latest-built: $(arch)-stamp-latest-configured + cd $(LATESTDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) all + cd $(LATESTDIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) $(GNUC) info + touch $@ + +$(arch)-stamp-latest-configured: + [ -d $(LATESTDIR) ] || mkdir $(LATESTDIR) + cd $(LATESTDIR) ; \ + $(TIME) ../$(TREE)/configure $(config) -v -srcdir=../$(TREE) $(prefixes) + touch $@ + .PHONY: in-place in-place: $(host)-stamp-in-place -$(host)-stamp-in-place: $(TREE)-stamp-co +$(host)-stamp-in-place: PATH=/bin:/usr/bin:/usr/ucb ; \ - export PATH ; \ - SHELL=/bin/sh ; export SHELL ; \ - $(TIME) $(GNU_MAKE) -f test-build.mk $(host)-stamp-in-place-installed host=$(host) $(FLAGS_TO_PASS) + export PATH ; \ + SHELL=/bin/sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) -f test-build.mk $(host)-stamp-in-place-installed host=$(host) $(FLAGS_TO_PASS) touch $@ + if [ -f CLEAN_ALL ] ; then \ + rm -rf $(INPLACEDIR) ; \ + else \ + mv $(INPLACEDIR) $(STAGE1DIR) ; \ + fi $(host)-stamp-in-place-installed: $(host)-stamp-in-place-checked - (cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) install host=$(host)) - (cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) install-info host=$(host)) + cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" install host=$(host) + cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" install-info host=$(host) touch $@ $(host)-stamp-in-place-checked: $(host)-stamp-in-place-built -# (cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) check host=$(host)) +# cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" check host=$(host) touch $@ $(host)-stamp-in-place-built: $(host)-stamp-in-place-configured - (cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) all host=$(host)) - (cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) info host=$(host)) + cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" all host=$(host) + cd $(INPLACEDIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" info host=$(host) touch $@ $(host)-stamp-in-place-configured: $(host)-stamp-in-place-cp - (cd $(INPLACEDIR) ; \ - $(TIME) ./configure $(host) -v \ - -prefix=$(release_root) \ - -exec_prefix=$(release_root)/H-$(host)) + cd $(INPLACEDIR) ; $(TIME) ./configure $(host) -v $(prefixes) touch $@ $(host)-stamp-in-place-cp: @@ -110,8 +251,14 @@ $(host)-stamp-in-place-cp: (cd $(TREE) ; tar cf - .) | (cd $(INPLACEDIR) ; tar xf -) touch $@ +$(host)-stamp-3stage-done: do1 do2 do3 comparison + touch $@ + + .PHONY: do1 do1: $(host)-stamp-holes $(host)-stamp-stage1 +do1-config: $(host)-stamp-stage1-configured +do1-build: $(host)-stamp-stage1-checked $(host)-stamp-stage1: if [ -d $(STAGE1DIR) ] ; then \ @@ -120,32 +267,34 @@ $(host)-stamp-stage1: true ; \ fi PATH=`pwd`/$(HOLESDIR) ; \ - export PATH ; \ - SHELL=sh ; export SHELL ; \ - $(TIME) $(GNU_MAKE) -f test-build.mk $(host)-stamp-stage1-installed host=$(host) $(FLAGS_TO_PASS) + export PATH ; \ + SHELL=sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) -f test-build.mk $(host)-stamp-stage1-installed host=$(host) $(FLAGS_TO_PASS) $(NATIVEC) touch $@ - mv $(WORKING_DIR) $(STAGE1DIR) + if [ -f CLEAN_ALL ] ; then \ + rm -rf $(WORKING_DIR) ; \ + else \ + mv $(WORKING_DIR) $(STAGE1DIR) ; \ + fi $(host)-stamp-stage1-installed: $(host)-stamp-stage1-checked - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) install host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) install-info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" install host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" install-info host=$(host) touch $@ $(host)-stamp-stage1-checked: $(host)-stamp-stage1-built -# (cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) check host=$(host)) +# cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" check host=$(host) touch $@ $(host)-stamp-stage1-built: $(host)-stamp-stage1-configured - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) all host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" all host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(MF) "CFLAGS=$(CFLAGS)" info host=$(host) touch $@ $(host)-stamp-stage1-configured: [ -d $(WORKING_DIR) ] || mkdir $(WORKING_DIR) - (cd $(WORKING_DIR) ; \ - $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) \ - -prefix=$(release_root) \ - -exec_prefix=$(release_root)/H-$(host)) + cd $(WORKING_DIR) ; \ + $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) $(prefixes) touch $@ .PHONY: do2 @@ -157,79 +306,69 @@ $(host)-stamp-stage2: else \ true ; \ fi - PATH=$(release_root)/H-$(host)/bin:`pwd`/$(HOLESDIR) ; \ - export PATH ; \ - SHELL=sh ; export SHELL ; \ - $(TIME) $(MAKE) -f test-build.mk -w $(STAGE2DIR) host=$(host) $(FLAGS_TO_PASS) + PATH=$(relbindir):`pwd`/$(HOLESDIR) ; \ + export PATH ; \ + SHELL=sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) $(FLAGS_TO_PASS) -f test-build.mk -w $(host)-stamp-stage2-installed + mv $(WORKING_DIR) $(STAGE2DIR) touch $@ -$(STAGE2DIR): $(host)-stamp-stage2-installed - mv $(WORKING_DIR) $(STAGE2DIR) $(host)-stamp-stage2-installed: $(host)-stamp-stage2-checked - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" install host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" install-info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" install host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" install-info host=$(host) touch $@ $(host)-stamp-stage2-checked: $(host)-stamp-stage2-built -# (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" check host=$(host)) +# cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) touch $@ $(host)-stamp-stage2-built: $(host)-stamp-stage2-configured - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" all host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" all host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" info host=$(host) touch $@ $(host)-stamp-stage2-configured: [ -d $(WORKING_DIR) ] || mkdir $(WORKING_DIR) - (cd $(WORKING_DIR) ; \ - $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) \ - -prefix=$(release_root) \ - -exec_prefix=$(release_root)/H-$(host)) + cd $(WORKING_DIR) ; \ + $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) $(prefixes) touch $@ .PHONY: do3 do3: $(HOLESDIR) $(host)-stamp-stage3 $(host)-stamp-stage3: - if [ -d $(TREE)/gcc ] ; then \ - if [ -d $(STAGE3DIR) ] ; then \ - mv $(STAGE3DIR) $(WORKING_DIR) ; \ - else \ - true ; \ - fi ; \ - PATH=$(release_root)/H-$(host)/bin:`pwd`/$(HOLESDIR) ; \ - export PATH ; \ - SHELL=sh ; export SHELL ; \ - $(TIME) $(MAKE) -f test-build.mk -w $(STAGE3DIR) host=$(host) $(FLAGS_TO_PASS) ; \ + if [ -d $(STAGE3DIR) ] ; then \ + mv $(STAGE3DIR) $(WORKING_DIR) ; \ else \ true ; \ fi + PATH=$(relbindir):`pwd`/$(HOLESDIR) ; \ + export PATH ; \ + SHELL=sh ; export SHELL ; \ + $(TIME) $(GNU_MAKE) $(FLAGS_TO_PASS) -f test-build.mk -w $(host)-stamp-stage3-checked + mv $(WORKING_DIR) $(STAGE3DIR) touch $@ -$(STAGE3DIR): $(host)-stamp-stage3-checked - mv $(WORKING_DIR) $(STAGE3DIR) $(host)-stamp-stage3-installed: $(host)-stamp-stage3-checked - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" install host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" install-info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" install host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" install-info host=$(host) touch $@ $(host)-stamp-stage3-checked: $(host)-stamp-stage3-built -# (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" check host=$(host)) +# cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) touch $@ $(host)-stamp-stage3-built: $(host)-stamp-stage3-configured - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" all host=$(host)) - (cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) "CC=$(GCC)" info host=$(host)) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" all host=$(host) + cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(MF) $(GNUC) "CFLAGS=$(CFLAGS)" info host=$(host) touch $@ $(host)-stamp-stage3-configured: [ -d $(WORKING_DIR) ] || mkdir $(WORKING_DIR) - (cd $(WORKING_DIR) ; \ - $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) \ - -prefix=$(release_root) \ - -exec_prefix=$(release_root)/H-$(host)) + cd $(WORKING_DIR) ; \ + $(TIME) ../$(TREE)/configure $(host) -v -srcdir=../$(TREE) $(prefixes) touch $@ # These things are needed by a three-stage, but are not included locally. @@ -253,6 +392,7 @@ HOLES := \ expr \ find \ grep \ + head \ hostname \ install \ ld \ @@ -285,8 +425,15 @@ else MAKE_HOLE := make endif +### solaris 2 -- don't use /usr/ucb/cc +ifeq (sparc-sun-solaris2,$(host)) +CC_HOLE := cc +else +CC_HOLE := +endif + ### rs6000 as is busted. We cache a patched version in unsupported. -ifeq ($(subst sun3,rs6000,$(host)),rs6000) +ifeq ($(host),rs6000-ibm-aix) AS_HOLE := as else AS_HOLE := @@ -296,6 +443,7 @@ endif PARTIAL_HOLES := \ $(AS_HOLE) \ $(MAKE_HOLE) \ + $(CC_HOLE) \ flex \ m4 @@ -304,12 +452,14 @@ HOLE_DIRS := \ /bin \ /usr/bin \ /usr/ucb \ + /usr/ccs/bin \ /usr/unsupported/bin ### look in these directories for alternate versions of some tools. PARTIAL_HOLE_DIRS := \ /usr/latest/bin \ /usr/progressive/bin \ + /opt/cygnus/bin \ /usr/vintage/bin \ /usr/unsupported/bin @@ -318,7 +468,7 @@ $(HOLESDIR): $(host)-stamp-holes $(host)-stamp-holes: -rm -rf $(HOLESDIR) -mkdir $(HOLESDIR) - for i in $(HOLES) ; do \ + @for i in $(HOLES) ; do \ found= ; \ for j in $(HOLE_DIRS) ; do \ if [ -x $$j/$$i ] ; then \ @@ -333,7 +483,7 @@ $(host)-stamp-holes: *) echo $$i is NOT found ;; \ esac ; \ done - for i in $(PARTIAL_HOLES) ; do \ + @for i in $(PARTIAL_HOLES) ; do \ found= ; \ for j in $(PARTIAL_HOLE_DIRS) ; do \ if [ -x $$j/$$i ] ; then \ @@ -352,26 +502,39 @@ $(host)-stamp-holes: touch $@ .PHONY: comparison -comparison: -ifeq ($(subst rs6000,iris4,$(subst decstation,iris4,$(host))),iris4) - if [ -d $(TREE)/gcc ] ; then \ - for i in `cd $(STAGE3DIR) ; find . -name \*.o -print` ; do \ - tail +10c $(STAGE2DIR)/$$i > foo1 ; \ - tail +10c $(STAGE3DIR)/$$i > foo2 ; \ - cmp foo1 foo2 || echo $$i ; \ - done ; \ - else \ - true ; \ - fi +comparison: $(host)-stamp-3stage-compared + +$(host)-stamp-3stage-compared: + rm -f .bad-compare +ifeq ($(subst rs6000-ibm-aix,mips-sgi-irix4,$(subst mips-dec-ultrix,mips-sgi-irix4,$(host))),mips-sgi-irix4) + for i in `cd $(STAGE3DIR) ; find . -name \*.o -print` ; do \ + tail +10c $(STAGE2DIR)/$$i > foo1 ; \ + tail +10c $(STAGE3DIR)/$$i > foo2 ; \ + if cmp foo1 foo2 ; then \ + true ; \ + else \ + echo $$i ; \ + touch .bad-compare ; \ + fi ; \ + done + rm -f foo1 foo2 else - if [ -d $(TREE)/gcc ] ; then \ - for i in `cd $(STAGE3DIR) ; find . -name \*.o -print` ; do \ - cmp $(STAGE2DIR)/$$i $(STAGE3DIR)/$$i ; \ - done ; \ + for i in `cd $(STAGE3DIR) ; find . -name \*.o -print` ; do \ + cmp $(STAGE2DIR)/$$i $(STAGE3DIR)/$$i || touch .bad-compare ; \ + done +endif + if [ -f CLEAN_ALL ] ; then \ + rm -rf $(STAGE2DIR) $(STAGE3DIR) ; \ else \ - true ; \ + if [ -f CLEAN_STAGES ] ; then \ + if [ -f .bad-compare ] ; then \ + true ; \ + else \ + rm -rf $(STAGE1DIR) $(STAGE2DIR) ; \ + fi ; \ + fi ; \ fi -endif + touch $@ .PHONY: clean clean: @@ -379,15 +542,7 @@ clean: .PHONY: very very: - rm -rf $(TREE) $(TREE)-stamp-co - -.PHONY: $(TREE) -$(TREE): $(TREE)-stamp-co - -$(TREE)-stamp-co: rm -rf $(TREE) - $(TIME) cvs co $(CVS_TAG) $(CVS_MODULE) - touch $@ force: |