Add Linux yacc suport.
[deliverable/binutils-gdb.git] / build-all.mk
index f9682e91b05db4dcb2b557edd81d74df7b8d4d18..25d258976f154b82d98957ac74e78c67528db11b 100644 (file)
@@ -1,14 +1,43 @@
-#  Build all of the targets for any given host.....
+# Build all of the targets for any given host.....
 #
-#  This file is going to be ugly.  It will be VERY specific to the
-#  Cygnus environment and build-process.
+# This file is going to be ugly.  It will be VERY specific to the
+# Cygnus environment and build-process.
 #
+# Useful targets (rt = recursion target):
+# (please correct or expand on this)
+# FIXME: Might some of these be superfluous?
 #
-
+# all-emacs
+# all-cygnus   - set up install directories, build 3stage native and all
+#              supported cross targets, then check 3stage'd native
+#              (rt = $(canonhost)-stamp-3stage-done, do-cygnus for cross)
+# native       - set up install directories, build 3stage native
+#              (rt = $(canonhost)-stamp-3stage-1)
+# build-cygnus - build 3stage native and all supported cross targets
+#              (rt = $(canonhost)-stamp-3stage-done, build-cygnus for cross)
+# build-latest - build all supported cross targets
+#              (rt = build-latest)
+# all-native   - set up install directories, build native
+#              (rt = do-native)
+# all-cross    - set up install directories, build all targets
+#              (rt = do-cygnus)
+# config       - configure native and all supported cross targets
+#              (rt = do1-config, do-native-config for cross)
+# build                - build native and all supported cross targets
+#              (rt = do1-build, build-native for cross)
+# 3build       - build 3stage native and all supported cross targets
+#              (rt = all, build-cygnus for cross)
+# build-all-latest - build 3stage native and all supported cross targets
+#              (rt = $(canonhost)-stamp-3stage-done, build-latest for cross)
+# clean                - remove objdir directories, stamp files
+#              (rt = clean)
+#
+# To configure/build for fewer targets, specify TARGETS="native cross1 ...".
+  
 TREE   = devo
 include $(TREE)/release-info
 
-TEST_INSTALL_DISK = /big
+TEST_INSTALL_DISK = /abc
 
 INSTALLDIR = $(TEST_INSTALL_DISK)/$(TREE)-test/$(RELEASE_TAG)
 
@@ -18,13 +47,16 @@ endif
 
 NATIVE  = native
 
-GCC     = gcc -O 
+GCC     = gcc -O2 
 CFLAGS  = -g
-CXXFLAGS = -g -O
+CXXFLAGS = -g -O2 -fexternal-templates
 MAKEINFOFLAGS =
 
 log    = 1>$(canonhost)-build-log 2>&1
-tlog    = 1> $(canonhost)-x-$$i-build-log 2>&1
+clog   = 1>$(canonhost)-check-log 2>&1
+cyglog    = 1> $(canonhost)-x-$$i-cygnus-build-log 2>&1
+latestlog = 1> $(canonhost)-x-$$i-latest-build-log 2>&1
+natlog    = 1> $(canonhost)-x-$$i-native-build-log 2>&1
 
 canonhost := $(shell $(TREE)/config.sub $(host))
 
@@ -32,12 +64,21 @@ canonhost := $(shell $(TREE)/config.sub $(host))
 ifeq ($(canonhost),sparc-sun-solaris2.1)
 canonhost := sparc-sun-solaris2
 endif
+ifeq ($(canonhost),sparc-sun-solaris2.3)
+canonhost := sparc-sun-solaris2
+endif
 ifeq ($(canonhost),mips-dec-ultrix4.2)
 canonhost := mips-dec-ultrix
 endif
 ifeq ($(canonhost),mips-sgi-irix4.0.1)
 canonhost := mips-sgi-irix4
 endif
+ifeq ($(canonhost),mips-sgi-irix4.0.5H)
+canonhost := mips-sgi-irix4
+endif
+ifeq ($(canonhost),mips-sgi-irix5.2)
+canonhost := mips-sgi-irix5
+endif
 ifeq ($(canonhost),rs6000-ibm-aix3.2)
 canonhost := rs6000-ibm-aix
 endif
@@ -47,37 +88,62 @@ endif
 ifeq ($(canonhost),i386-unknown-sco3.2v4.0)
 canonhost := i386-sco3.2v4
 endif
+ifeq ($(canonhost),i386-unknown-sco3.2v4)
+canonhost := i386-sco3.2v4
+endif
 ifeq ($(canonhost),i386-unknown-go32)
 canonhost := i386-go32
 endif
+ifeq ($(canonhost),i386-unknown-sysv4.2)
+canonhost := i386-sysv4.2
+endif
 ifeq ($(canonhost),i386-lynx-lynxos)
