-# 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?
#
-
-TREE = devo
+# 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 = /dumbo
INSTALLDIR = $(TEST_INSTALL_DISK)/$(TREE)-test/$(RELEASE_TAG)
NATIVE = native
-GCC = gcc -O
+GCC = gcc
CFLAGS = -g
-CXXFLAGS = -g -O
+GNUCFLAGS= -g -O2
+CXXFLAGS = -g -O2
MAKEINFOFLAGS =
log = 1>$(canonhost)-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))
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-dec-ultrix4.4)
+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
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
+ifeq ($(canonhost),i386-unknown-linux)
+canonhost := i386-linux
+endif
+ifeq ($(canonhost),i486-unknown-linux)
+canonhost := i486-linux
+endif
+ifeq ($(canonhost),i586-unknown-linux)
+canonhost := i486-linux
+endif
+ifeq ($(canonhost),i386-unknown-linuxaout)
+canonhost := i386-linuxaout
+endif
+ifeq ($(canonhost),i486-unknown-linuxaout)
+canonhost := i486-linuxaout
+endif
+ifeq ($(canonhost),i586-unknown-linuxaout)
+canonhost := i486-linuxaout
+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)
+TARGETS = $(NATIVE) \
+ i386-go32 \
+ a29k-amd-udi a29k-vxworks5.1 \
+ sh-hms h8300-hms \
+ powerpc-eabi hppa1.1-hp-proelf \
+ i386-aout i386-elf \
+ i960-nindy-coff i960-vxworks5.0 i960-vxworks5.1 \
+ m68k-aout m68k-coff m68k-elf m68k-vxworks5.1 \
+ mips-elf mips-idt-ecoff mips64-elf \
+ sparc-aout sparclite-aout sparclite-coff \
+ z8k-coff i386-unixware mips-ncd-elf \
+ OSE68000 OSE68k
+GCC = gcc -O2 -pipe
+all: all-cygnus
endif
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-intel-nindy i960-vxworks \
- mips-idt-ecoff \
- m68k-aout m68k-vxworks m68k-coff \
- m88k-coff \
- sh-hms \
- sparc-aout sparc-vxworks sparclite-aout \
- z8k-sim z8k-coff
-GCC = gcc -O -pipe
+ hppa1.1-hp-proelf \
+ i386-aout i386-elf \
+ i960-nindy-coff i960-vxworks5.0 i960-vxworks5.1 \
+ m68k-aout m68k-coff m68k-elf m68k-vxworks5.1 \
+ mips-idt-ecoff mips64-elf mips-elf \
+ sh-hms \
+ sparc-aout sparc64-aout sparc-vxworks \
+ sparclite-aout sparclite-coff sparclite-vxworks \
+ z8k-coff \
+ OSE68000 OSE68k mips-ncd-elf i386-unixware
+# The OSE68000 and OSE68k targets are for Ericsson 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
-GCC = gcc -O -msoft-float
+TARGETS = $(NATIVE)
+GCC = gcc -O2 -msoft-float
CC = cc -J
all: all-cygnus
endif
ifeq ($(canonhost),sparc-sun-solaris2)
TARGETS = $(NATIVE) \
a29k-amd-udi \
- i386-aout \
- i960-vxworks i960-intel-nindy \
- m68k-aout m68k-coff m68k-vxworks \
- mips-idt-ecoff \
- sparc-aout sparc-vxworks sparclite-aout
-CC = cc -Xs
-GCC = gcc -O -pipe
+ h8300-hms h8500-hms \
+ hppa1.1-hp-proelf \
+ i960-vxworks5.0 i960-vxworks5.1 \
+ m68k-aout m68k-coff m68k-vxworks5.1 m88k-coff \
+ mips-idt-ecoff mips-elf \
+ sparc64-elf sparclite-aout sparclite-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
+GCC = gcc -O2 -pipe
all: all-cygnus
endif
ifeq ($(canonhost),mips-dec-ultrix)
-TARGETS = $(NATIVE) m68k-aout
+TARGETS = $(NATIVE)
CC = cc -Wf,-XNg1000
all: all-cygnus
+SHELL = /usr/unsupported/bin/bash
+CONFIG_SHELL = /usr/unsupported/bin/bash
+TMPDIR = $(shell mkdir $(canonhost)-tmpdir; cd $(canonhost)-tmpdir ; pwd)
+endif
+
+ifeq ($(patsubst alpha-dec-osf%,alpha,$(canonhost)),alpha)
+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 \
+ mips-elf mips64-elf \
+ sh-hms
+CC = cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh2000
+all: all-cygnus
+endif
+
+ifeq ($(canonhost),mips-sgi-irix5)
+TARGETS = $(NATIVE) \
+ mips-idt-ecoff \
+ mips-elf mips64-elf \
+ sh-hms
+CC = cc -cckr -Wf,-XNg1500 -Wf,-XNk1000 -Wf,-XNh2000
+all: all-cygnus
+endif
+
+ifeq ($(canonhost),powerpc-ibm-aix4.1)
+TARGETS = $(NATIVE)
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),rs6000-ibm-aix3.2.5)
+TARGETS = $(NATIVE) \
+ i960-vxworks5.0 i960-vxworks5.1 \
+ m68k-aout
all: all-cygnus
endif
-ifeq ($(canonhost),m68k-hp-hpux)
-TARGETS = $(NATIVE) m68k-aout
+ifeq ($(canonhost),rs6000-ibm-aix4.1)
+TARGETS = $(NATIVE)
+all: all-cygnus
+endif
+
+ifeq ($(canonhost),m68k-hp-hpux9)
+TARGETS = $(NATIVE)
TMPDIR := $(shell mkdir $(canonhost)-tmpdir; cd $(canonhost)-tmpdir ; pwd)
-CC = cc -Wp,-P
+CC = cc -Wp,-P,-H256000
#CFLAGS = +O1000
CFLAGS = -g
all: all-cygnus
endif
-ifeq ($(canonhost),hppa1.1-hp-hpux)
+ifeq ($(canonhost),hppa1.1-hp-hpux9)
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) \
+ h8300-hms \
+ hppa1.1-hp-proelf \
+ i960-vxworks5.0 i960-vxworks5.1 \
+ m68k-aout m68k-coff m68k-vxworks5.1
+CC = cc -Wp,-H256000
#CFLAGS = +Obb2000
CFLAGS = -g
-all: all-native
+all: all-cygnus
+endif
+
+#ifeq ($(canonhost),hppa1.1-hp-hpux10)
+ifeq ($(patsubst hppa1.1-hp-hpux10%,hpux10,$(canonhost)),hpux10)
+TARGETS = $(NATIVE)
+CC = cc -Wp,-H256000
+#CFLAGS = +Obb2000
+CFLAGS = -g
+all: all-cygnus
endif
ifeq ($(canonhost),i386-sco3.2v4)
-TARGETS = $(NATIVE) i386-aout
+TARGETS = $(NATIVE)
all: all-cygnus
endif
ifeq ($(canonhost),i386-go32)
TARGETS = \
a29k-amd-udi \
- h8300-hms h8500-hms \
- i386-aout \
+ h8300-hms hppa1.1-hp-proelf \
+ i386-aout \
m68k-aout m68k-coff \
- mips-idt-ecoff \
- sh-hms \
- sparclite-aout
+ mips-elf mips-idt-ecoff mips64-elf \
+ sh-hms \
+ sparc-aout sparclite-aout sparclite-coff
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-ncr-sysv4.3)
TARGETS = $(NATIVE)
-CC = /bin/gcc
+CC = cc -Hnocopyr
+SHELL = /usr/unsupported/bin/bash
+CONFIG_SHELL = /usr/unsupported/bin/bash
all: all-cygnus
endif
-ifeq ($(canonhost),m68k-lynxos)
+ifeq ($(canonhost),i386-lynx)
TARGETS = $(NATIVE)
-CC = /bin/gcc
+CC = /usr/cygnus/progressive/bin/gcc
all: all-cygnus
+SHELL=/bin/bash
endif
+ifeq ($(canonhost),m68k-lynx)
+TARGETS = $(NATIVE)
+CC = /usr/cygnus/progressive/bin/gcc
+all: all-cygnus
+SHELL=/bin/bash
+endif
+
+ifeq ($(canonhost),sparc-lynx)
+TARGETS = $(NATIVE)
+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
+
+ifeq ($(patsubst %-linux,linux,$(patsubst %-linuxaout,linux,$(canonhost))),linux)
+TARGETS = $(NATIVE)
+all: all-cygnus
+endif
FLAGS_TO_PASS := \
"GCC=$(GCC)" \
"CC=$(CC)" \
"CFLAGS=$(CFLAGS)" \
+ "GNUCFLAGS=$(GNUCFLAGS)" \
"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
+
+ifeq ($(patsubst %-linux,linux,$(patsubst %-linuxaout,linux,$(canonhost))),linux)
+FLAGS_TO_PASS := $(FLAGS_TO_PASS) "GNU_MAKE=$(MAKE)"
+endif
+
+ifeq ($(patsubst %i386-ncr-sysv4.3,ncr,$(canonhost)),ncr)
+FLAGS_TO_PASS := $(FLAGS_TO_PASS) "CONFIG_SHELL=/usr/unsupported/bin/bash"
+endif
all-emacs:
@echo build started at `date`
- [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
+ test -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)
+ test -d $(INSTALLDIR) || mkdir $(INSTALLDIR)
+ -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" ; \
- $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log) && \
- echo " completed successfully" ; \
+ echo Flags passed to make: $(FLAGS_TO_PASS) ; \
+ if $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) $(canonhost)-stamp-3stage-done $(log); then \
+ echo " completed successfully" ; \
+ else \
+ exit 1; \
+ fi; \
else \
true ; \
- fi \
+ fi ; \
else \
echo "building $(canonhost) cross to $$i" ; \
$(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)
+ test -d $(INSTALLDIR) || mkdir $(INSTALLDIR)
+ -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`
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 $(cyglog) && \
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
+ @echo done at `date`
+
all-native:
- [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
+ test -d $(INSTALLDIR) || mkdir $(INSTALLDIR)
rm -f $(ROOTING)/$(RELEASE_TAG)
ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG)
@for i in $(TARGETS) ; do \
done
all-cross:
- [ -d $(INSTALLDIR) ] || mkdir $(INSTALLDIR)
+ test -d $(INSTALLDIR) || mkdir $(INSTALLDIR)
rm -f $(ROOTING)/$(RELEASE_TAG)
ln -s $(INSTALLDIR) $(ROOTING)/$(RELEASE_TAG)
@for i in $(TARGETS) ; do \
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 \
echo " completed successfully" ; \
else \
echo "building $(canonhost) cross to $$i" ; \
- $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-native $(cyglog) && \
+ $(MAKE) -f test-build.mk $(FLAGS_TO_PASS) target=$$i build-native $(natlog) && \
echo " completed successfully" ; \
fi ; \
done
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: