* aoutx.h (howto_table_ext): Comment the field names.
[deliverable/binutils-gdb.git] / bfd / configure.in
index 54f40a7ab7f72731b4b0412cc3fa296dd939477c..55469a00df2f87d8879293b97046ea1ba2d98aa9 100644 (file)
@@ -7,136 +7,21 @@ configdirs="doc"
 srctrigger=libbfd.c
 srcname="BFD"
 target_dependent=true
+host64=false
+target64=false
+want64=false
 
 # per-host:
 
-case "${host_cpu}" in
-
-rs6000)        my_host=rs6000
-       ;;
-
-mips)
-       case "${host_vendor}" in
-       dec)    my_host=decstation ;;
-       sgi)
-               case "${host_os}" in
-               irix3)  my_host=irix3 ;;
-               irix4)  my_host=irix4 ;;
-               esac
-               ;;
-       esac
-       ;;
-
-m88k)
-       case "${host_vendor}" in
-       motorola)
-               my_host=delta88 ;;
-       harris)
-               my_host=harris ;;
-       *)
-               case "${host_os}" in
-               dgux)   my_host=dgux ;;
-               esac
-               ;;
-       esac
-       ;;
-
-m68k|m680[01234]0)
-       case "${host_vendor}" in
-       cbm)
-               case ${host_os} in
-               amigados)       my_host=amigados ;;
-               sysv4*)         my_host=amix ;;
-               esac
-               ;;
-       hp)     
-               case "${host_os}" in
-               hpux)   my_host=hp9000 ;;
-               bsd)    my_host=hp300bsd ;;
-               esac
-               ;;
-       sony)   my_host=news ;;
-       sun)    my_host=sun3 ;;
-       apollo*)
-               case "${host_os}" in
-               sysv*)  my_host=apollov68 ;;
-               bsd*)   my_host=apollo68 ;;
-               esac
-               ;;
-       esac
-       ;;
-
-i860)  my_host=stratus
-       ;;
-
-i386)
-       case "${host_vendor}" in
-       ncr*)
-               case "${host_os}" in
-               sysv4*) my_host=ncr3000 ;;
-               esac
-               ;;
-       *)
-               case "${host_os}" in
-               go32) my_host=go32 ;;
-               sysv4*) my_host=i386v4 ;;
-               sysv* | scosysv*) my_host=i386v ;;
-               mach*)  my_host=i386mach ;;
-               msdos*) my_host=dose ;;
-               linux)  my_host=i386linux ;;
-               esac
-               ;;
-       esac
-       ;;
-
-sparc)
-       case "${host_os}" in
-       sunos64)        my_host=sparc-ll ;;
-       sysv4)          my_host=sysv4 ;;
-       solaris2)       my_host=solaris2 ;;
-       sysv64)         my_host=sysv4-ll ;;
-       *)              my_host=sparc ;;
-       esac
-       ;;
-
-romp)  my_host=rtbsd
-       ;;
-
-a29k)  my_host=ultra3
-       ;;
-
-tahoe)
-       my_host=tahoe
-       ;;
-
-vax)
-       case "${host_os}" in
-       ultrix*) my_host=vaxult ;;
-       *) my_host=vaxbsd ;;
-       esac
-       ;;
-hppa)
-       case "${host_vendor}" in
-       hp)
-               case "${host_os}" in
-               hpux)   my_host=hppahpux ;;
-               bsd)    my_host=hppabsd ;;
-               esac
-               ;;
-       esac
-       ;;
-esac
+. ${srcdir}/configure.host
 
 # Set up to make a link between the host's include file and "sysdep.h".
 files="hosts/${my_host}.h"
 links="sysdep.h"
 
 if [ ! -f ${srcdir}/${files} ] ; then
-       if [ -n "${my_host}" ] ; then
-               echo '***' No file ${srcdir}/${files}
-       fi
-       echo '***' ${srcname} does not support host ${host}
-       exit 1
+       files=../bfd/hosts/std-host.h
+       echo "[${srcname} has no specific support for host ${host} -- using std-host]"
 fi
 
 host_makefile_frag=
@@ -146,92 +31,140 @@ fi
 
 # per-target:
 
-case "${target}" in
-
-rs6000-ibm-*           ) bfd_target=rs6000 ;;
-
-a29k-amd-ebmon         ) bfd_target=a29k-coff ;;
-a29k-amd-udi           ) bfd_target=a29k-coff ;;
-a29k-amd-*             ) bfd_target=a29k-aout ;;
-
-h8300-hitachi-*                ) bfd_target=h8300-coff ;;
-*-hitachi-*            ) echo "bad hitachi cpu"; exit 1 ;;
-
-i960-wrs-*             ) bfd_target=i960-bout ;;
-m68k-wrs-*             ) bfd_target=m68k-aout ;;
-m680[01234]0-wrs-*     ) bfd_target=m68k-aout ;;
-
-m68k-sun-*             ) bfd_target=m68k-aout ;;
-m680[01234]0-sun-*     ) bfd_target=m68k-aout ;;
-sparc-sun-sysv4                ) bfd_target=sparc-elf ;;
-sparc-sun-solaris2*    ) bfd_target=sparc-elf ;;
-sparc-sun-*            ) bfd_target=sparc-aout ;;
-
-mips-dec-*             ) bfd_target=decstation ;;
-vax-dec-*              ) bfd_target=vax ;;
-
-m68k-hp-hpux           ) bfd_target=hp9000 ;;
-m680[01234]0-hp-hpux   ) bfd_target=hp9000 ;;
-m68k-hp-bsd            ) bfd_target=hp300bsd ;;
-m60[01234]0-hp-bsd     ) bfd_target=hp300bsd ;;
-
-mips-sgi-*             ) bfd_target=irix3 ;;
-mips-big-*             ) bfd_target=irix3 ;;
-       
-*-tandem-*             ) bfd_target=st2000 ;;
-
-m68k-none-os68k                ) bfd_target=m68k-aout ;;
-m680[01234]0-none-os68k        ) bfd_target=m68k-aout ;;
-i386-sco-*             ) bfd_target=i386-coff ;;
-
-a29k-none-aout         ) bfd_target=a29k-aout ;;
-a29k-none-coff         ) bfd_target=a29k-coff ;;
-a29k-nyu-sym1          ) bfd_target=a29k-coff ;;
-
-m88k-harris-*          ) bfd_target=m88k-coff ;;
-m88k-motorola-*                ) bfd_target=m88k-coff ;;
-
-vax-*-*                        ) bfd_target=vax ;;
-tahoe-*-*              ) bfd_target=tahoe ;;
-
-hppa-hp-hpux           ) bfd_target=hppahpux ;;
-hppa-hp-bsd            ) bfd_target=hppabsd ;;
-
-*-*-aout               ) bfd_target=${target_cpu}-aout ;;
-*-*-bsd                        ) bfd_target=${target_cpu}-aout ;;
-*-*-sysv4*             ) bfd_target=${target_cpu}-elf ;;
-*-*-solaris2*          ) bfd_target=${target_cpu}-elf ;;
-*-*-go32               ) bfd_target=${target_cpu}-aout ;;              
-*-*-linux*             ) bfd_target=${target_cpu}-linux ;;
-*-*-sysv*              ) bfd_target=${target_cpu}-coff ;;
-*-*-scosysv*           ) bfd_target=${target_cpu}-coff ;;
-tahoe-*-none           ) bfd_target=${target_cpu} ;;
-vax-*-none             ) bfd_target=${target_cpu} ;;
-
-# These are obsolete and should be removed.  FIXME.   -- gnu
-*-aout-*               ) bfd_target=${target_cpu}-aout ;;
-*-bout-*               ) bfd_target=${target_cpu}-bout ;;
-*-coff-*               ) bfd_target=${target_cpu}-coff ;;
-*-elf-*                        ) bfd_target=${target_cpu}-elf ;;
-
-i386-none-*            ) bfd_target=i386-coff ;;
-*-sony-*               ) bfd_target=news ;;
-*-intel-*              ) bfd_target=${target_cpu}-coff ;;      
-*-stratus-*            ) bfd_target=${target_cpu}-elf ;;
-*-cbm-*                        ) bfd_target=${target_cpu}-elf ;;
-*-ncr-*                        ) bfd_target=${target_cpu}-elf ;;
+# WHEN ADDING ENTRIES TO THIS MATRIX:
+#  Make sure that the left side always has two dashes.  Otherwise you
+#  can get spurious matches.  Even for unambiguous cases, do this as a
+#  convention, else the table becomes a real mess to understand and maintain.
 
+case "${target}" in
+  alpha-*-*)           bfd_target=alphaosf ;;
+  a29k-*-ebmon)                bfd_target=a29k-coff ;;
+  a29k-*-udi)          bfd_target=a29k-coff ;;
+  a29k-*-aout)         bfd_target=a29k-aout ;;
+  a29k-*-coff)         bfd_target=a29k-coff ;;
+  a29k-*-sym1)         bfd_target=a29k-coff ;;
+  h8300-*-*)           bfd_target=h8300-coff ;;
+  h8500-*-*)           bfd_target=h8500-coff ;;
+  sh-*-*)              bfd_target=sh-coff ;;
+  hppa*-*-bsd*)                bfd_target=hppabsd ;;
+  hppa*-*-hpux*)       bfd_target=hppahpux ;;
+  hppa*-*-osf)         bfd_target=hppa-elf ;;
+  i[34]86-*-sysv4*)    bfd_target=i386-elf ;;
+  i[34]86-*-sysv*)     bfd_target=i386-coff ;;
+  i[34]86-*-isc*)      bfd_target=i386-sco ;; # gets core dump reading right
+  i[34]86-*-sco*)      bfd_target=i386-sco ;;
+  i[34]86-*-bsd*)      bfd_target=i386-bsd ;;
+  i[34]86-*-aix*)      bfd_target=i386-coff ;;
+  i[34]86-*-elf)       bfd_target=i386-elf ;;
+  i[34]86-*-linux*)    bfd_target=i386-linux ;;
+  i[34]86-none-*)      bfd_target=i386-coff ;;
+  i960-*-vxworks)      bfd_target=i960-bout ;;
+  i960-*-aout)         bfd_target=i960-bout ;;
+  i960-*-bout)         bfd_target=i960-bout ;;
+  m68*-hp-bsd*)                bfd_target=hp300bsd ;;
+  m68*-*-aout)         bfd_target=m68k-aout ;;
+  m68*-*-coff)         bfd_target=m68k-coff ;;
+  m68*-*-hpux*)                bfd_target=hp300hpux ;;
+  m68*-*-os68k)                bfd_target=m68k-aout ;;
+  m68*-*-sunos*)       bfd_target=m68k-aout ;;
+  m68*-*-sysv*)                bfd_target=m68k-coff ;;
+  m68*-*-vxworks*)     bfd_target=m68k-aout ;;
+  m68*-ericsson-*)     bfd_target=m68k-aout ;;
+  m68*-netx-*)         bfd_target=m68k-aout ;;
+  m88k-*-*)            bfd_target=m88k-coff ;;
+  mips-big-*)          bfd_target=bigmips ;;
+  mips-dec-bsd*)        bfd_target=mipsdecbsd ;;
+  mips-dec-*)          bfd_target=decstation ;;
+  mips-*-ecoffl*)      bfd_target=decstation ;;
+  mips-*-ecoff*)       bfd_target=bigmips ;;
+  mips-sgi-*)          bfd_target=bigmips ;;
+  mips-*-sysv*)                bfd_target=riscos ;;
+  mips-*-bsd*)         bfd_target=noop ;;
+  rs6000-*-*)          bfd_target=rs6000 ;;
+  sparc-*-solaris2*)   bfd_target=sparc-elf ;;
+  sparc-*-sysv4*)      bfd_target=sparc-elf ;;
+  sparc64-*-aout*)     bfd_target=sparc-aout ; target64=true ;; # v9
+  sparc64-*-elf*)      bfd_target=sparc-aout ; target64=true ;; # v9
+  sparc*-*-*)          bfd_target=sparc-aout ;;
+  tahoe-*-*)           bfd_target=tahoe ;;
+  vax-*-vms)           bfd_target=vax-vms ;;
+  vax-*-*)             bfd_target=vax ;;
+  we32k-*-*)           bfd_target=we32k ;;
+  z8k*-*-*)            bfd_target=z8k-coff ;;
+
+  *-*-aout)            bfd_target=${target_cpu}-aout ;;
+  *-*-bsd*)            bfd_target=${target_cpu}-aout ;;
+  *-*-sysv4*)          bfd_target=${target_cpu}-elf ;;
+  *-*-solaris2*)       bfd_target=${target_cpu}-elf ;;
+  *-*-go32)            bfd_target=${target_cpu}-aout ;;
+  *-*-sysv*)           bfd_target=${target_cpu}-coff ;;
+
+  *-*-aout64)          bfd_target=${target_cpu}-aout64 ; target64=true ;;
+  *-*-elf64)           bfd_target=${target_cpu}-elf64 ; target64=true ;;
+
+  *-adobe-*)           bfd_target=adobe ;;
+  *-sony-*)            bfd_target=news ;;
+  *-intel-*)           bfd_target=${target_cpu}-coff ;;
+  *-stratus-*)         bfd_target=${target_cpu}-elf ;;
+  *-cbm-*)             bfd_target=${target_cpu}-elf ;;
+  *-ncr-*)             bfd_target=${target_cpu}-elf ;;
+  *-tandem-*)          bfd_target=st2000 ;;
 esac
 
 if [ ! -f ${srcdir}/config/${bfd_target}.mt ] ; then
        if [ -n "${bfd_target}" ] ; then