-canonhost := i386-lynxos
+canonhost := i386-lynx
 endif
 ifeq ($(canonhost),m68k-lynx-lynxos)
-canonhost := m68k-lynxos
+canonhost := m68k-lynx
+endif
+ifeq ($(canonhost),sparc-lynx-lynxos)
+canonhost := sparc-lynx
+endif
+ifeq ($(canonhost),rs6000-lynx-lynxos)
+canonhost := rs6000-lynx
 endif
 
+#
+# The following TARGETS variable settings probably ought to
+# be made automatically from the 
+# /s1/cygnus/progressive/host-target-pairs.tbl file, using
+# the /s1/cygnus/progressive/targets script.  But, be sure
+# that the native is spelled 'native'.
+#
+
 ifeq ($(canonhost),sparc-sun-sunos4.1.3)
 TARGETS = $(NATIVE) \
+       i386-go32       \
        a29k-amd-udi    \
-       h8300-hms       h8500-hms \
-       i386-aout       i386-go32       i386-coff \
-       i960-vxworks    i960-intel-nindy \
-       mips-idt-ecoff  \
+       h8300-hms       \
+       i386-aout       \
+       i386-lynx       \
+       i960-vxworks5.0 i960-vxworks5.1 \
+       mips-idt-ecoff  mips64-elf      mips-elf \
        m68k-aout       m68k-vxworks    m68k-coff \
-       m88k-coff \
-       sh-hms \
-       sparc-aout      sparc-vxworks   sparclitefrwcompat-aout sparclite-aout \
-       z8k-sim         
-GCC = gcc -O -pipe
+       m68k-lynx       \
+       sh-hms          \
+       sparc-aout      sparc-lynx      sparc-vxworks   \
+       sparclite-aout  sparclite-vxworks \
+       sparclite-coff  z8k-coff \
+       OSE68000 OSE68k mips-ncd-elf
+# The OSE68000 and OSE68k targets are for Ericsson only;
+# the mips-ncd-elf target is for NCD only.
+GCC = gcc -O2 -pipe
 all: all-cygnus
 endif
 
 ifeq ($(canonhost),m68k-sun-sunos4.1.1)
 TARGETS = $(NATIVE) \
-       i960-intel-nindy \
-       m68k-aout       m68k-vxworks    m68k-coff       i960
-GCC = gcc -O -msoft-float
+       m68k-coff 
+GCC = gcc -O2 -msoft-float
 CC = cc -J
 all: all-cygnus
 endif
@@ -85,13 +151,18 @@ endif
 ifeq ($(canonhost),sparc-sun-solaris2)
 TARGETS = $(NATIVE) \
        a29k-amd-udi \
-       m68k-vxworks    m68k-coff       m68k-aout \
-       mips-idt-ecoff \
-       i386-aout \
-       i960-vxworks    i960-intel-nindy \
-       sparc-aout      sparc-vxworks   sparclite-aout 
+       i960-vxworks5.0 i960-vxworks5.1 \
+       m68k-aout       m68k-coff       m68k-vxworks \
+       mipsel-idt-ecoff sparc-lynx \
+       sparclite-aout sparclite-coff m88k-coff z8k-coff \
+       OSE68000 OSE68k \
+       sparc-sun-sunos4.1.3
+# The latter assures that BNR's special build (which they now
+# do for themselves from sources) hasn't developed bit-rot.
+# The OSE68000 and OSE68k targets are for Ericsson only.
+
 CC = cc -Xs
-GCC = gcc -O -pipe
+GCC = gcc -O2 -pipe
 all: all-cygnus
 endif
 
@@ -101,21 +172,37 @@ CC = cc -Wf,-XNg1000
 all: all-cygnus
 endif
 
+ifeq ($(canonhost),alpha-dec-osf1.3)
+TARGETS = $(NATIVE)
+CC = cc
+all: all-cygnus
+endif
+
 ifeq ($(canonhost),mips-sgi-irix4)
-TARGETS        = $(NATIVE) sh-hms
-CC = cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh1500
+TARGETS        = $(NATIVE) \
+       mips-idt-ecoff  sh-hms \
+       mips64-elf
+CC = cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh2000
+all: all-cygnus
+endif
+
+ifeq ($(canonhost),mips-sgi-irix5)
+TARGETS        = $(NATIVE) \
+       mips-idt-ecoff  sh-hms \
+       mips64-elf
+CC = cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh2000
 all: all-cygnus
 endif
 
 ifeq ($(canonhost),rs6000-ibm-aix)
 TARGETS        = $(NATIVE) \
-       i960-vxworks    i960-intel-nindy \
-       m68k-aout       m68k-vxworks 
+       i960-vxworks5.0 i960-vxworks5.1 \
+       m68k-aout
 all: all-cygnus
 endif
 
 ifeq ($(canonhost),m68k-hp-hpux)
