X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=test-build.mk;h=939852bd0a96f9e9a399bf051d35018bb2b891d7;hb=c7b2ac2856cd36fbe61a05a4c43f3135a1825cb0;hp=3cee9a7e9e25c3024ee7b262e665a90d9b8059d2;hpb=60430a466773b7d41173d79684d1dd7c9f2f5b50;p=deliverable%2Fbinutils-gdb.git diff --git a/test-build.mk b/test-build.mk index 3cee9a7e9e..939852bd0a 100644 --- a/test-build.mk +++ b/test-build.mk @@ -32,13 +32,16 @@ TREE := devo include $(TREE)/release-info +# Set TIME to time to get timings. Not done by default because time +# ignores the exit status. +TIME := -TIME := time CONFIG_SHELL := -GCC := $(host)-gcc -O -GNUC := CC="$(GCC)" +GCC := $(host)-gcc +GNUCFLAGS := -g -O2 +GNUC := CC="$(GCC)" CFLAGS="$(GNUCFLAGS)" CFLAGS := -g -CXXFLAGS := -g -O +CXXFLAGS := -g -O2 GNU_MAKE := /usr/latest/bin/make -w MAKEINFOFLAGS := @@ -56,6 +59,18 @@ ifndef target target := $(host) endif +ifeq ($(patsubst %-lynx,lynx,$(host)),lynx) +SHELL := /bin/bash +GNU_MAKE := $(MAKE) +CONFIG_SHELL := /bin/bash +endif + +ifeq ($(patsubst %-m68k-hp-hpux,m68k-hp-hpux,$(host)),m68k-hp-hpux) +SHELL := /usr/unsupported/bin/bash +GNU_MAKE := $(MAKE) +CONFIG_SHELL := /usr/unsupported/bin/bash +endif + ifneq ($(build),$(host)) # We are building on a machine other than the host. We rely upon @@ -71,23 +86,25 @@ BISON := byacc CC := $(host)-gcc CC_FOR_BUILD := gcc CC_FOR_TARGET := $(target)-gcc -CXX := $(host)-c++ -CXX_FOR_TARGET := $(target)-c++ -GCC := $(host)-gcc -O +CFLAGS := $(GNUCFLAGS) +CXX := $(host)-gcc +CXX_FOR_TARGET := $(target)-gcc +GCC := $(host)-gcc GXX := $(host)-g++ GXX_FOR_TARGET := $(target)-g++ HOST_PREFIX := $(build)- HOST_PREFIX_1 := $(build)- LEX := flex MAKEINFO := makeinfo +MUNCH_NM := $(host)-nm NM := $(host)-nm NM_FOR_TARGET := $(target)-nm RANLIB := $(host)-ranlib RANLIB_FOR_TARGET := $(target)-ranlib YACC := $(BISON) -ifeq ($(build),hppa1.1-hp-hpux) -CC_FOR_BUILD := cc +ifeq ($(host),i386-go32) +MAKEINFOFLAGS = --no-split endif FLAGS_TO_PASS := \ @@ -110,6 +127,7 @@ FLAGS_TO_PASS := \ "MAKEINFO=$(MAKEINFO)" \ "MAKEINFOFLAGS=$(MAKEINFOFLAGS)" \ "MF=$(MF)" \ + "MUNCH_NM=$(MUNCH_NM)" \ "NM=$(NM)" \ "NM_FOR_TARGET=$(NM_FOR_TARGET)" \ "RANLIB=$(RANLIB)" \ @@ -137,9 +155,9 @@ FLAGS_TO_PASS := \ "TIME=$(TIME)" \ "MAKEINFOFLAGS=$(MAKEINFOFLAGS)" \ "MF=$(MF)" \ - "SHELL=$(SHELL)" \ "host=$(host)" \ - "RELEASE_TAG=$(RELEASE_TAG)" + "RELEASE_TAG=$(RELEASE_TAG)" \ + "SHELL=$(SHELL)" configenv := @@ -154,7 +172,15 @@ ifeq ($(host),mips-sgi-irix4) CC := cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh2000 endif -ifeq ($(host),mips-mips-riscos5) +ifeq ($(host),hppa1.1-hp-hpux) +CC := cc -Wp,-H256000 +endif + +ifeq ($(host),m68k-hp-hpux) +CC := cc -Wp,-P,-H256000 +endif + +ifeq ($(host),mips-mips-riscos5sysv) CC := cc -non_shared -systype sysv endif @@ -166,23 +192,33 @@ ifeq ($(host),m68k-sun-sunos4.1.1) CC := cc -J endif +# Support gdbtk everywhere +configargs = --enable-gdbtk # We want to use stabs for MIPS targets. ifeq ($(target),mips-idt-ecoff) -configargs = -with-stabs +configargs := $(configargs) --with-stabs endif ifeq ($(target),mips-dec-ultrix) -configargs = -with-stabs +configargs := $(configargs) --with-stabs endif ifeq ($(target),mips-sgi-irix4) -configargs = -with-stabs +configargs := $(configargs) --with-stabs +endif + +ifeq ($(target),mips-sgi-irix5) +configargs := $(configargs) --with-stabs +endif + +ifeq ($(patsubst alpha-dec-osf%,alpha,$(target)),alpha) +configargs := $(configargs) --with-stabs endif # We must use stabs for SVR4 targets. ifeq ($(target),i386-sysv4.2) -configargs = -with-stabs +configargs := $(configargs) --with-stabs endif ifneq ($(CC), 'cc') @@ -194,7 +230,6 @@ ifeq ($(patsubst %-lynxos,lynxos,$(host)),lynxos) FLAGS_TO_PASS := "CONFIG_SHELL=$(CONFIG_SHELL)" $(FLAGS_TO_PASS) endif - # These are the prefixes used for Cygnus builds. prefixes = --prefix=$(release_root) --exec-prefix=$(release_root)/H-$(host) @@ -244,6 +279,50 @@ arch = $(host)-x-$(target) config = -host=$(host) -target=$(target) FLAGS_TO_PASS := $(FLAGS_TO_PASS) "target=$(target)" +ifeq ($(patsubst %-lynx,lynx,$(target)),lynx) +configargs := $(configargs) --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + +ifeq ($(patsubst %-i386-sysv4.2,i386-sysv4.2,$(target)),i386-sysv4.2) +configargs := $(configargs) --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + +ifeq ($(patsubst %-i386-netware,i386-netware,$(target)),i386-netware) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + +ifeq ($(patsubst %-sparc-sun-sunos4.1.3,sparc-sun-sunos4.1.3,$(target)),sparc-sun-sunos4.1.3) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + +ifeq ($(patsubst %-sparc-sun-solaris2,sparc-sun-solaris2,$(target)),sparc-sun-solaris2) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + +ifeq ($(patsubst %-i960-vxworks5.1,i960-vxworks5.1,$(target)),i960-vxworks5.1) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include +endif + +ifeq ($(patsubst %-m68k-vxworks5.1,m68k-vxworks5.1,$(target)),m68k-vxworks5.1) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include +endif + +ifeq ($(patsubst %-i386-unixware,i386-unixware,$(target)),i386-unixware) +configargs := $(configargs) \ + --with-headers=/s1/cygnus/dejagnu/$(target)/include \ + --with-libs=/s1/cygnus/dejagnu/$(target)/lib +endif + ifneq ($(build),$(host)) all: do-cygnus do-latest build-all: build-cygnus build-latest @@ -499,6 +578,9 @@ $(host)-stamp-stage1-installed: $(host)-stamp-stage1-checked $(SET_NATIVE_HOLES) cd $(WORKING_DIR) ; $(TIME) $(MAKE) $(FLAGS_TO_PASS) "CFLAGS=$(CFLAGS)" install-info host=$(host) ifeq ($(host),rs6000-ibm-aix) -rm $(relbindir)/make +endif +ifeq ($(host),rs6000-ibm-aix3.2.5) + -rm $(relbindir)/make endif touch $@ @@ -522,9 +604,9 @@ do2: $(HOLESDIR) $(host)-stamp-stage2 do2-vault: $(HOLESSTAMP) $(host)-stamp-stage2-built if [ -d $(WORKING_DIR).2 ] ; then \ - $(SET_CYGNUS_PATH) cd $(WORKING_DIR).2 ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(CFLAGS)" vault-install ; \ + $(SET_CYGNUS_PATH) cd $(WORKING_DIR).2 ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(GNUCFLAGS)" vault-install ; \ else \ - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(CFLAGS)" vault-install ; \ + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(GNUCFLAGS)" vault-install ; \ fi @@ -540,18 +622,23 @@ $(host)-stamp-stage2: touch $@ +# The SunOS make program gets confused when it is deleted while running. +# The signal handlers return to the wrong place, or something, and the +# program dumps core. To avoid trouble with installing make over itself, +# we delete the installed make program. $(host)-stamp-stage2-installed: $(host)-stamp-stage2-checked - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install-info host=$(host) + -rm -f $(relbindir)/make + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(GNU_MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install-info host=$(host) touch $@ $(host)-stamp-stage2-checked: $(host)-stamp-stage2-built -# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) +# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) check host=$(host) touch $@ $(host)-stamp-stage2-built: $(host)-stamp-stage2-configured - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" all host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" info host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) all host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) info host=$(host) touch $@ $(host)-stamp-stage2-configured: @@ -565,9 +652,9 @@ do3: $(HOLESDIR) $(host)-stamp-stage3 do3-vault: $(HOLESSTAMP) $(host)-stamp-stage3-built if [ -d $(WORKING_DIR).3 ] ; then \ - $(SET_CYGNUS_PATH) cd $(WORKING_DIR).3 ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(CFLAGS)" vault-install ; \ + $(SET_CYGNUS_PATH) cd $(WORKING_DIR).3 ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(GNUCFLAGS)" vault-install ; \ else \ - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(CFLAGS)" vault-install ; \ + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(MAKE) $(FLAGS_TO_PASS) host=$(host) "CFLAGS=$(GNUCFLAGS)" vault-install ; \ fi $(host)-stamp-stage3: @@ -581,25 +668,30 @@ $(host)-stamp-stage3: touch $@ +# The SunOS make program gets confused when it is deleted while running. +# The signal handlers return to the wrong place, or something, and the +# program dumps core. To avoid trouble with installing make over itself, +# we delete the installed make program. $(host)-stamp-stage3-installed: $(host)-stamp-stage3-checked - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install-info host=$(host) + -rm -f $(relbindir)/make + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(GNU_MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install-info host=$(host) if [ -f VAULT-INSTALL ] ; then \ $(SET_CYGNUS_PATH) cd $(CYGNUSDIR) ; $(MAKE) $(FLAGS_TO_PASS) $(GNUC) vault-install ; \ else true ; fi touch $@ $(host)-stamp-stage3-checked: $(host)-stamp-stage3-built -# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) +# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) check host=$(host) touch $@ $(host)-check-3stage: $(host)-stamp-stage3 - $(SET_CYGNUS_PATH) cd $(STAGE3DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) + $(SET_CYGNUS_PATH) cd $(STAGE3DIR) ; $(TIME) $(MAKE) -k -w $(FLAGS_TO_PASS) $(GNUC) check host=$(host) touch $@ $(host)-stamp-stage3-built: $(host)-stamp-stage3-configured - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" all host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" info host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) all host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) info host=$(host) touch $@ $(host)-stamp-stage3-configured: @@ -623,17 +715,17 @@ $(host)-stamp-stage4: $(host)-stamp-stage4-installed: $(host)-stamp-stage4-checked - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" install-info host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) install-info host=$(host) touch $@ $(host)-stamp-stage4-checked: $(host)-stamp-stage4-built -# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" check host=$(host) +# $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) check host=$(host) touch $@ $(host)-stamp-stage4-built: $(host)-stamp-stage4-configured - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" all host=$(host) - $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) "CFLAGS=$(CFLAGS)" info host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) all host=$(host) + $(SET_CYGNUS_PATH) cd $(WORKING_DIR) ; $(TIME) $(MAKE) -w $(FLAGS_TO_PASS) $(GNUC) info host=$(host) touch $@ $(host)-stamp-stage4-configured: @@ -685,7 +777,9 @@ HOLES := \ rmdir \ sed \ sh \ + sleep \ sort \ + tail \ tar \ test \ time \ @@ -694,6 +788,7 @@ HOLES := \ true \ uname \ uniq \ + uptime \ uudecode \ wc \ whoami @@ -717,6 +812,22 @@ ifeq ($(host),i386-go32) DOS_HOLES := aout2exe doschk file endif +ifeq ($(host),i386-lynx) +MAKE_HOLE := make +endif + +ifeq ($(host),m68k-lynx) +MAKE_HOLE := make +endif + +ifeq ($(host),sparc-lynx) +MAKE_HOLE := make +endif + +ifeq ($(host),rs6000-lynx) +MAKE_HOLE := make +endif + ### These things are also needed by a three-stage, but in this case, the GNU version of the tool is required. PARTIAL_HOLES := \ $(MAKE_HOLE) \ @@ -731,6 +842,7 @@ HOLE_DIRS := \ /bin \ /usr/bin \ /usr/ucb \ + /etc /usr/etc \ /usr/unsupported/bin ### look in these directories for alternate versions of some tools. @@ -739,7 +851,8 @@ PARTIAL_HOLE_DIRS := \ /usr/progressive/bin \ $(PARTIAL_HOLE_DIRS) \ /usr/vintage/bin \ - /usr/unsupported/bin + /usr/unsupported/bin \ + $(HOLE_DIRS) $(HOLESDIR): $(holesys)-stamp-holes @@ -870,7 +983,7 @@ comparison-stage3to4: $(host)-stamp-4stage-compared $(host)-stamp-3stage-compared: rm -f .bad-compare -ifeq ($(patsubst %-lynxos,mips-sgi-irix4,$(subst i386-sco3.2v4,mips-sgi-irix4,$(subst rs6000-ibm-aix,mips-sgi-irix4,$(subst mips-dec-ultrix,mips-sgi-irix4,$(host))))),mips-sgi-irix4) +ifeq ($(patsubst %-lynx,mips-sgi-irix4,$(subst i386-sco3.2v4,mips-sgi-irix4,$(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 ; \ @@ -903,7 +1016,7 @@ endif $(host)-stamp-4stage-compared: rm -f .bad-compare -ifeq ($(patsubst %-lynxos,mips-sgi-irix4,$(subst i386-sco3.2v4,mips-sgi-irix4,$(subst rs6000-ibm-aix,mips-sgi-irix4,$(subst mips-dec-ultrix,mips-sgi-irix4,$(host))))),mips-sgi-irix4) +ifeq ($(patsubst %-lynx,mips-sgi-irix4,$(subst i386-sco3.2v4,mips-sgi-irix4,$(subst rs6000-ibm-aix,mips-sgi-irix4,$(subst mips-dec-ultrix,mips-sgi-irix4,$(host))))),mips-sgi-irix4) for i in `cd $(STAGE4DIR) ; find . -name \*.o -print` ; do \ tail +10c $(STAGE3DIR)/$$i > foo1 ; \ tail +10c $(STAGE4DIR)/$$i > foo2 ; \