-               echo '***' No file ${srcdir}/config/${bfd_target}.mt
+               echo '***' No file ${srcdir}/config/${bfd_target}.mt 1>&2
        fi
-       echo '***' BFD does not support target ${target}
-       echo '***' Look in bfd/configure.in for supported targets
+       echo '***' BFD does not support target ${target} 1>&2
+       echo '***' Look in bfd/configure.in for supported targets 1>&2
        exit 1
 fi
 target_makefile_frag=config/${bfd_target}.mt
 
 # We don't do any links based on the target system, just very minor makefile
 # config.
+
+# post-target:
+
+rm -f Makefile.tmp Makefile.2
+mv Makefile Makefile.tmp
+
+case ${with_minimal_bfd} in
+  yes)
+    echo MINIMIZE=1 > Makefile.2
+    ;;
+  no | "")
+    echo MINIMIZE=0 > Makefile.2
+    ;;
+  *)
+    echo "*** bad value \"${with_minimal_bfd}\" for minimal-bfd flag; ignored" 1>&2
+    echo MINIMIZE=0 > Makefile.2
+    ;;
+esac
+
+case ${with_64_bit_bfd} in
+  yes)
+    want64=true
+    ;;
+  no | "")
+    want64=false
+    ;;
+  *)
+    echo "*** bad value \"${with_64_bit_bfd}\" for 64-bit-bfd flag; ignored" 1>&2
+    ;;
+esac
+
+case ${host64}-${target64}-${want64} in
+  *true*)
+    echo WORDSIZE=64 >> Makefile.2
+    echo 'BFD_BACKENDS = $(BFD32_BACKENDS) $(BFD64_BACKENDS)' >> Makefile.2
+    ;;
+  false-false-false)
+    echo WORDSIZE=32 >> Makefile.2
+    echo 'BFD_BACKENDS = $(BFD32_BACKENDS)' >> Makefile.2
+    ;;
+esac
+
+cat Makefile.tmp >> Makefile.2
+rm -f Makefile.tmp
+mv Makefile.2 Makefile
This page took 0.025809 seconds and 4 git commands to generate.