-TARGETS        = $(NATIVE) 
+TARGETS        = $(NATIVE)     m68k-aout
 TMPDIR := $(shell mkdir $(canonhost)-tmpdir; cd $(canonhost)-tmpdir ; pwd)
 CC = cc -Wp,-P 
 #CFLAGS = +O1000 
@@ -125,21 +212,14 @@ endif
 
 ifeq ($(canonhost),hppa1.1-hp-hpux)
 TARGETS = \
-       i960-vxworks \
-       m68k-aout       m68k-vxworks
-#      a29k-amd-udi    \
-#      h8300-hms       h8500-hms \
-#      i386-aout       i386-go32 \
-#      i960-vxworks    i960-intel-nindy \
-#      mips-idt-ecoff  \
-#      m68k-aout       m68k-vxworks    m68k-coff \
-#      m88k-coff \
-#      sparc-aout      sparclite-aout \
-#      z8k-sim         
-CC = cc 
+       $(NATIVE) \
+       i960-vxworks5.0 i960-vxworks5.1 \
+       m68k-aout  m68k-coff  m68k-vxworks \
+       z8k-coff
+CC = cc -Wp,-H256000
 #CFLAGS = +Obb2000
 CFLAGS = -g
-all: all-native
+all: all-cygnus
 endif
 
 ifeq ($(canonhost),i386-sco3.2v4)
@@ -150,37 +230,53 @@ endif
 ifeq ($(canonhost),i386-go32)
 TARGETS = \
        a29k-amd-udi \
-       h8300-hms \
-       i386-aout \
+       h8300-hms       \
+       i386-aout       \
        m68k-aout       m68k-coff \
-       mips-idt-ecoff \
+       mips-idt-ecoff  \
+       sh-hms          \
        sparclite-aout
 CC = i386-go32-gcc
-GCC = i386-go32-gcc -O
+GCC = i386-go32-gcc -O2
 CFLAGS =
-CXXFLAGS = -O
+CXXFLAGS = -O2
 MAKEINFOFLAGS = --no-split
-all: all-cross
+all: all-dos
 endif
 
-ifeq ($(canonhost),i386-univel-sysv4.2)
-TARGETS        = $(NATIVE) 
+ifeq ($(canonhost),i386-sysv4.2)
+TARGETS = $(NATIVE) i386-netware
 CC = cc
 all: all-cygnus
 endif
 
-ifeq ($(canonhost),i386-lynxos)
+ifeq ($(canonhost),i386-lynx)
+TARGETS = $(NATIVE)
+CC = /usr/cygnus/progressive/bin/gcc
+all: all-cygnus
+SHELL=/bin/bash
+endif
+
+ifeq ($(canonhost),m68k-lynx)
 TARGETS = $(NATIVE)
-CC = /bin/gcc
+CC = /usr/cygnus/progressive/bin/gcc
 all: all-cygnus
+SHELL=/bin/bash
 endif
 
-ifeq ($(canonhost),m68k-lynxos)
+ifeq ($(canonhost),sparc-lynx)
 TARGETS = $(NATIVE)
-CC = /bin/gcc
+CC = /usr/cygnus/progressive/bin/gcc
 all: all-cygnus
+SHELL=/bin/bash
 endif
 
+ifeq ($(canonhost),rs6000-lynx)
+TARGETS = $(NATIVE)
+CC = /usr/cygnus/progressive/bin/gcc
+all: all-cygnus
+SHELL=/bin/bash
+endif
 
 FLAGS_TO_PASS := \
        "GCC=$(GCC)" \
@@ -189,44 +285,63 @@ FLAGS_TO_PASS := \
        "CXXFLAGS=$(CXXFLAGS)" \
        "host=$(canonhost)" \
        "MAKEINFOFLAGS=$(MAKEINFOFLAGS)" \
-       "RELEASE_TAG=$(RELEASE_TAG)"
+       "RELEASE_TAG=$(RELEASE_TAG)" \
+       "SHELL=$(SHELL)"
+
+# set GNU_MAKE and CONFIG_SHELL correctly in sub-builds
+ifeq ($(patsubst %-lynx,lynx,$(canonhost)),lynx)
+FLAGS_TO_PASS := $(FLAGS_TO_PASS) "GNU_MAKE=$(MAKE)" "CONFIG_SHELL=/bin/bash"
+endif
 
 all-emacs:
        @echo build started at `date`
        [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
        -rm -f $(ROOTING)/$(RELEASE_TAG)
        ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG) 
