Initial revision
authorK. Richard Pixley <rich@cygnus>
Thu, 4 Apr 1991 19:01:18 +0000 (19:01 +0000)
committerK. Richard Pixley <rich@cygnus>
Thu, 4 Apr 1991 19:01:18 +0000 (19:01 +0000)
Makefile.in [new file with mode: 0644]
config/mt-a29k [new file with mode: 0644]
configure [new file with mode: 0755]
configure.in [new file with mode: 0644]
ld/Makefile.in [new file with mode: 0644]
ld/configure [new file with mode: 0755]

diff --git a/Makefile.in b/Makefile.in
new file mode 100644 (file)
index 0000000..29e2490
--- /dev/null
@@ -0,0 +1,120 @@
+#
+# Makefile for development tools.
+#
+# Last Mod Tue Apr 2 16:57:52 PST 1991, by rich@sendai
+#
+
+srcdir = .
+subdir = Host-$(host)/Target-$(target)
+
+OSLAYER = clib/os-layer
+OSINCLUDE = $(OSLAYER)/include
+
+#CC = gcc -b$(target) # -B$(srcdir)/../gas/Host-$(host)/Target-$(target)/
+#CFLAGS = -g -nostdinc -nostdlib -I- -I$(srcdir) -I$(srcdir)/../include -I$(OSINCLUDE)
+
+# These are roughly topologically sorted in order to make porting more
+# streamlined.
+
+SUBDIRS =
+NONSUBDIRS =
+SUBDIRS_INCLUDE = machine-dep
+
+TARGETLIB = libc.a
+RANLIB = ranlib
+AR = ar cqv
+
+#### host and target specific makefile fragments come in here.
+
+all: $(TARGETLIB)
+
+subdir_do: $(SUBDIRS) $(TARGETDIRS)
+       for i in $(SUBDIRS); \
+         do \
+           if (cd $(srcdir)/$$i`if [ -d $(srcdir)/$$i.$(target) ] ; \
+               then echo .$(target) ; fi`/$(subdir); \
+               $(MAKE)  \
+                   "OSLAYER=../$(OSLAYER)" \
+                   "TARGETLIB=../$(srcdir)/$(subdir)/$(TARGETLIB)" \
+                   "AR=$(AR)" \
+                   "RANLIB=$(RANLIB)" $(DO)) ; \
+           then true ; \
+           else exit 1 ; \
+           fi ;\
+         done
+
+$(TARGETLIB): FORCE
+       @$(MAKE) subdir_do "DO=all"
+       $(RANLIB) $(TARGETLIB)
+
+oldlibc.a: $(SUBDIRS) FORCE
+       @$(MAKE) subdir_do DO=all
+       rm -rf TEMP
+       mkdir TEMP
+# Extract files from all subdirs, making sure that none overwrites others.
+       cd TEMP; for i in $(SUBDIRS); do\
+          ar x ../$$i/library.a;\
+          chmod a-w *;\
+       done;
+# Be sure if interrupted, no libc.a exists.
+       rm -f libc.new
+       cd TEMP; ar cq ../libc.new *
+       ranlib libc.new
+       mv libc.new libc.a
+       rm -rf TEMP
+
+clean:
+       rm -rf *.a TEMP errs core *.o *~ \#* TAGS *.E
+       $(MAKE) subdir_do DO=clean
+
+install: all install_include install_crt install_gnulib install_lib
+
+# When installing include files, be sure that machine-dependent
+# files override machine-independent files.
+# Might be better to check for collisions?  FIXME
+install_crt:
+       $(MAKE) SUBDIRS=machine-dep DO=install_crt
+
+install_gnulib:
+       $(MAKE) SUBDIRS=gnulib DO=install_gnulib
+
+install_include:
+       $(MAKE) SUBDIRS=$(SUBDIRS_INCLUDE) DO=install_include
+
+install_lib: libc.a
+       cp libc.a $(DESTDIR)/lib/libc.a
+
+etags tags: TAGS
+
+TAGS: FORCE
+       etags `$(MAKE) ls`
+
+ls:
+       @echo Makefile
+       @for i in $(SUBDIRS); \
+       do \
+               (cd $$i; \
+                       pwd=`pwd`; \
+                       wd=`basename $$pwd`; \
+                       for j in `$(MAKE) ls`; \
+                       do \
+                               echo $$wd/$$j; \
+                       done) \
+       done
+
+FORCE:
+
+# with the gnu make, this is done automatically.
+
+Makefile: $(srcdir)/Makefile.in $(srcdir)/configure
+       (cd $(srcdir) ; configure -srcdir=$(srcdir) -host=$(host) $(target) -norecurse)
+
+#
+# $Log$
+# Revision 1.1  1991/04/04 18:56:39  rich
+# Initial revision
+#
+#
+#
+
+# end of Makefile.in
diff --git a/config/mt-a29k b/config/mt-a29k
new file mode 100644 (file)
index 0000000..9a6ed1d
--- /dev/null
@@ -0,0 +1,4 @@
+BINUTILSDIR=/u1/rich/work/binutils.$(target)/Host-$(host)/Target-$(target)
+AR=$(BINUTILSDIR)/ar cqv
+RANLIB=$(BINUTILSDIR)/ranlib
+OSLAYER = clib/os-layer.$(target)
diff --git a/configure b/configure
new file mode 100755 (executable)
index 0000000..f5a812d
--- /dev/null
+++ b/configure
@@ -0,0 +1,853 @@
+#!/bin/sh
+# Do not edit this file.  It is generated automatically from configure.in
+# and a configure template.
+configdirs=
+
+#!/bin/sh
+# Do not edit this file.  It is generated automatically from configure.in
+# and a configure template.
+configdirs=
+
+# Configuration script template
+#   Copyright (C) 1988, 1990, 1991 Free Software Foundation, Inc.
+
+#This file is part of GNU.
+
+#GNU CC is free software; you can redistribute it and/or modify
+#it under the terms of the GNU General Public License as published by
+#the Free Software Foundation; either version 1, or (at your option)
+#any later version.
+
+#GNU CC is distributed in the hope that it will be useful,
+#but WITHOUT ANY WARRANTY; without even the implied warranty of
+#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#GNU General Public License for more details.
+
+#You should have received a copy of the GNU General Public License
+#along with GNU CC; see the file COPYING.  If not, write to
+#the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+
+#
+# Shell script to create proper links to machine-dependent files in
+# preparation for compiling gcc.
+#
+# Usage: configure [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET
+#
+# If configure succeeds, it leaves its status in config.status.
+# If configure fails after disturbing the status quo, 
+#      config.status is removed.
+#
+
+progname=$0
+
+remove=rm
+hard_link=ln
+symbolic_link='ln -s'
+
+#for Test
+#remove="echo rm"
+#hard_link="echo ln"
+#symbolic_link="echo ln -s"
+
+# clear some things potentially inherited from environment.
+target=
+template=
+removing=
+norecurse=
+ansi=
+
+for arg in $*;
+do
+       case $arg in
+       -ansi | +ansi)
+               ansi=true
+               ;;
+       -template=* | +template=*)
+               template=`echo $arg | sed 's/[+-]template=//'`
+               ;;
+       -norecurse | +norecurse)
+               norecurse=true
+               ;;
+       -rm | +rm)
+               removing=$arg
+               ;;
+       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
+               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+               ;;
+       -host=* | +host=* | +hos=* | +ho=* | +h=*)
+               host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
+               ;; 
+       -languages=* | +languages=* | -languag=* | +languag=* | langua=* \
+               | +langua=* | -langu=* | +langu=* | -lang=* | +lang=* | -lan=* \
+               | +lan=* | -la=* | +la=* | -l=* | +l=*)
+               languages="$languages `echo $arg | sed 's/[+-]l[a-z]*=//'`"
+               ;;
+       -gas | +gas | +ga | +g)
+               gas=yes
+               ;;
+       -nfp | +nfp | +nf | +n)
+               nfp=yes
+               ;;
+       *)
+# Allow configure HOST TARGET
+               if [ x$host = x ] ; then host=$target ; fi
+               target=$arg
+               ;;
+       esac
+done
+
+# process host and target only if not rebuilding configure itself.
+if [ -z "$template" ]
+then
+       # Complain if an arg is missing
+       if [ x$target = x ]
+       then
+               echo "Usage: $progname [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET"
+               echo -n "Where HOST and TARGET are something like "
+               echo "\`vax', \`sun3', \`encore', etc."
+               if [ -r config.status ]
+               then
+                       cat config.status
+               fi
+               exit 1
+       fi
+
+       # Default other arg
+       if [ x$host = x ]
+       then
+               host=$target
+       fi
+
+       # Decode the host machine, then the target machine.
+       # For the host machine, we save the xm_file variable as host_xm_file;
+       # then we decode the target machine and forget everything else
+       # that came from the host machine.
+       for machine in $host $target; do
+
+               # Separate what the user gave into CPU/company and OS (if any).
+               basic_machine=`echo $machine | sed 's/-[^-]*$//'`
+               if [ $basic_machine != $machine ]
+               then os=`echo $machine | sed 's/[^-]*-/-/'`
+               else os=; fi
+
+               # Decode aliases for certain machine/company combinations.
+               case $basic_machine in
+                       iris | iris4d)
+                               basic_machine=mips/sgi
+                               ;;
+                       news | news800)
+                               basic_machine=m68k/sony
+                               ;;
+                       3b1 | 7300 | 7300/att | att-7300)
+                               basic_machine=m68k/att
+                               ;;
+                       delta | 3300 | motorola-3300 | motorola-delta \
+                             | 3300/motorola | delta/motorola)
+                               basic_machine=m68k/motorola
+                               ;;
+                       vax/dec)
+                               basic_machine=vax
+                               ;;
+                       balance)
+                               basic_machine=ns32k/sequent
+                               ;;
+                       symmetry)
+                               basic_machine=i386/sequent
+                               ;;
+                       sun2)
+                               basic_machine=m68000/sun
+                               ;;
+                       sun3)
+                               basic_machine=m68k/sun
+                               ;;
+                       sun4)
+                               basic_machine=sparc/sun
+                               ;;
+                       sun386 | sun386i)
+                               basic_machine=i386/sun
+                               ;;
+                       ps2)
+                               basic_machine=i386/ibm
+                               ;;
+                       next)
+                               basic_machine=m68k/next
+                               ;;
+                       hp9k3[2-9][0-9])
+                               basic_machine=m68k/hp
+                               ;;
+                       hp9k31[0-9] | hp9k2[0-9][0-9])
+                               basic_machine=m68000/hp
+                               ;;
+                       isi68)
+                               basic_machine=m68k/isi
+                               ;;
+                       apollo68)
+                               basic_machine=m68k/apollo
+                               ;;
+                       altos | altos3068)
+                               basic_machine=m68k/altos
+                               ;;
+                       miniframe)
+                               basic_machine=m68000/convergent
+                               ;;
+                       tower | tower-32)
+                               basic_machine=m68k/ncr
+                               ;;
+                       news-3600 | risc-news)
+                               basic_machine=mips/sony
+                               ;;
+                       decstation | decstation-3100 | pmax)
+                               basic_machine=mips/dec
+                               ;;
+                       gmicro)
+                               basic_machine=tron
+                               ;;
+                       convex-c1)
+                               basic_machine=c1/convex
+                               ;;
+                       convex-c2)
+                               basic_machine=c2/convex
+                               ;;
+               esac
+
+               # Decode manufacturer-specific aliases for certain operating systems.
+
+               case $os in
+                       -newsos*)
+                               os=-bsd
+                               ;;
+                       -ultrix*)
+                               os=-bsd
+                               ;;
+                       -dynix*)
+                               os=-bsd
+                               ;;
+                       -ctix*)
+                               os=-sysv
+                               ;;
+               esac
+
+               machine=$basic_machine$os
+
+               cpu_type=
+               xm_file=
+               tm_file=
+               make_var_file=
+
+               case $machine in
+               vax | vax-bsd*)                 # vaxen running BSD
+                       ;;
+               vax-vms | vms)                  # vaxen running VMS
+                       cpu_type=vax
+                       xm_file=xm-vms.h
+                       tm_file=tm-vms.h
+                       ;;
+               vax-sysv* | vaxv)               # vaxen running system V
+                       cpu_type=vax
+                       xm_file=xm-vaxv.h
+                       tm_file=tm-vaxv.h
+                       ;;
+               tahoe | tahoe-bsd*)             # tahoe running BSD
+                       ;;
+               tahoe/harris*)                  # Harris tahoe, using COFF.
+                       cpu_type=tahoe
+                       ;;
+               i386/sequent* | i386/sequent-bsd*)  # 80386 from Sequent
+                       cpu_type=i386
+                       xm_file=xm-i386.h
+                       tm_file=tm-seq386.h
+                       ;;
+               i386-mach | i386/*-mach)
+                       cpu_type=i386
+                       xm_file=xm-i386.h
+                       tm_file=tm-i386gas.h
+                       ;;
+               i386/sco | i386/sco-sysv* | i386/*-sco) # 80386 running SCO system
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       tm_file=tm-i386sco.h
+                       make_var_file=make-i386sco
+                       ;;
+               i386/isc | i386/isc-sysv* | i386/*-isc) # 80386 running ISC system
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       tm_file=tm-i386isc.h
+                       make_var_file=make-i386isc
+                       ;;
+               i386/ibm | i386-aix | i386/ibm-aix)     # IBM PS/2 running AIX
+                       cpu_type=i386
+                       tm_file=tm-i386v.h
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       ;;
+               i386/sun*)
+                       cpu_type=i386
+                       xm_file=xm-sun386i.h
+                       tm_file=tm-sun386i.h
+                       ;;
+               i386-sysv4 | i386/*-sysv4 | i386v4)  # Intel 80386's running system V.4
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       tm_file=tm-i386v4.h
+                       ;;
+               i386-sysv* | i386/*-sysv* | i386v)  # Intel 80386's running system V
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i386gas.h
+                       else
+                               tm_file=tm-i386v.h
+                       fi
+                       ;;
+               i860 | i860-sysv* | i860/*-sysv*)
+                       cpu_type=i860
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i860g.h
+                       else
+                               tm_file=tm-i860.h
+                       fi
+                       ;;
+               i860-bsd* | i860/*-bsd*)
+                       cpu_type=i860
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i860bsdg.h
+                       else
+                               tm_file=tm-i860bsd.h
+                       fi
+                       ;;
+               sparc | sparc/* | sparc-*os4 | sparc/*-*os4)
+                       cpu_type=sparc
+                       tm_file=tm-sparc.h
+                       ;;
+               sparc-*os3 | sparc/*-*os3)
+                       cpu_type=sparc
+                       tm_file=tm-sun4os3.h
+                       ;;
+               m68k/next)
+                       cpu_type=m68k
+                       tm_file=tm-next.h
+                       out_file=out-next.c
+                       xm_file=xm-next.h
+                       ;;
+               m68k/sun-*os3)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-sun3os3nf.h
+                       else
+                               tm_file=tm-sun3os3.h
+                       fi
+                       ;;
+               m68k/sun-mach)
+                       cpu_type=m68k
+                       tm_file=tm-sun3mach.h
+                       ;;
+               m68k/sun | m68k/sun-*os4)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-sun3nfp.h
+                       else
+                               tm_file=tm-sun3.h
+                       fi
+                       ;;
+               m68k/hp | m68k/hp-hpux*)        # HP 9000 series 300
+                       cpu_type=m68k
+                       xm_file=xm-hp9k320.h
+                       if [ x$gas = xyes ]
+                       then
+                               make_var_file=make-hp9k320g
+                               tm_file=tm-hp9k320g.h
+                       else
+                               make_var_file=make-hp9k320
+                               tm_file=tm-hp9k320.h
+                       fi
+                       ;;
+               m68k/hp-bsd*)                   # HP 9000/3xx running Berkeley Unix
+                       cpu_type=m68k
+                       tm_file=tm-hp9k3bsd.h
+                       ;;
+               m68k/isi | m68k/isi-bsd*)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-isi68-nfp.h
+                       else
+                               tm_file=tm-isi68.h
+                       fi
+                       ;;
+               m68k/sony | m68k/sony-bsd*)
+                       xm_file=xm-m68k.h
+                       cpu_type=m68k
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-newsgas.h
+                       else
+                               tm_file=tm-news.h
+                       fi
+                       ;;
+               m68k/altos | m68k/altos-sysv*)             # Altos 3068
+                       cpu_type=m68k
+                       if [ x$gas = xyes ]
+                       then
+                               xm_file=xm-altos3068.h
+                               tm_file=tm-altos3068.h
+                       else
+                               echo "The Altos is supported only with the GNU assembler" 1>&2
+                               exit 1
+                       fi
+                       ;;
+               m68k/motorola | m68k/motorola-sysv*)
+                       cpu_type=m68k
+                       tm_file=tm-mot3300.h
+                       xm_file=xm-mot3300.h
+                       ;;
+               m68k/crds | m68k/crds-unos | m68k-unos | crds | unos)
+                       cpu_type=m68k
+                       xm_file=xm-crds.h
+                       make_var_file=make-crds
+                       tm_file=tm-crds.h
+                       ;;
+               m68k/apollo)
+                       cpu_type=m68k
+                       make_var_file=make-apollo68
+                       tm_file=tm-apollo68.h
+                       ;;
+               m68k/ncr | m68k/ncr-sysv*)      # NCR Tower 32 SVR3
+                       cpu_type=m68k
+                       tm_file=tm-tower-as.h
+                       xm_file=xm-tower.h
+                       ;;
+               m68000/sun | m68000/sun-*os3)
+                       cpu_type=m68k
+                       tm_file=tm-sun2.h
+                       ;;
+               m68000/sun-*os4)
+                       cpu_type=m68k
+                       tm_file=tm-sun2os4.h
+                       ;;
+               m68000/hp | m68000/hp-hpux*)    # HP 9000 series 300
+                       cpu_type=m68k
+                       xm_file=xm-hp9k310.h
+                       if [ x$gas = xyes ]
+                       then
+                               make_var_file=make-hp9k320g
+                               tm_file=tm-hp9k310g.h
+                       else
+                               make_var_file=make-hp9k320
+                               tm_file=tm-hp9k310.h
+                       fi
+                       ;;
+               m68000/hp-bsd*)                 # HP 9000/200 running BSD
+                       cpu_type=m68k
+                       tm_file=tm-hp9k2bsd.h
+                       make_var_file=make-hp9k2bsd
+                       ;;
+               m68000/att | m68000/att-sysv*)
+                       cpu_type=m68k
+                       xm_file=xm-3b1.h
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-3b1g.h
+                       else
+                               tm_file=tm-3b1.h
+                       fi
+                       ;;
+               m68000/convergent | m68000/convergent-sysv*)
+                       cpu_type=m68k
+                       xm_file=xm-3b1.h
+                       tm_file=tm-ctix.h
+                       ;;
+               ns32k/sequent | ns32k/sequent-bsd*)
+                       cpu_type=ns32k
+                       tm_file=tm-sequent.h
+                       ;;
+               ns32k/encore | ns32k/encore-bsd* | encore | encore-bsd*)
+                       cpu_type=ns32k
+                       tm_file=tm-encore.h
+                       ;;
+               ns32k-genix* | ns32k/*-genix* | genix)
+                       cpu_type=ns32k
+                       xm_file=xm-genix.h
+                       make_var_file=make-genix
+                       tm_file=tm-genix.h
+                       ;;
+               merlin)
+                       cpu_type=ns32k
+                       ;;
+               m88k/dg | m88k/dg-dgux* | m88k-dgux*)
+                       cpu_type=m88k
+                       xm_file=xm-m88kdgux.h
+                       make_var_file=make-m88kdgux
+                       tm_file=tm-m88kdgux.h
+                       ;;
+               m88k-v88r32 | m88k/*-v88r32)
+                       cpu_type=m88k
+                       tm_file=tm-v88r32.h
+                       xm_file=xm-v88r32.h
+                       ;;
+               m88k-sysv* | m88k/*-sysv*)
+                       cpu_type=m88k
+                       tm_file=tm-m88ksvr4.h
+                       xm_file=xm-m88ksvr4.h
+                       ;;
+               alliant | alliant/alliant)      # Alliant FX/8
+                       cpu_type=alliant
+                       tm_file=tm-alliant.h
+                       ;;
+               c1/convex)                      # Convex C1
+                       if [ -r /usr/include/stdlib.h ]
+                       then
+                               tm_file=tm-convex1.h
+                       else
+                               tm_file=tm-conv1os7.h
+                       fi
+                       cpu_type=convex
+                       ;;
+               c2/convex)                      # Convex C2
+                       if [ -r /usr/include/stdlib.h ]
+                       then
+                               tm_file=tm-convex2.h
+                       else
+                               tm_file=tm-conv2os7.h
+                       fi
+                       cpu_type=convex
+                       ;;
+               mips/sgi | mips/sgi-sysv*)      # Mostly like a MIPS.
+                       cpu_type=mips
+                       tm_file=tm-iris.h
+                       xm_file=xm-iris.h
+                       ;;
+               mips | mips/mips)               # Default MIPS environment.
+                       ;;
+               mips/dec | mips/dec-bsd*)       # Decstation.
+                       cpu_type=mips
+                       tm_file=tm-decstatn.h
+                       ;;
+               mips/sony | mips/sony-bsd*)     # Sony NEWS 3600 or risc/news.
+                       cpu_type=mips
+                       tm_file=tm-mips-news.h
+                       ;;
+               mips/*-sysv* | mips-sysv*)      # SYSV variant of MIPS system.
+                       cpu_type=mips
+                       tm_file=tm-mips-sysv.h
+                       ;;
+               mips/*-bsd* | mips-bsd*)        # BSD 4.3 variant of MIPS system.
+                       cpu_type=mips
+                       tm_file=tm-mips-bsd.h
+                       ;;
+               pyramid | pyramid/* | pyramid-*)
+                       cpu_type=pyr
+                       tm_file=tm-pyr.h
+                       ;;
+               tron | tron/*)
+                       cpu_type=gmicro
+                       tm_file=tm_gmicro.h
+                       ;;
+               a29k-bsd* | a29k/*-bsd*)
+                       cpu_type=a29k
+                       tm_file=tm-a29kunix.h
+                       ;;
+               i960)                           # Default i960 environment.
+                       ;;
+       #       370)
+       #               ;;
+               esac
+               if [ x$pass1done = x ]
+               then
+                       if [ x$cpu_type = x ]; then cpu_type=$host; fi
+                       if [ x$xm_file = x ]; then host_xm_file=xm-$cpu_type.h
+                       else host_xm_file=$xm_file
+                       fi
+                       if [ x$make_var_file = x ]
+                       then make_var_file=make-$cpu_type; fi
+                       host_make_var_file=$make_var_file
+                       pass1done=yes
+               fi
+       done
+
+       # Default the machine-specific variables that were not explicitly set.
+       if [ x$cpu_type = x ]
+       then cpu_type=$target; fi
+
+       if [ x$tm_file = x ]
+       then tm_file=tm-$target.h; fi
+
+       md_file=${cpu_type}.md
+
+       if [ x$out_file = x ]
+       then out_file=out-$cpu_type.c; fi
+fi
+
+#### configure.in files go here.
+# This file is a shell script fragment that supplies the information
+# necessary to tailor a template configure script into the configure
+# script appropriate for this directory.  For more information, check
+# any existing configure script.
+
+configdirs="gcc gas bfd binutils ld clib"
+srctrigger=gcc-new
+srcname="gnu development package"
+### end of configure.in
+
+# are we rebuilding config itself?
+if [ -n "$template" ]
+then
+       if [ ! -r $template ]
+       then
+               echo "Can't find template ${template}."
+               exit 1
+       fi
+
+       mv configure configure.old
+       echo "#!/bin/sh" > configure
+       echo "# Do not edit this file.  It is generated automatically from configure.in" >> configure
+       echo "# and a configure template." >> configure
+       echo "configdirs=" >> configure
+       echo >> configure
+
+       if [ -r configure.in ]
+       then
+               sed -e "/^####/  r configure.in" $template >> configure
+       else
+               cat $template >> configure
+       fi
+
+       chmod a+x configure
+       rm configure.old
+#      echo Rebuilt configure in `pwd` from ${template}.
+       echo Rebuilt configure in `pwd`
+
+       if [ x$norecurse = x ]
+       then
+               while [ -n "$configdirs" ]
+               do
+                       # set configdir to car of configdirs, configdirs to cdr of configdirs
+                       set $configdirs; configdir=$1; shift; configdirs=$*
+
+                       if [ "`echo ${configdir}.*`" != "${configdir}.*" ]
+                       then
+                               targetspecificdirs=${configdir}.*
+                       else
+                               targetspecificdirs=
+                       fi
+
+                       for i in ${configdir} ${targetspecificdirs}
+                       do
+                               if [ -r $i/configure ]
+                               then
+                                       (cd $i ;
+                                               configure +template=${template})
+                               else
+                                       echo No configure script in `pwd`/$i
+                               fi
+                       done
+               done
+       fi
+
+       exit 0
+fi
+
+# Temporarily, we support only direct subdir builds.
+hostsubdir=Host-$host
+targetsubdir=Target-$target
+
+if [ -n "$removing" ]
+then
+       rm -rf $hostsubdir/$targetsubdir
+
+       if [ -z "`(ls $hostsubdir) 2>&1 | grep Target-`" ]
+       then
+               rm -rf $hostsubdir
+       fi
+else
+       if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
+       cd $hostsubdir
+
+       if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
+       cd $targetsubdir
+
+       srcdir=../..
+
+       ## Find the source files, if location was not specified.
+       #if [ x$srcdir = x ]
+       #then
+       #       srcdirdefaulted=1
+       #       srcdir=.
+       #       if [ ! -r ${srctrigger} ]
+       #       then
+       #               srcdir=..
+       #       fi
+       #fi
+       #
+       #if [ ! -r ${srcdir}/${srctrigger} ]
+       #then
+       #       if [ x$srcdirdefaulted = x ]
+       #       then
+       #         echo "$progname: Can't find ${srcname} sources in \`${srcdir}'." 1>&2
+       #       else
+       #         echo "$progname: Can't find ${srcname} sources in \`.' or \`..'." 1>&2
+       #       fi
+       #       exit 1
+       #fi
+
+
+
+       # Set up the list of links to be made.
+       # $links is the list of link names, and $files is the list of names to link to.
+
+       # Make the links.
+       while [ -n "$files" ]
+       do
+               # set file to car of files, files to cdr of files
+               set $files; file=$1; shift; files=$*
+               set $links; link=$1; shift; links=$*
+
+               if [ ! -r ${srcdir}/config/$file ]
+               then
+                       echo "$progname: cannot create a link \`$link'," 1>&2
+                       echo "since the file \`config/$file' does not exist." 1>&2
+                       exit 1
+               fi
+
+               $remove -f $link
+               rm -f config.status
+               # Make a symlink if possible, otherwise try a hard link
+               $symbolic_link ${srcdir}/config/$file $link 2>/dev/null || $hard_link ${srcdir}/config/$file $link
+
+               if [ ! -r $link ]
+               then
+                       echo "$progname: unable to link \`$link' to \`${srcdir}/config/$file'." 1>&2
+                       exit 1
+               fi
+               echo "Linked \`$link' to \`${srcdir}/config/$file'."
+       done
+
+       # Install a makefile, and make it set VPATH
+       # if necessary so that the sources are found.
+       # Also change its value of srcdir.
+       # Also create a .gdbinit file which runs the one in srcdir
+       # and tells GDB to look there for source files.
+       case $srcdir in
+       .)
+               ;;
+       *)
+               echo "VPATH = ${srcdir}" > x
+               cat x ${srcdir}/Makefile.in | sed "s@^srcdir = \.@srcdir = ${srcdir}@" > Makefile.in
+               rm x
+               echo "dir ." > .gdbinit
+               echo "dir ${srcdir}" >> .gdbinit
+               echo "source ${srcdir}/.gdbinit" >> .gdbinit
+               ;;
+       esac
+
+       host_var_file=hmake-${host}
+       target_var_file=tmake-${target}
+
+       # Conditionalize the makefile for this machine.
+       if [ -f ${srcdir}/config/${host_var_file} ]
+       then
+               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile.in > Makefile.tem
+       else
+               cp Makefile.in Makefile.tem
+       fi
+
+       if [ -f ${srcdir}/config/${target_var_file} ]
+       then
+               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile.tem > Makefile.tem1
+               mv Makefile.tem1 Makefile.tem
+       fi
+
+       # Remove all formfeeds, since some Makes get confused by them.
+       sed "s/\f//" Makefile.tem >> Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # reset SUBDIRS
+       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile.tem > Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # reset NONSUBDIRS
+       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile.tem > Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # Delete the intermediate files
+       if [ x$srcdir != x. ] ; then rm Makefile.in ; fi
+
+       rm -f Makefile
+
+       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
+       if [ x$host != x$target ]
+       then
+               echo "CROSS=-DCROSS_COMPILE" > Makefile
+               echo "ALL=start.encap" >> Makefile
+       else
+               echo "ALL=all.internal" > Makefile
+       fi
+
+       # set target and host
+       echo "host = $host" >> Makefile
+       echo "target = $target" >> Makefile
+
+       cat Makefile.tem >> Makefile
+       rm Makefile.tem
+
+       using=
+       if [ -f ${srcdir}/config/${host_var_file} ]
+       then
+               using=" using \"${host_var_file}\""
+       fi
+
+       if [ -f ${srcdir}/config/${target_var_file} ]
+       then
+               if [ -z "${using}" ]
+               then
+                       andusing=" using \"${target_var_file}\""
+               else
+                       andusing="${using} and \"${target_var_file}\""
+               fi
+       else
+               andusing=${using}
+       fi
+
+       echo "Created \"Makefile\""${andusing}.
+
+       if [ x$host = x$target ]
+       then
+               echo "Links are now set up for use with a $target." \
+                       | tee ${srcdir}/config.status
+       else
+               echo "Links are now set up for host $host and target $target." \
+                       | tee ${srcdir}/config.status
+       fi
+
+       cd ${srcdir}
+fi
+
+# If there are subdirectories, then recurse. 
+
+if [ x$norecurse != x ] ; then exit 0 ; fi
+
+while [ -n "$configdirs" ]
+do
+       # set configdir to car of configdirs, configdirs to cdr of configdirs
+       set $configdirs; configdir=$1; shift; configdirs=$*
+
+       # check for target override
+       targetspecificdir=${configdir}.${target}
+       if [ -d ${targetspecificdir} ]
+       then
+               configdir=${targetspecificdir}
+       fi
+
+       echo Configuring ${configdir}...
+       (cd ${configdir} ;
+               configure +host=${host} ${target} ${removing}) \
+               | sed 's/^/     /'
+done
+
+exit 0
diff --git a/configure.in b/configure.in
new file mode 100644 (file)
index 0000000..e6df4e4
--- /dev/null
@@ -0,0 +1,8 @@
+# This file is a shell script fragment that supplies the information
+# necessary to tailor a template configure script into the configure
+# script appropriate for this directory.  For more information, check
+# any existing configure script.
+
+configdirs="gcc gas bfd binutils ld clib"
+srctrigger=gcc-new
+srcname="gnu development package"
diff --git a/ld/Makefile.in b/ld/Makefile.in
new file mode 100644 (file)
index 0000000..ca22ac3
--- /dev/null
@@ -0,0 +1,183 @@
+#
+# Makefile for ld version 2
+#
+# $Id$
+#
+
+srcdir = .
+
+BASEDIR = $(srcdir)/..
+BFDDIR = $(BASEDIR)/bfd
+INCLUDE        = $(BASEDIR)/include-cygnus
+INCLUDES = -I. -I$(srcdir) -I$(INCLUDE) -I$(BFDDIR)
+DEBUG  = -g
+CFLAGS = $(INCLUDES) $(DEBUG) 
+
+# go directly to ld.new in case this ld isn't capable of
+# linking native object on this host.  It can be renamed on
+# install.
+PROGS  = ld.new
+
+# for self hosting
+GNUTARGET=a.out-generic-big
+LDEMULATION=gld
+bfdlib=$(BASEDIR)/bfd/Host-$(host)/libbfd.a
+
+OBJS= ldgram.o ldlex.o ldlang.o ldmain.o ldwrite.o ldexp.o ld-lnk960.o \
+       ld-gld.o ld-gld960.o ld-emul.o ldversion.o ldmisc.o ldsym.o ldfile.o
+
+HEADERS=config.h ldmain.h ldmain.h ldmisc.h ldsym.h ldlang.h ldexp.h \
+       ldlex.h ldwrite.h ldversion.h ld-emul.h ldfile.h ldgram.h ld.h
+
+MANSOURCES=ld.tex
+
+LDCSOURCES=ldlang.c ldmain.c ldwrite.c ld-lnk960.c ld-gld.c \
+       ld-gld960.c ld-emul.c ldversion.c ldmisc.c ldexp.c ldsym.c ldfile.c
+
+GENERATED_SOURCES=ldgram.tab.c ldlex.c ldgram.tab.h y.tab.h
+GENERATED_HEADERS=ldgram.tab.h
+
+LDSOURCES=$(LDCSOURCES) ldgram.y ldlex.l
+
+#BFDSOURCES=../bfd/libbfd.c ../bfd/bfd.c  ../bfd/sunos.c ../bfd/icoff.c ../bfd/b.out.c   ../bfd/archive.c  ../bfd/srec.c
+
+SOURCES= $(LDSOURCES) $(BFDSOURCES)
+LINTSOURCES=   $(LDCSOURCES) $(BFDSOURCES) $(GENERATED_SOURCES)
+
+all: $(PROGS)
+
+$(PROGS): $(OBJS)
+#      (cd ../bfd; make)
+#      LDEMULATION=gld; export LDEMULATION;  GNUTARGET=a.out-generic-big;./ldok -format a.out-generic-big  -o ld /lib/crt0.o   $(OBJS) $(bfdlib) -lc /usr/local/lib/gcc/sparc/1.91/gnulib
+#      gld -o ld /lib/crt0.o   $(OBJS) $(bfdlib) -lc /usr/local/lib/gcc/sparc/1.91/gnulib
+       $(CC) -Bstatic -o ld.new $(OBJS) $(bfdlib)
+
+
+ld1: ld
+       gcc -v  -B./ -o ld1  $(OBJS) $(bfdlib)
+
+ld2: ld1
+       mv ld1 ld
+       gcc -v  -B./ -o ld2  $(OBJS) $(bfdlib)
+
+ld3: ld2
+       mv ld2 ld
+       gcc -v  -B./ -o ld3  $(OBJS) $(bfdlib)
+
+ld.dvi:ld.tex
+       tex ld.tex
+
+ldgram.o:ldgram.y
+       yacc -d $(srcdir)/ldgram.y
+       mv y.tab.c ldgram.tab.c
+       $(CC) -c $(CFLAGS) ldgram.tab.c
+       mv ldgram.tab.o ldgram.o
+
+ldgram.tab.h:ldgram.o 
+       cp y.tab.h ldgram.tab.h
+       
+ldlex.c: ldlex.l ldgram.tab.h
+ldlex.o: ldlex.c ldgram.tab.h
+
+ldmain.o: ldmain.c
+ldversion.o: ldversion.c
+ldfile.o: ldfile.c
+ldwrite.o: ldwrite.c
+ldlang.o: ldlang.c ldgram.tab.h
+ld-gld.o: ld-gld.c
+ld-gld960.o: ld-gld960.c
+ld-emul.o:ld-emul.c
+ld-lnk960.o:ld-lnk960.c
+ldexp.o:ldexp.c ldgram.tab.h
+ldmisc.o:ldmisc.c 
+ldsym.o:ldsym.c 
+
+clean:
+       - rm -f $(OBJS) $(GENERATED_SOURCES) $(GENERATED_HEADERS)
+       - rm -f ld ld1 ld2
+
+
+lintlog:$(SOURCES) Makefile
+       $(LINT) -abhxzn  $(CFLAGS)  $(LINTSOURCES) \
+| grep -v "pointer casts may be troublesome" \
+| grep -v "possible pointer alignment problem" \
+| grep -v "ignore" \
+| grep -v "conversion from long may lose accuracy" \
+| grep -v "warning: constant argument to NOT" \
+| grep -v "enumeration type clash, operator CAST" \
+| grep -v "warning: constant in conditional context"\
+| grep -v "archive\.c"
+
+
+tags TAGS:$(SOURCES) $(HEADERS)
+       etags -t $(SOURCES) $(HEADERS)
+
+release:
+       (cd /4/steve/ld; tar cf -  $(LDSOURCES) $(HEADERS) $(MANSOURCES)) | tar xf - 
+
+objdump:objdump.c 
+
+install: $(PROGS)
+       rm -f $G960BASE/bin/$(PROGS)
+       cp $(PROGS) $$G960BASE/bin/gld960c
+
+#-----------------------------------------------------------------------------
+#              'STANDARD' GNU/960 TARGETS BELOW THIS POINT
+#
+# 'VERSION' file must be present and contain a string of the form "x.y"
+#-----------------------------------------------------------------------------
+
+ver960.c: FORCE
+       rm -f ver960.c
+       echo "char ${TARG}_ver[]= \"${TARG} `cat VERSION`, `date`\";" > ver960.c
+
+
+# This target should be invoked before building a new release.
+# 'VERSION' file must be present and contain a string of the form "x.y"
+#
+roll:
+       @V=`cat VERSION`                ; \
+       MAJ=`sed 's/\..*//' VERSION`    ; \
+       MIN=`sed 's/.*\.//' VERSION`    ; \
+       V=$$MAJ.`expr $$MIN + 1`        ; \
+       rm -f VERSION                   ; \
+       echo $$V >VERSION               ; \
+       echo Version $$V
+
+# Dummy target to force execution of dependent targets.
+#
+.force:
+FORCE:
+
+# Target to uncomment host-specific lines in this makefile.  Such lines must
+# have the following string beginning in column 1: #__<hostname>__#
+# Original Makefile is backed up as 'Makefile.old'.
+#
+# Invoke with:  make make HOST=xxx
+#
+make:
+       -@if test $(HOST)x = x ; then \
+               echo '\aSpecify "make make HOST=???"'; \
+               exit 1; \
+       fi ; \
+       grep -s "^#The next line was generated by 'make make'" Makefile; \
+       if test $$? = 0 ; then  \
+               echo "\aMakefile has already been processed with 'make make'";\
+               exit 1; \
+       fi ; \
+       mv -f Makefile Makefile.old; \
+       echo "#The next line was generated by 'make make'"       >Makefile ; \
+       echo "HOST=$(HOST)"                                     >>Makefile ; \
+       echo                                                    >>Makefile ; \
+       sed "s/^#__$(HOST)__#//" < Makefile.old                 >>Makefile
+
+#\f
+
+Makefile: $(srcdir)/Makefile.in $(srcdir)/configure
+       (cd $(srcdir) ; configure -host=$(host) $(target))
+
+### Local Variables: ***
+### mode:fundamental ***
+### page-delimiter: "^#\f" ***
+### End: ***
+### end of file
diff --git a/ld/configure b/ld/configure
new file mode 100755 (executable)
index 0000000..627867a
--- /dev/null
@@ -0,0 +1,845 @@
+#!/bin/sh
+# Do not edit this file.  It is generated automatically from configure.in
+# and a configure template.
+configdirs=
+
+#!/bin/sh
+# Do not edit this file.  It is generated automatically from configure.in
+# and a configure template.
+configdirs=
+
+# Configuration script template
+#   Copyright (C) 1988, 1990, 1991 Free Software Foundation, Inc.
+
+#This file is part of GNU.
+
+#GNU CC is free software; you can redistribute it and/or modify
+#it under the terms of the GNU General Public License as published by
+#the Free Software Foundation; either version 1, or (at your option)
+#any later version.
+
+#GNU CC is distributed in the hope that it will be useful,
+#but WITHOUT ANY WARRANTY; without even the implied warranty of
+#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+#GNU General Public License for more details.
+
+#You should have received a copy of the GNU General Public License
+#along with GNU CC; see the file COPYING.  If not, write to
+#the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
+
+#
+# Shell script to create proper links to machine-dependent files in
+# preparation for compiling gcc.
+#
+# Usage: configure [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET
+#
+# If configure succeeds, it leaves its status in config.status.
+# If configure fails after disturbing the status quo, 
+#      config.status is removed.
+#
+
+progname=$0
+
+remove=rm
+hard_link=ln
+symbolic_link='ln -s'
+
+#for Test
+#remove="echo rm"
+#hard_link="echo ln"
+#symbolic_link="echo ln -s"
+
+# clear some things potentially inherited from environment.
+target=
+template=
+removing=
+norecurse=
+ansi=
+
+for arg in $*;
+do
+       case $arg in
+       -ansi | +ansi)
+               ansi=true
+               ;;
+       -template=* | +template=*)
+               template=`echo $arg | sed 's/[+-]template=//'`
+               ;;
+       -norecurse | +norecurse)
+               norecurse=true
+               ;;
+       -rm | +rm)
+               removing=$arg
+               ;;
+       -srcdir=* | +srcdir=* | +srcdi=* | +srcd=* | +src=* | +sr=* | +s=*)
+               srcdir=`echo $arg | sed 's/[+-]s[a-z]*=//'`
+               ;;
+       -host=* | +host=* | +hos=* | +ho=* | +h=*)
+               host=`echo $arg | sed 's/[+-]h[a-z]*=//'`
+               ;; 
+       -languages=* | +languages=* | -languag=* | +languag=* | langua=* \
+               | +langua=* | -langu=* | +langu=* | -lang=* | +lang=* | -lan=* \
+               | +lan=* | -la=* | +la=* | -l=* | +l=*)
+               languages="$languages `echo $arg | sed 's/[+-]l[a-z]*=//'`"
+               ;;
+       -gas | +gas | +ga | +g)
+               gas=yes
+               ;;
+       -nfp | +nfp | +nf | +n)
+               nfp=yes
+               ;;
+       *)
+# Allow configure HOST TARGET
+               if [ x$host = x ] ; then host=$target ; fi
+               target=$arg
+               ;;
+       esac
+done
+
+# process host and target only if not rebuilding configure itself.
+if [ -z "$template" ]
+then
+       # Complain if an arg is missing
+       if [ x$target = x ]
+       then
+               echo "Usage: $progname [+srcdir=DIR] [+host=HOST] [+gas] [+nfp] TARGET"
+               echo -n "Where HOST and TARGET are something like "
+               echo "\`vax', \`sun3', \`encore', etc."
+               if [ -r config.status ]
+               then
+                       cat config.status
+               fi
+               exit 1
+       fi
+
+       # Default other arg
+       if [ x$host = x ]
+       then
+               host=$target
+       fi
+
+       # Decode the host machine, then the target machine.
+       # For the host machine, we save the xm_file variable as host_xm_file;
+       # then we decode the target machine and forget everything else
+       # that came from the host machine.
+       for machine in $host $target; do
+
+               # Separate what the user gave into CPU/company and OS (if any).
+               basic_machine=`echo $machine | sed 's/-[^-]*$//'`
+               if [ $basic_machine != $machine ]
+               then os=`echo $machine | sed 's/[^-]*-/-/'`
+               else os=; fi
+
+               # Decode aliases for certain machine/company combinations.
+               case $basic_machine in
+                       iris | iris4d)
+                               basic_machine=mips/sgi
+                               ;;
+                       news | news800)
+                               basic_machine=m68k/sony
+                               ;;
+                       3b1 | 7300 | 7300/att | att-7300)
+                               basic_machine=m68k/att
+                               ;;
+                       delta | 3300 | motorola-3300 | motorola-delta \
+                             | 3300/motorola | delta/motorola)
+                               basic_machine=m68k/motorola
+                               ;;
+                       vax/dec)
+                               basic_machine=vax
+                               ;;
+                       balance)
+                               basic_machine=ns32k/sequent
+                               ;;
+                       symmetry)
+                               basic_machine=i386/sequent
+                               ;;
+                       sun2)
+                               basic_machine=m68000/sun
+                               ;;
+                       sun3)
+                               basic_machine=m68k/sun
+                               ;;
+                       sun4)
+                               basic_machine=sparc/sun
+                               ;;
+                       sun386 | sun386i)
+                               basic_machine=i386/sun
+                               ;;
+                       ps2)
+                               basic_machine=i386/ibm
+                               ;;
+                       next)
+                               basic_machine=m68k/next
+                               ;;
+                       hp9k3[2-9][0-9])
+                               basic_machine=m68k/hp
+                               ;;
+                       hp9k31[0-9] | hp9k2[0-9][0-9])
+                               basic_machine=m68000/hp
+                               ;;
+                       isi68)
+                               basic_machine=m68k/isi
+                               ;;
+                       apollo68)
+                               basic_machine=m68k/apollo
+                               ;;
+                       altos | altos3068)
+                               basic_machine=m68k/altos
+                               ;;
+                       miniframe)
+                               basic_machine=m68000/convergent
+                               ;;
+                       tower | tower-32)
+                               basic_machine=m68k/ncr
+                               ;;
+                       news-3600 | risc-news)
+                               basic_machine=mips/sony
+                               ;;
+                       decstation | decstation-3100 | pmax)
+                               basic_machine=mips/dec
+                               ;;
+                       gmicro)
+                               basic_machine=tron
+                               ;;
+                       convex-c1)
+                               basic_machine=c1/convex
+                               ;;
+                       convex-c2)
+                               basic_machine=c2/convex
+                               ;;
+               esac
+
+               # Decode manufacturer-specific aliases for certain operating systems.
+
+               case $os in
+                       -newsos*)
+                               os=-bsd
+                               ;;
+                       -ultrix*)
+                               os=-bsd
+                               ;;
+                       -dynix*)
+                               os=-bsd
+                               ;;
+                       -ctix*)
+                               os=-sysv
+                               ;;
+               esac
+
+               machine=$basic_machine$os
+
+               cpu_type=
+               xm_file=
+               tm_file=
+               make_var_file=
+
+               case $machine in
+               vax | vax-bsd*)                 # vaxen running BSD
+                       ;;
+               vax-vms | vms)                  # vaxen running VMS
+                       cpu_type=vax
+                       xm_file=xm-vms.h
+                       tm_file=tm-vms.h
+                       ;;
+               vax-sysv* | vaxv)               # vaxen running system V
+                       cpu_type=vax
+                       xm_file=xm-vaxv.h
+                       tm_file=tm-vaxv.h
+                       ;;
+               tahoe | tahoe-bsd*)             # tahoe running BSD
+                       ;;
+               tahoe/harris*)                  # Harris tahoe, using COFF.
+                       cpu_type=tahoe
+                       ;;
+               i386/sequent* | i386/sequent-bsd*)  # 80386 from Sequent
+                       cpu_type=i386
+                       xm_file=xm-i386.h
+                       tm_file=tm-seq386.h
+                       ;;
+               i386-mach | i386/*-mach)
+                       cpu_type=i386
+                       xm_file=xm-i386.h
+                       tm_file=tm-i386gas.h
+                       ;;
+               i386/sco | i386/sco-sysv* | i386/*-sco) # 80386 running SCO system
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       tm_file=tm-i386sco.h
+                       make_var_file=make-i386sco
+                       ;;
+               i386/isc | i386/isc-sysv* | i386/*-isc) # 80386 running ISC system
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       tm_file=tm-i386isc.h
+                       make_var_file=make-i386isc
+                       ;;
+               i386/ibm | i386-aix | i386/ibm-aix)     # IBM PS/2 running AIX
+                       cpu_type=i386
+                       tm_file=tm-i386v.h
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       ;;
+               i386/sun*)
+                       cpu_type=i386
+                       xm_file=xm-sun386i.h
+                       tm_file=tm-sun386i.h
+                       ;;
+               i386-sysv4 | i386/*-sysv4 | i386v4)  # Intel 80386's running system V.4
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       tm_file=tm-i386v4.h
+                       ;;
+               i386-sysv* | i386/*-sysv* | i386v)  # Intel 80386's running system V
+                       cpu_type=i386
+                       xm_file=xm-i386v.h
+                       make_var_file=make-i386v
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i386gas.h
+                       else
+                               tm_file=tm-i386v.h
+                       fi
+                       ;;
+               i860 | i860-sysv* | i860/*-sysv*)
+                       cpu_type=i860
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i860g.h
+                       else
+                               tm_file=tm-i860.h
+                       fi
+                       ;;
+               i860-bsd* | i860/*-bsd*)
+                       cpu_type=i860
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-i860bsdg.h
+                       else
+                               tm_file=tm-i860bsd.h
+                       fi
+                       ;;
+               sparc | sparc/* | sparc-*os4 | sparc/*-*os4)
+                       cpu_type=sparc
+                       tm_file=tm-sparc.h
+                       ;;
+               sparc-*os3 | sparc/*-*os3)
+                       cpu_type=sparc
+                       tm_file=tm-sun4os3.h
+                       ;;
+               m68k/next)
+                       cpu_type=m68k
+                       tm_file=tm-next.h
+                       out_file=out-next.c
+                       xm_file=xm-next.h
+                       ;;
+               m68k/sun-*os3)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-sun3os3nf.h
+                       else
+                               tm_file=tm-sun3os3.h
+                       fi
+                       ;;
+               m68k/sun-mach)
+                       cpu_type=m68k
+                       tm_file=tm-sun3mach.h
+                       ;;
+               m68k/sun | m68k/sun-*os4)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-sun3nfp.h
+                       else
+                               tm_file=tm-sun3.h
+                       fi
+                       ;;
+               m68k/hp | m68k/hp-hpux*)        # HP 9000 series 300
+                       cpu_type=m68k
+                       xm_file=xm-hp9k320.h
+                       if [ x$gas = xyes ]
+                       then
+                               make_var_file=make-hp9k320g
+                               tm_file=tm-hp9k320g.h
+                       else
+                               make_var_file=make-hp9k320
+                               tm_file=tm-hp9k320.h
+                       fi
+                       ;;
+               m68k/hp-bsd*)                   # HP 9000/3xx running Berkeley Unix
+                       cpu_type=m68k
+                       tm_file=tm-hp9k3bsd.h
+                       ;;
+               m68k/isi | m68k/isi-bsd*)
+                       cpu_type=m68k
+                       if [ x$nfp = xyes ]
+                       then
+                               tm_file=tm-isi68-nfp.h
+                       else
+                               tm_file=tm-isi68.h
+                       fi
+                       ;;
+               m68k/sony | m68k/sony-bsd*)
+                       xm_file=xm-m68k.h
+                       cpu_type=m68k
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-newsgas.h
+                       else
+                               tm_file=tm-news.h
+                       fi
+                       ;;
+               m68k/altos | m68k/altos-sysv*)             # Altos 3068
+                       cpu_type=m68k
+                       if [ x$gas = xyes ]
+                       then
+                               xm_file=xm-altos3068.h
+                               tm_file=tm-altos3068.h
+                       else
+                               echo "The Altos is supported only with the GNU assembler" 1>&2
+                               exit 1
+                       fi
+                       ;;
+               m68k/motorola | m68k/motorola-sysv*)
+                       cpu_type=m68k
+                       tm_file=tm-mot3300.h
+                       xm_file=xm-mot3300.h
+                       ;;
+               m68k/crds | m68k/crds-unos | m68k-unos | crds | unos)
+                       cpu_type=m68k
+                       xm_file=xm-crds.h
+                       make_var_file=make-crds
+                       tm_file=tm-crds.h
+                       ;;
+               m68k/apollo)
+                       cpu_type=m68k
+                       make_var_file=make-apollo68
+                       tm_file=tm-apollo68.h
+                       ;;
+               m68k/ncr | m68k/ncr-sysv*)      # NCR Tower 32 SVR3
+                       cpu_type=m68k
+                       tm_file=tm-tower-as.h
+                       xm_file=xm-tower.h
+                       ;;
+               m68000/sun | m68000/sun-*os3)
+                       cpu_type=m68k
+                       tm_file=tm-sun2.h
+                       ;;
+               m68000/sun-*os4)
+                       cpu_type=m68k
+                       tm_file=tm-sun2os4.h
+                       ;;
+               m68000/hp | m68000/hp-hpux*)    # HP 9000 series 300
+                       cpu_type=m68k
+                       xm_file=xm-hp9k310.h
+                       if [ x$gas = xyes ]
+                       then
+                               make_var_file=make-hp9k320g
+                               tm_file=tm-hp9k310g.h
+                       else
+                               make_var_file=make-hp9k320
+                               tm_file=tm-hp9k310.h
+                       fi
+                       ;;
+               m68000/hp-bsd*)                 # HP 9000/200 running BSD
+                       cpu_type=m68k
+                       tm_file=tm-hp9k2bsd.h
+                       make_var_file=make-hp9k2bsd
+                       ;;
+               m68000/att | m68000/att-sysv*)
+                       cpu_type=m68k
+                       xm_file=xm-3b1.h
+                       if [ x$gas = xyes ]
+                       then
+                               tm_file=tm-3b1g.h
+                       else
+                               tm_file=tm-3b1.h
+                       fi
+                       ;;
+               m68000/convergent | m68000/convergent-sysv*)
+                       cpu_type=m68k
+                       xm_file=xm-3b1.h
+                       tm_file=tm-ctix.h
+                       ;;
+               ns32k/sequent | ns32k/sequent-bsd*)
+                       cpu_type=ns32k
+                       tm_file=tm-sequent.h
+                       ;;
+               ns32k/encore | ns32k/encore-bsd* | encore | encore-bsd*)
+                       cpu_type=ns32k
+                       tm_file=tm-encore.h
+                       ;;
+               ns32k-genix* | ns32k/*-genix* | genix)
+                       cpu_type=ns32k
+                       xm_file=xm-genix.h
+                       make_var_file=make-genix
+                       tm_file=tm-genix.h
+                       ;;
+               merlin)
+                       cpu_type=ns32k
+                       ;;
+               m88k/dg | m88k/dg-dgux* | m88k-dgux*)
+                       cpu_type=m88k
+                       xm_file=xm-m88kdgux.h
+                       make_var_file=make-m88kdgux
+                       tm_file=tm-m88kdgux.h
+                       ;;
+               m88k-v88r32 | m88k/*-v88r32)
+                       cpu_type=m88k
+                       tm_file=tm-v88r32.h
+                       xm_file=xm-v88r32.h
+                       ;;
+               m88k-sysv* | m88k/*-sysv*)
+                       cpu_type=m88k
+                       tm_file=tm-m88ksvr4.h
+                       xm_file=xm-m88ksvr4.h
+                       ;;
+               alliant | alliant/alliant)      # Alliant FX/8
+                       cpu_type=alliant
+                       tm_file=tm-alliant.h
+                       ;;
+               c1/convex)                      # Convex C1
+                       if [ -r /usr/include/stdlib.h ]
+                       then
+                               tm_file=tm-convex1.h
+                       else
+                               tm_file=tm-conv1os7.h
+                       fi
+                       cpu_type=convex
+                       ;;
+               c2/convex)                      # Convex C2
+                       if [ -r /usr/include/stdlib.h ]
+                       then
+                               tm_file=tm-convex2.h
+                       else
+                               tm_file=tm-conv2os7.h
+                       fi
+                       cpu_type=convex
+                       ;;
+               mips/sgi | mips/sgi-sysv*)      # Mostly like a MIPS.
+                       cpu_type=mips
+                       tm_file=tm-iris.h
+                       xm_file=xm-iris.h
+                       ;;
+               mips | mips/mips)               # Default MIPS environment.
+                       ;;
+               mips/dec | mips/dec-bsd*)       # Decstation.
+                       cpu_type=mips
+                       tm_file=tm-decstatn.h
+                       ;;
+               mips/sony | mips/sony-bsd*)     # Sony NEWS 3600 or risc/news.
+                       cpu_type=mips
+                       tm_file=tm-mips-news.h
+                       ;;
+               mips/*-sysv* | mips-sysv*)      # SYSV variant of MIPS system.
+                       cpu_type=mips
+                       tm_file=tm-mips-sysv.h
+                       ;;
+               mips/*-bsd* | mips-bsd*)        # BSD 4.3 variant of MIPS system.
+                       cpu_type=mips
+                       tm_file=tm-mips-bsd.h
+                       ;;
+               pyramid | pyramid/* | pyramid-*)
+                       cpu_type=pyr
+                       tm_file=tm-pyr.h
+                       ;;
+               tron | tron/*)
+                       cpu_type=gmicro
+                       tm_file=tm_gmicro.h
+                       ;;
+               a29k-bsd* | a29k/*-bsd*)
+                       cpu_type=a29k
+                       tm_file=tm-a29kunix.h
+                       ;;
+               i960)                           # Default i960 environment.
+                       ;;
+       #       370)
+       #               ;;
+               esac
+               if [ x$pass1done = x ]
+               then
+                       if [ x$cpu_type = x ]; then cpu_type=$host; fi
+                       if [ x$xm_file = x ]; then host_xm_file=xm-$cpu_type.h
+                       else host_xm_file=$xm_file
+                       fi
+                       if [ x$make_var_file = x ]
+                       then make_var_file=make-$cpu_type; fi
+                       host_make_var_file=$make_var_file
+                       pass1done=yes
+               fi
+       done
+
+       # Default the machine-specific variables that were not explicitly set.
+       if [ x$cpu_type = x ]
+       then cpu_type=$target; fi
+
+       if [ x$tm_file = x ]
+       then tm_file=tm-$target.h; fi
+
+       md_file=${cpu_type}.md
+
+       if [ x$out_file = x ]
+       then out_file=out-$cpu_type.c; fi
+fi
+
+#### configure.in files go here.
+### end of configure.in
+
+# are we rebuilding config itself?
+if [ -n "$template" ]
+then
+       if [ ! -r $template ]
+       then
+               echo "Can't find template ${template}."
+               exit 1
+       fi
+
+       mv configure configure.old
+       echo "#!/bin/sh" > configure
+       echo "# Do not edit this file.  It is generated automatically from configure.in" >> configure
+       echo "# and a configure template." >> configure
+       echo "configdirs=" >> configure
+       echo >> configure
+
+       if [ -r configure.in ]
+       then
+               sed -e "/^####/  r configure.in" $template >> configure
+       else
+               cat $template >> configure
+       fi
+
+       chmod a+x configure
+       rm configure.old
+#      echo Rebuilt configure in `pwd` from ${template}.
+       echo Rebuilt configure in `pwd`
+
+       if [ x$norecurse = x ]
+       then
+               while [ -n "$configdirs" ]
+               do
+                       # set configdir to car of configdirs, configdirs to cdr of configdirs
+                       set $configdirs; configdir=$1; shift; configdirs=$*
+
+                       if [ "`echo ${configdir}.*`" != "${configdir}.*" ]
+                       then
+                               targetspecificdirs=${configdir}.*
+                       else
+                               targetspecificdirs=
+                       fi
+
+                       for i in ${configdir} ${targetspecificdirs}
+                       do
+                               if [ -r $i/configure ]
+                               then
+                                       (cd $i ;
+                                               configure +template=${template})
+                               else
+                                       echo No configure script in `pwd`/$i
+                               fi
+                       done
+               done
+       fi
+
+       exit 0
+fi
+
+# Temporarily, we support only direct subdir builds.
+hostsubdir=Host-$host
+targetsubdir=Target-$target
+
+if [ -n "$removing" ]
+then
+       rm -rf $hostsubdir/$targetsubdir
+
+       if [ -z "`(ls $hostsubdir) 2>&1 | grep Target-`" ]
+       then
+               rm -rf $hostsubdir
+       fi
+else
+       if [ ! -d $hostsubdir ] ; then mkdir $hostsubdir ; fi
+       cd $hostsubdir
+
+       if [ ! -d $targetsubdir ] ; then mkdir $targetsubdir ; fi
+       cd $targetsubdir
+
+       srcdir=../..
+
+       ## Find the source files, if location was not specified.
+       #if [ x$srcdir = x ]
+       #then
+       #       srcdirdefaulted=1
+       #       srcdir=.
+       #       if [ ! -r ${srctrigger} ]
+       #       then
+       #               srcdir=..
+       #       fi
+       #fi
+       #
+       #if [ ! -r ${srcdir}/${srctrigger} ]
+       #then
+       #       if [ x$srcdirdefaulted = x ]
+       #       then
+       #         echo "$progname: Can't find ${srcname} sources in \`${srcdir}'." 1>&2
+       #       else
+       #         echo "$progname: Can't find ${srcname} sources in \`.' or \`..'." 1>&2
+       #       fi
+       #       exit 1
+       #fi
+
+
+
+       # Set up the list of links to be made.
+       # $links is the list of link names, and $files is the list of names to link to.
+
+       # Make the links.
+       while [ -n "$files" ]
+       do
+               # set file to car of files, files to cdr of files
+               set $files; file=$1; shift; files=$*
+               set $links; link=$1; shift; links=$*
+
+               if [ ! -r ${srcdir}/config/$file ]
+               then
+                       echo "$progname: cannot create a link \`$link'," 1>&2
+                       echo "since the file \`config/$file' does not exist." 1>&2
+                       exit 1
+               fi
+
+               $remove -f $link
+               rm -f config.status
+               # Make a symlink if possible, otherwise try a hard link
+               $symbolic_link ${srcdir}/config/$file $link 2>/dev/null || $hard_link ${srcdir}/config/$file $link
+
+               if [ ! -r $link ]
+               then
+                       echo "$progname: unable to link \`$link' to \`${srcdir}/config/$file'." 1>&2
+                       exit 1
+               fi
+               echo "Linked \`$link' to \`${srcdir}/config/$file'."
+       done
+
+       # Install a makefile, and make it set VPATH
+       # if necessary so that the sources are found.
+       # Also change its value of srcdir.
+       # Also create a .gdbinit file which runs the one in srcdir
+       # and tells GDB to look there for source files.
+       case $srcdir in
+       .)
+               ;;
+       *)
+               echo "VPATH = ${srcdir}" > x
+               cat x ${srcdir}/Makefile.in | sed "s@^srcdir = \.@srcdir = ${srcdir}@" > Makefile.in
+               rm x
+               echo "dir ." > .gdbinit
+               echo "dir ${srcdir}" >> .gdbinit
+               echo "source ${srcdir}/.gdbinit" >> .gdbinit
+               ;;
+       esac
+
+       host_var_file=hmake-${host}
+       target_var_file=tmake-${target}
+
+       # Conditionalize the makefile for this machine.
+       if [ -f ${srcdir}/config/${host_var_file} ]
+       then
+               sed -e "/^####/  r ${srcdir}/config/${host_var_file}" Makefile.in > Makefile.tem
+       else
+               cp Makefile.in Makefile.tem
+       fi
+
+       if [ -f ${srcdir}/config/${target_var_file} ]
+       then
+               sed -e "/^####/  r ${srcdir}/config/${target_var_file}" Makefile.tem > Makefile.tem1
+               mv Makefile.tem1 Makefile.tem
+       fi
+
+       # Remove all formfeeds, since some Makes get confused by them.
+       sed "s/\f//" Makefile.tem >> Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # reset SUBDIRS
+       sed "s:^SUBDIRS =.*$:SUBDIRS = ${configdirs}:" Makefile.tem > Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # reset NONSUBDIRS
+       sed "s:^NONSUBDIRS =.*$:NONSUBDIRS = ${noconfigdirs}:" Makefile.tem > Makefile.tem1
+       mv Makefile.tem1 Makefile.tem
+
+       # Delete the intermediate files
+       if [ x$srcdir != x. ] ; then rm Makefile.in ; fi
+
+       rm -f Makefile
+
+       # Define macro CROSS_COMPILE in compilation if this is a cross-compiler.
+       if [ x$host != x$target ]
+       then
+               echo "CROSS=-DCROSS_COMPILE" > Makefile
+               echo "ALL=start.encap" >> Makefile
+       else
+               echo "ALL=all.internal" > Makefile
+       fi
+
+       # set target and host
+       echo "host = $host" >> Makefile
+       echo "target = $target" >> Makefile
+
+       cat Makefile.tem >> Makefile
+       rm Makefile.tem
+
+       using=
+       if [ -f ${srcdir}/config/${host_var_file} ]
+       then
+               using=" using \"${host_var_file}\""
+       fi
+
+       if [ -f ${srcdir}/config/${target_var_file} ]
+       then
+               if [ -z "${using}" ]
+               then
+                       andusing=" using \"${target_var_file}\""
+               else
+                       andusing="${using} and \"${target_var_file}\""
+               fi
+       else
+               andusing=${using}
+       fi
+
+       echo "Created \"Makefile\""${andusing}.
+
+       if [ x$host = x$target ]
+       then
+               echo "Links are now set up for use with a $target." \
+                       | tee ${srcdir}/config.status
+       else
+               echo "Links are now set up for host $host and target $target." \
+                       | tee ${srcdir}/config.status
+       fi
+
+       cd ${srcdir}
+fi
+
+# If there are subdirectories, then recurse. 
+
+if [ x$norecurse != x ] ; then exit 0 ; fi
+
+while [ -n "$configdirs" ]
+do
+       # set configdir to car of configdirs, configdirs to cdr of configdirs
+       set $configdirs; configdir=$1; shift; configdirs=$*
+
+       # check for target override
+       targetspecificdir=${configdir}.${target}
+       if [ -d ${targetspecificdir} ]
+       then
+               configdir=${targetspecificdir}
+       fi
+
+       echo Configuring ${configdir}...
+       (cd ${configdir} ;
+               configure +host=${host} ${target} ${removing}) \
+               | sed 's/^/     /'
+done
+
+exit 0