-       $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) do1 > $(canonhost)-native-log 2>&1 
-       $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) do-latest > $(canonhost)-latest-log 2>&1 
+       $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) do1 > $(canonhost)-emacs-native-log 2>&1 
+       $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) do-latest > $(canonhost)-emacs-latest-log 2>&1 
        @echo done at `date`
 
 all-cygnus:
        @echo build started at `date`
        [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
-       rm -f $(ROOTING)/$(RELEASE_TAG)
-       ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG) 
+       -rm -f $(ROOTING)/$(RELEASE_TAG) && ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG) 
+#
+#      The following line to be used during regular progressive builds
+#      to help developers test, but should be commented out for final
+#      progressive build.
+#
+#      -rm -f $(ROOTING)/progressive-beta && ln -s $(RELEASE_TAG) $(ROOTING)/progresssive
        @for i in $(TARGETS) ; do \
          if [ "$$i" = "native" ] ; then \
             if [ ! -f $(canonhost)-stamp-3stage-done ] ; then \
              echo "3staging $(canonhost) native" ; \
+             echo Flags passed to make: $(FLAGS_TO_PASS) ; \
              $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log) && \
                 echo "     completed successfully" ; \
            else \
              true ; \
-           fi \
+           fi \
          else \
            echo "building $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-cygnus $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-cygnus $(cyglog) && \
               echo "     completed successfully" ; \
          fi ; \
        done
+       @if [ ! -f $(canonhost)-stamp-3stage-checked ] ; then \
+         echo checking $(canonhost) native ; \
+         $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-check-3stage $(clog) ; \
+         touch $(canonhost)-stamp-3stage-checked ; \
+       else \
+         true ; \
+       fi
        @echo done at `date`
 
 native:
        @echo build started at `date`
        [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
-       rm -f $(ROOTING)/$(RELEASE_TAG)
-       ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG) 
+       -rm -f $(ROOTING)/$(RELEASE_TAG) && ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG)
+#      -rm -f $(ROOTING)/progressive-beta && ln -s $(RELEASE_TAG) $(ROOTING)/progressive-beta
        $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log)
        @echo done at `date`
 
@@ -238,10 +353,21 @@ build-cygnus:
              echo "3staging $(canonhost) native" ; \
              $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log) && \
                 echo "     completed successfully" ; \
-           fi \
+           fi \
          else \
            echo "building $(canonhost) cross to $$i:" `date` ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-cygnus $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-cygnus $(cyglog) && \
+              echo "     completed successfully" ; \
+         fi ; \
+       done
+       @echo done at `date`
+
+build-latest:
+       @echo build started at `date`
+       @for i in $(TARGETS) ; do \
+         if [ "$$i" != "native" ] ; then \
+           echo "building $(canonhost) cross to $$i:" `date` ; \
+           $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-latest $(latestlog) && \
               echo "     completed successfully" ; \
          fi ; \
        done
@@ -253,7 +379,7 @@ all-native:
        ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG)
        @for i in $(TARGETS) ; do \
            echo "building $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-native $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-native $(natlog) && \
               echo "     completed successfully" ; \
        done
 
@@ -263,10 +389,19 @@ all-cross:
        ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG)
        @for i in $(TARGETS) ; do \
            echo "building $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build=$(build) do-cygnus $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build=$(build) do-cygnus $(cyglog) && \
               echo "     completed successfully" ; \
        done
 
+do-dos:
+        $(MAKE) -f build-all.mk build=$(host) host=i386-go32 all-dos
+all-dos:
+        @for i in $(TARGETS) ; do \
+            echo "building $(canonhost) cross to $$i" ; \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) host=$(host) target=$$i do-dos $(cyglog) && \
+               echo "     completed successfully at `date`" ; \
+        done
+
 config:
        @for i in $(TARGETS) ; do \
          if [ "$$i" = "native" ] ; then \
@@ -275,7 +410,7 @@ config:
               echo "     completed successfully" ; \
          else \
            echo "config $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-native-config $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i do-native-config $(cyglog) && \
               echo "     completed successfully" ;  \
          fi ; \
        done
@@ -288,7 +423,7 @@ build:
               echo "     completed successfully" ; \
          else \
            echo "building $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-native $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-native $(natlog) && \
               echo "     completed successfully" ; \
          fi ; \
        done
@@ -302,11 +437,27 @@ build:
               echo "     completed successfully" ; \
          else \
            echo "building $(canonhost) cross to $$i" ; \
-            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-cygnus $(tlog) && \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-cygnus $(cyglog) && \
               echo "     completed successfully" ; \
          fi ; \
        done
 
+build-all-latest:
+       @for i in $(TARGETS) ; do \
+         if [ "$$i" = "native" ] ; then \
+           echo "building 3stage for $(canonhost)" ; \
+           $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log) && \
+              echo "     completed successfully" ; \
+         else \
+           echo "building $(canonhost) cross to $$i" ; \
+            $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-latest $(cyglog) && \
+              echo "     completed successfully" ; \
+         fi ; \
+       done
+
+clean:
+       $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) clean $(log)
+
 ### Local Variables:
 ### fill-column: 131
 ### End:
This page took 0.043332 seconds and 4 git commands to generate.