diff options
| -rwxr-xr-x | contrib/gdb/config.guess | 599 | ||||
| -rwxr-xr-x | contrib/gdb/config.sub | 1110 | ||||
| -rwxr-xr-x | contrib/gdb/configure | 1303 | ||||
| -rw-r--r-- | contrib/gdb/configure.in | 763 | ||||
| -rwxr-xr-x | contrib/gdb/install.sh | 236 | ||||
| -rwxr-xr-x | contrib/gdb/move-if-change | 15 | ||||
| -rw-r--r-- | contrib/gdb/opcodes/config.in | 7 | ||||
| -rwxr-xr-x | contrib/gdb/opcodes/configure | 1538 | ||||
| -rw-r--r-- | contrib/gdb/opcodes/configure.in | 216 | ||||
| -rw-r--r-- | contrib/gdb/opcodes/z8k-dis.c | 571 | 
10 files changed, 6358 insertions, 0 deletions
| diff --git a/contrib/gdb/config.guess b/contrib/gdb/config.guess new file mode 100755 index 000000000000..c3c4e799a6ba --- /dev/null +++ b/contrib/gdb/config.guess @@ -0,0 +1,599 @@ +#! /bin/sh +# Attempt to guess a canonical system name. +#   Copyright (C) 1992, 93, 94, 95, 1996 Free Software Foundation, Inc. +# +# This file 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 2 of the License, or +# (at your option) any later version. +# +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# Written by Per Bothner <bothner@cygnus.com>. +# The master version of this file is at the FSF in /home/gd/gnu/lib. +# +# This script attempts to guess a canonical system name similar to +# config.sub.  If it succeeds, it prints the system name on stdout, and +# exits with 0.  Otherwise, it exits with 1. +# +# The plan is that this can be called by configure scripts if you +# don't specify an explicit system type (host/target name). +# +# Only a few systems have been added to this list; please add others +# (but try to keep the structure clean). +# + +# This is needed to find uname on a Pyramid OSx when run in the BSD universe. +# (ghazi@noc.rutgers.edu 8/24/94.) +if (test -f /.attbin/uname) >/dev/null 2>&1 ; then +	PATH=$PATH:/.attbin ; export PATH +fi + +UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown +UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown +UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown +UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown + +trap 'rm -f dummy.c dummy.o dummy; exit 1' 1 2 15 + +# Note: order is significant - the case branches are not exclusive. + +case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in +    alpha:OSF1:[VX]*:*) +	# After 1.2, OSF1 uses "V1.3" for uname -r. +	# After 4.x, OSF1 uses "X4.x" for uname -r. +	echo alpha-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[VX]//'` +	exit 0 ;; +    alpha:OSF1:*:*) +	# 1.2 uses "1.2" for uname -r. +	echo alpha-dec-osf${UNAME_RELEASE} +        exit 0 ;; +    21064:Windows_NT:50:3) +	echo alpha-dec-winnt3.5 +	exit 0 ;; +    Amiga*:UNIX_System_V:4.0:*) +	echo m68k-cbm-sysv4 +	exit 0;; +    amiga:NetBSD:*:*) +      echo m68k-cbm-netbsd${UNAME_RELEASE} +      exit 0 ;; +    arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) +	echo arm-acorn-riscix${UNAME_RELEASE} +	exit 0;; +    Pyramid*:OSx*:*:*) +	if test "`(/bin/universe) 2>/dev/null`" = att ; then +		echo pyramid-pyramid-sysv3 +	else +		echo pyramid-pyramid-bsd +	fi +	exit 0 ;; +    sun4*:SunOS:5.*:*) +	echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` +	exit 0 ;; +    i86pc:SunOS:5.*:*) +	echo i386-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` +	exit 0 ;; +    sun4*:SunOS:6*:*) +	# According to config.sub, this is the proper way to canonicalize +	# SunOS6.  Hard to guess exactly what SunOS6 will be like, but +	# it's likely to be more like Solaris than SunOS4. +	echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'` +	exit 0 ;; +    sun4*:SunOS:*:*) +	case "`/usr/bin/arch -k`" in +	    Series*|S4*) +		UNAME_RELEASE=`uname -v` +		;; +	esac +	# Japanese Language versions have a version number like `4.1.3-JL'. +	echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'` +	exit 0 ;; +    sun3*:SunOS:*:*) +	echo m68k-sun-sunos${UNAME_RELEASE} +	exit 0 ;; +    atari*:NetBSD:*:*) +	echo m68k-atari-netbsd${UNAME_RELEASE} +	exit 0 ;; +    sun3*:NetBSD:*:*) +	echo m68k-sun-netbsd${UNAME_RELEASE} +	exit 0 ;; +    mac68k:NetBSD:*:*) +	echo m68k-apple-netbsd${UNAME_RELEASE} +	exit 0 ;; +    RISC*:ULTRIX:*:*) +	echo mips-dec-ultrix${UNAME_RELEASE} +	exit 0 ;; +    VAX*:ULTRIX*:*:*) +	echo vax-dec-ultrix${UNAME_RELEASE} +	exit 0 ;; +    mips:*:4*:UMIPS) +	echo mips-mips-riscos4sysv +	exit 0 ;; +    mips:*:5*:RISCos) +	echo mips-mips-riscos${UNAME_RELEASE} +	exit 0 ;; +    Night_Hawk:Power_UNIX:*:*) +	echo powerpc-harris-powerunix +	exit 0 ;; +    m88k:CX/UX:7*:*) +	echo m88k-harris-cxux7 +	exit 0 ;; +    m88k:*:4*:R4*) +	echo m88k-motorola-sysv4 +	exit 0 ;; +    m88k:*:3*:R3*) +	echo m88k-motorola-sysv3 +	exit 0 ;; +    AViiON:dgux:*:*) +        # DG/UX returns AViiON for all architectures +        UNAME_PROCESSOR=`uname -p` +        if [ $UNAME_PROCESSOR = mc88100 -o $UNAME_PROCESSOR = mc88100 ] ; then +	if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx \ +	     -o ${TARGET_BINARY_INTERFACE}x = x ] ; then +		echo m88k-dg-dgux${UNAME_RELEASE} +	else +		echo m88k-dg-dguxbcs${UNAME_RELEASE} +	fi +        else echo i586-dg-dgux${UNAME_RELEASE} +        fi + 	exit 0 ;; +    M88*:DolphinOS:*:*)	# DolphinOS (SVR3) +	echo m88k-dolphin-sysv3 +	exit 0 ;; +    M88*:*:R3*:*) +	# Delta 88k system running SVR3 +	echo m88k-motorola-sysv3 +	exit 0 ;; +    XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) +	echo m88k-tektronix-sysv3 +	exit 0 ;; +    Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) +	echo m68k-tektronix-bsd +	exit 0 ;; +    *:IRIX*:*:*) +	echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'` +	exit 0 ;; +   ????????:AIX?:[12].1:2)   # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. +	echo romp-ibm-aix      # uname -m gives an 8 hex-code CPU id +	exit 0 ;;              # Note that: echo "'`uname -s`'" gives 'AIX ' +    i[34]86:AIX:*:*) +	echo i386-ibm-aix +	exit 0 ;; +    *:AIX:2:3) +	if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then +		sed 's/^		//' << EOF >dummy.c +		#include <sys/systemcfg.h> + +		main() +			{ +			if (!__power_pc()) +				exit(1); +			puts("powerpc-ibm-aix3.2.5"); +			exit(0); +			} +EOF +		${CC-cc} dummy.c -o dummy && ./dummy && rm dummy.c dummy && exit 0 +		rm -f dummy.c dummy +		echo rs6000-ibm-aix3.2.5 +	elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then +		echo rs6000-ibm-aix3.2.4 +	else +		echo rs6000-ibm-aix3.2 +	fi +	exit 0 ;; +    *:AIX:*:4) +	if /usr/sbin/lsattr -EHl proc0 | grep POWER >/dev/null 2>&1; then +		IBM_ARCH=rs6000 +	else +		IBM_ARCH=powerpc +	fi +	if [ -x /usr/bin/oslevel ] ; then +		IBM_REV=`/usr/bin/oslevel` +	else +		IBM_REV=4.${UNAME_RELEASE} +	fi +	echo ${IBM_ARCH}-ibm-aix${IBM_REV} +	exit 0 ;; +    *:AIX:*:*) +	echo rs6000-ibm-aix +	exit 0 ;; +    ibmrt:4.4BSD:*|romp-ibm:BSD:*) +	echo romp-ibm-bsd4.4 +	exit 0 ;; +    ibmrt:*BSD:*|romp-ibm:BSD:*)            # covers RT/PC NetBSD and +	echo romp-ibm-bsd${UNAME_RELEASE}   # 4.3 with uname added to  +	exit 0 ;;                           # report: romp-ibm BSD 4.3 +    *:BOSX:*:*) +	echo rs6000-bull-bosx +	exit 0 ;; +    DPX/2?00:B.O.S.:*:*) +	echo m68k-bull-sysv3 +	exit 0 ;; +    9000/[34]??:4.3bsd:1.*:*) +	echo m68k-hp-bsd +	exit 0 ;; +    hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) +	echo m68k-hp-bsd4.4 +	exit 0 ;; +    9000/[3478]??:HP-UX:*:*) +	case "${UNAME_MACHINE}" in +	    9000/31? )            HP_ARCH=m68000 ;; +	    9000/[34]?? )         HP_ARCH=m68k ;; +	    9000/7?? | 9000/8?[679] ) HP_ARCH=hppa1.1 ;; +	    9000/8?? )            HP_ARCH=hppa1.0 ;; +	esac +	HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'` +	echo ${HP_ARCH}-hp-hpux${HPUX_REV} +	exit 0 ;; +    3050*:HI-UX:*:*) +	sed 's/^	//' << EOF >dummy.c +	#include <unistd.h> +	int +	main () +	{ +	  long cpu = sysconf (_SC_CPU_VERSION); +	  /* The order matters, because CPU_IS_HP_MC68K erroneously returns +	     true for CPU_PA_RISC1_0.  CPU_IS_PA_RISC returns correct +	     results, however.  */ +	  if (CPU_IS_PA_RISC (cpu)) +	    { +	      switch (cpu) +		{ +		  case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; +		  case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; +		  case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; +		  default: puts ("hppa-hitachi-hiuxwe2"); break; +		} +	    } +	  else if (CPU_IS_HP_MC68K (cpu)) +	    puts ("m68k-hitachi-hiuxwe2"); +	  else puts ("unknown-hitachi-hiuxwe2"); +	  exit (0); +	} +EOF +	${CC-cc} dummy.c -o dummy && ./dummy && rm dummy.c dummy && exit 0 +	rm -f dummy.c dummy +	echo unknown-hitachi-hiuxwe2 +	exit 0 ;; +    9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* ) +	echo hppa1.1-hp-bsd +	exit 0 ;; +    9000/8??:4.3bsd:*:*) +	echo hppa1.0-hp-bsd +	exit 0 ;; +    hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* ) +	echo hppa1.1-hp-osf +	exit 0 ;; +    hp8??:OSF1:*:*) +	echo hppa1.0-hp-osf +	exit 0 ;; +    parisc*:Lites*:*:*) +	echo hppa1.1-hp-lites +	exit 0 ;; +    C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) +	echo c1-convex-bsd +        exit 0 ;; +    C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) +	if getsysinfo -f scalar_acc +	then echo c32-convex-bsd +	else echo c2-convex-bsd +	fi +        exit 0 ;; +    C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) +	echo c34-convex-bsd +        exit 0 ;; +    C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) +	echo c38-convex-bsd +        exit 0 ;; +    C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) +	echo c4-convex-bsd +        exit 0 ;; +    CRAY*X-MP:*:*:*) +	echo xmp-cray-unicos +        exit 0 ;; +    CRAY*Y-MP:*:*:*) +	echo ymp-cray-unicos${UNAME_RELEASE} +	exit 0 ;; +    CRAY*C90:*:*:*) +	echo c90-cray-unicos${UNAME_RELEASE} +	exit 0 ;; +    CRAY-2:*:*:*) +	echo cray2-cray-unicos +        exit 0 ;; +    hp3[0-9][05]:NetBSD:*:*) +	echo m68k-hp-netbsd${UNAME_RELEASE} +	exit 0 ;; +    i[34]86:BSD/386:*:* | *:BSD/OS:*:*) +	echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE} +	exit 0 ;; +    *:FreeBSD:*:*) +	echo ${UNAME_MACHINE}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` +	exit 0 ;; +    *:NetBSD:*:*) +	echo ${UNAME_MACHINE}-unknown-netbsd`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'` +	exit 0 ;; +    i*:CYGWIN*:*) +	echo i386-unknown-cygwin32 +	exit 0 ;; +    p*:CYGWIN*:*) +	echo powerpcle-unknown-cygwin32 +	exit 0 ;; +    *:GNU:*:*) +	echo `echo ${UNAME_MACHINE}|sed -e 's,/.*$,,'`-unknown-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'` +	exit 0 ;; +    *:Linux:*:*) +	# The BFD linker knows what the default object file format is, so +	# first see if it will tell us. +	ld_help_string=`ld --help 2>&1` +	if echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations: elf_i[345]86"; then +	  echo "${UNAME_MACHINE}-unknown-linux" ; exit 0 +	elif echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations: i[345]86linux"; then +	  echo "${UNAME_MACHINE}-unknown-linuxaout" ; exit 0 +	elif echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations: i[345]86coff"; then +	  echo "${UNAME_MACHINE}-unknown-linuxcoff" ; exit 0 +	elif echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations: m68kelf"; then +	  echo "${UNAME_MACHINE}-unknown-linux" ; exit 0 +	elif echo "$ld_help_string" | grep >/dev/null 2>&1 "supported emulations: m68klinux"; then +	  echo "${UNAME_MACHINE}-unknown-linuxaout" ; exit 0 +	elif test "${UNAME_MACHINE}" = "alpha" ; then +	  echo alpha-unknown-linux ; exit 0 +	else +	  # Either a pre-BFD a.out linker (linuxoldld) or one that does not give us +	  # useful --help.  Gcc wants to distinguish between linuxoldld and linuxaout. +	  test ! -d /usr/lib/ldscripts/. \ +	    && echo "${UNAME_MACHINE}-unknown-linuxoldld" && exit 0 +	  # Determine whether the default compiler is a.out or elf +	  cat >dummy.c <<EOF +main(argc, argv) +int argc; +char *argv[]; +{ +#ifdef __ELF__ +  printf ("%s-unknown-linux\n", argv[1]); +#else +  printf ("%s-unknown-linuxaout\n", argv[1]); +#endif +  return 0; +} +EOF +	  ${CC-cc} dummy.c -o dummy 2>/dev/null && ./dummy "${UNAME_MACHINE}" && rm dummy.c dummy && exit 0 +	  rm -f dummy.c dummy +	fi ;; +# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.  earlier versions +# are messed up and put the nodename in both sysname and nodename. +    i[34]86:DYNIX/ptx:4*:*) +	echo i386-sequent-sysv4 +	exit 0 ;; +    i[34]86:*:4.*:* | i[34]86:SYSTEM_V:4.*:*) +	if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then +		echo ${UNAME_MACHINE}-univel-sysv${UNAME_RELEASE} +	else +		echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE} +	fi +	exit 0 ;; +    i[34]86:*:3.2:*) +	if test -f /usr/options/cb.name; then +		UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name` +		echo ${UNAME_MACHINE}-unknown-isc$UNAME_REL +	elif /bin/uname -X 2>/dev/null >/dev/null ; then +		UNAME_REL=`(/bin/uname -X|egrep Release|sed -e 's/.*= //')` +		(/bin/uname -X|egrep i80486 >/dev/null) && UNAME_MACHINE=i486 +		(/bin/uname -X|egrep '^Machine.*Pentium' >/dev/null) \ +			&& UNAME_MACHINE=i586 +		echo ${UNAME_MACHINE}-unknown-sco$UNAME_REL +	else +		echo ${UNAME_MACHINE}-unknown-sysv32 +	fi +	exit 0 ;; +    Intel:Mach:3*:*) +	echo i386-unknown-mach3 +	exit 0 ;; +    paragon:*:*:*) +	echo i860-intel-osf1 +	exit 0 ;; +    i860:*:4.*:*) # i860-SVR4 +	if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then +	  echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4 +	else # Add other i860-SVR4 vendors below as they are discovered. +	  echo i860-unknown-sysv${UNAME_RELEASE}  # Unknown i860-SVR4 +	fi +	exit 0 ;; +    mini*:CTIX:SYS*5:*) +	# "miniframe" +	echo m68010-convergent-sysv +	exit 0 ;; +    M680[234]0:*:R3V[567]*:*) +	test -r /sysV68 && echo 'm68k-motorola-sysv' && exit 0 ;; +    3[34]??:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0) +        uname -p 2>/dev/null | grep 86 >/dev/null \ +          && echo i486-ncr-sysv4.3 && exit 0 ;; +    3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) +        uname -p 2>/dev/null | grep 86 >/dev/null \ +          && echo i486-ncr-sysv4 && exit 0 ;; +    m680[234]0:LynxOS:2.[23]*:*) +	echo m68k-lynx-lynxos${UNAME_RELEASE} +	exit 0 ;; +    mc68030:UNIX_System_V:4.*:*) +	echo m68k-atari-sysv4 +	exit 0 ;; +    i[34]86:LynxOS:2.[23]*:*) +	echo i386-lynx-lynxos${UNAME_RELEASE} +	exit 0 ;; +    TSUNAMI:LynxOS:2.[23]*:*) +	echo sparc-lynx-lynxos${UNAME_RELEASE} +	exit 0 ;; +    rs6000:LynxOS:2.[23]*:*) +	echo rs6000-lynx-lynxos${UNAME_RELEASE} +	exit 0 ;; +    RM*:SINIX-*:*:*) +	echo mips-sni-sysv4 +	exit 0 ;; +    *:SINIX-*:*:*) +	if uname -p 2>/dev/null >/dev/null ; then +		UNAME_MACHINE=`(uname -p) 2>/dev/null` +		echo ${UNAME_MACHINE}-sni-sysv4 +	else +		echo ns32k-sni-sysv +	fi +	exit 0 ;; +    mc68*:A/UX:*:*) +	echo m68k-apple-aux${UNAME_RELEASE} +	exit 0 ;; +    R3000:*System_V*:*:*) +	if [ -d /usr/nec ]; then +	        echo mips-nec-sysv${UNAME_RELEASE} +	else +	        echo mips-unknown-sysv${UNAME_RELEASE} +	fi +        exit 0 ;; +esac + +#echo '(No uname command or uname output not recognized.)' 1>&2 +#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2 + +cat >dummy.c <<EOF +#ifdef _SEQUENT_ +# include <sys/types.h> +# include <sys/utsname.h> +#endif +main () +{ +#if defined (sony) +#if defined (MIPSEB) +  /* BFD wants "bsd" instead of "newsos".  Perhaps BFD should be changed, +     I don't know....  */ +  printf ("mips-sony-bsd\n"); exit (0); +#else +#include <sys/param.h> +  printf ("m68k-sony-newsos%s\n", +#ifdef NEWSOS4 +          "4" +#else +	  "" +#endif +         ); exit (0); +#endif +#endif + +#if defined (__arm) && defined (__acorn) && defined (__unix) +  printf ("arm-acorn-riscix"); exit (0); +#endif + +#if defined (hp300) && !defined (hpux) +  printf ("m68k-hp-bsd\n"); exit (0); +#endif + +#if defined (NeXT) +#if !defined (__ARCHITECTURE__) +#define __ARCHITECTURE__ "m68k" +#endif +  int version; +  version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; +  printf ("%s-next-nextstep%s\n", __ARCHITECTURE__,  version==2 ? "2" : "3"); +  exit (0); +#endif + +#if defined (MULTIMAX) || defined (n16) +#if defined (UMAXV) +  printf ("ns32k-encore-sysv\n"); exit (0); +#else +#if defined (CMU) +  printf ("ns32k-encore-mach\n"); exit (0); +#else +  printf ("ns32k-encore-bsd\n"); exit (0); +#endif +#endif +#endif + +#if defined (__386BSD__) +  printf ("i386-unknown-bsd\n"); exit (0); +#endif + +#if defined (sequent) +#if defined (i386) +  printf ("i386-sequent-dynix\n"); exit (0); +#endif +#if defined (ns32000) +  printf ("ns32k-sequent-dynix\n"); exit (0); +#endif +#endif + +#if defined (_SEQUENT_) +    struct utsname un; + +    uname(&un); + +    if (strncmp(un.version, "V2", 2) == 0) { +	printf ("i386-sequent-ptx2\n"); exit (0); +    } +    if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ +	printf ("i386-sequent-ptx1\n"); exit (0); +    } +    printf ("i386-sequent-ptx\n"); exit (0); + +#endif + +#if defined (vax) +#if !defined (ultrix) +  printf ("vax-dec-bsd\n"); exit (0); +#else +  printf ("vax-dec-ultrix\n"); exit (0); +#endif +#endif + +#if defined (alliant) && defined (i860) +  printf ("i860-alliant-bsd\n"); exit (0); +#endif + +  exit (1); +} +EOF + +${CC-cc} dummy.c -o dummy 2>/dev/null && ./dummy && rm dummy.c dummy && exit 0 +rm -f dummy.c dummy + +# Apollos put the system type in the environment. + +test -d /usr/apollo && { echo ${ISP}-apollo-${SYSTYPE}; exit 0; } + +# Convex versions that predate uname can use getsysinfo(1) + +if [ -x /usr/convex/getsysinfo ] +then +    case `getsysinfo -f cpu_type` in +    c1*) +	echo c1-convex-bsd +	exit 0 ;; +    c2*) +	if getsysinfo -f scalar_acc +	then echo c32-convex-bsd +	else echo c2-convex-bsd +	fi +	exit 0 ;; +    c34*) +	echo c34-convex-bsd +	exit 0 ;; +    c38*) +	echo c38-convex-bsd +	exit 0 ;; +    c4*) +	echo c4-convex-bsd +	exit 0 ;; +    esac +fi + +#echo '(Unable to guess system type)' 1>&2 + +exit 1 diff --git a/contrib/gdb/config.sub b/contrib/gdb/config.sub new file mode 100755 index 000000000000..c462f8a1ca88 --- /dev/null +++ b/contrib/gdb/config.sub @@ -0,0 +1,1110 @@ +#! /bin/sh +# Configuration validation subroutine script, version 1.1. +#   Copyright (C) 1991, 92, 93, 94, 95, 1996 Free Software Foundation, Inc. +# This file is (in principle) common to ALL GNU software. +# The presence of a machine in this file suggests that SOME GNU software +# can handle that machine.  It does not imply ALL GNU software can.  +# +# This file 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 2 of the License, or +# (at your option) any later version. +# +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, +# Boston, MA 02111-1307, USA. + +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# Configuration subroutine to validate and canonicalize a configuration type. +# Supply the specified configuration type as an argument. +# If it is invalid, we print an error message on stderr and exit with code 1. +# Otherwise, we print the canonical config type on stdout and succeed. + +# This file is supposed to be the same for all GNU packages +# and recognize all the CPU types, system types and aliases +# that are meaningful with *any* GNU software. +# Each package is responsible for reporting which valid configurations +# it does not support.  The user should be able to distinguish +# a failure to support a valid configuration from a meaningless +# configuration. + +# The goal of this file is to map all the various variations of a given +# machine specification into a single specification in the form: +#	CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM +# It is wrong to echo any other type of specification. + +if [ x$1 = x ] +then +	echo Configuration name missing. 1>&2 +	echo "Usage: $0 CPU-MFR-OPSYS" 1>&2 +	echo "or     $0 ALIAS" 1>&2 +	echo where ALIAS is a recognized configuration type. 1>&2 +	exit 1 +fi + +# First pass through any local machine types. +case $1 in +	*local*) +		echo $1 +		exit 0 +		;; +	*) +	;; +esac + +# Separate what the user gave into CPU-COMPANY and OS (if any). +basic_machine=`echo $1 | sed 's/-[^-]*$//'` +if [ $basic_machine != $1 ] +then os=`echo $1 | sed 's/.*-/-/'` +else os=; fi + +### Let's recognize common machines as not being operating systems so +### that things like config.sub decstation-3100 work.  We also +### recognize some manufacturers as not being operating systems, so we +### can provide default operating systems below. +case $os in +	-sun*os*) +		# Prevent following clause from handling this invalid input. +		;; +	-dec* | -mips* | -sequent* | -encore* | -pc532* | -sgi* | -sony* | \ +	-att* | -7300* | -3300* | -delta* | -motorola* | -sun[234]* | \ +	-unicom* | -ibm* | -next | -hp | -isi* | -apollo | -altos* | \ +	-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\ +	-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \ +	-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp ) +		os= +		basic_machine=$1 +		;; +	-sim | -cisco | -oki | -wec | -winbond )	# CYGNUS LOCAL +		os= +		basic_machine=$1 +		;; +	-apple*)					# CYGNUS LOCAL +		os= +		basic_machine=$1 +		;; +	-scout)						# CYGNUS LOCAL +		;; +	-wrs)						# CYGNUS LOCAL +		os=vxworks +		basic_machine=$1 +		;; +	-hiux*) +		os=-hiuxwe2 +		;; +	-sco5) +		os=sco3.2v5 +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-sco4) +		os=-sco3.2v4 +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-sco3.2.[4-9]*) +		os=`echo $os | sed -e 's/sco3.2./sco3.2v/'` +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-sco3.2v[4-9]*) +		# Don't forget version if it is 3.2v4 or newer. +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-sco*) +		os=-sco3.2v2 +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-isc) +		os=-isc2.2 +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-clix*) +		basic_machine=clipper-intergraph +		;; +	-isc*) +		basic_machine=`echo $1 | sed -e 's/86-.*/86-unknown/'` +		;; +	-lynx*) +		os=-lynxos +		;; +	-ptx*) +		basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'` +		;; +	-windowsnt*) +		os=`echo $os | sed -e 's/windowsnt/winnt/'` +		;; +	-psos*) +		os=-psos +		;; +esac + +# Decode aliases for certain CPU-COMPANY combinations. +case $basic_machine in +	# Recognize the basic CPU types without company name. +	# Some are omitted here because they have special meanings below. +	tahoe | i[3456]86 | i860 | m68k | m68000 | m88k | ns32k | arm \ +		| arme[lb] | pyramid \ +		| tron | a29k | 580 | i960 | h8300 | hppa1.0 | hppa1.1 \ +		| alpha | we32k | ns16k | clipper | i370 | sh \ +		| powerpc | powerpcle | 1750a | dsp16xx | mips64 | mipsel \ +		| pdp11 | mips64el | mips64orion | mips64orionel \ +		| sparc | sparclet | sparclite | sparc64) +		basic_machine=$basic_machine-unknown +		;; +	m88110 | m680[01234]0 | m683?2 | m68360 | z8k | v70 | h8500 | w65) # CYGNUS LOCAL +		basic_machine=$basic_machine-unknown +		;; +	mips64vr4300 | mips64vr4300el) # CYGNUS LOCAL jsmith/vr4300 +		basic_machine=$basic_machine-unknown +		;; +	mips64vr4100 | mips64vr4100el) # CYGNUS LOCAL jsmith/vr4100 +		basic_machine=$basic_machine-unknown +		;; +	# Object if more than one company name word. +	*-*-*) +		echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 +		exit 1 +		;; +	# Recognize the basic CPU types with company name. +	vax-* | tahoe-* | i[3456]86-* | i860-* | m68k-* | m68000-* | m88k-* \ +	      | sparc-* | ns32k-* | fx80-* | arm-* | arme[lb]-* | c[123]* \ +	      | mips-* | pyramid-* | tron-* | a29k-* | romp-* | rs6000-* | power-* \ +	      | none-* | 580-* | cray2-* | h8300-* | i960-* | xmp-* | ymp-* \ +	      | hppa1.0-* | hppa1.1-* | alpha-* | we32k-* | cydra-* | ns16k-* \ +	      | pn-* | np1-* | xps100-* | clipper-* | orion-* | sparclite-* \ +	      | pdp11-* | sh-* | powerpc-* | powerpcle-* | sparc64-* | mips64-* | mipsel-* \ +	      | mips64el-* | mips64orion-* | mips64orionel-*) +		;; +	m88110-* | m680[01234]0-* | m683?2-* | m68360-* | z8k-* | h8500-*) # CYGNUS LOCAL +		;; +	mips64vr4300-* | mips64vr4300el-*) # CYGNUS LOCAL jsmith/vr4300 +		;; +	mips64vr4100-* | mips64vr4100el-*) # CYGNUS LOCAL jsmith/vr4100 +		;; +	# Recognize the various machine names and aliases which stand +	# for a CPU type and a company and sometimes even an OS. +	386bsd)						# CYGNUS LOCAL +		basic_machine=i386-unknown +		os=-bsd +		;; +	3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) +		basic_machine=m68000-att +		;; +	3b*) +		basic_machine=we32k-att +		;; +	a29khif)					# CYGNUS LOCAL +		basic_machine=a29k-amd +		os=-udi +		;; +	adobe68k)					# CYGNUS LOCAL +		basic_machine=m68010-adobe +		os=-scout +		;; +	alliant | fx80) +		basic_machine=fx80-alliant +		;; +	altos | altos3068) +		basic_machine=m68k-altos +		;; +	am29k) +		basic_machine=a29k-none +		os=-bsd +		;; +	amdahl) +		basic_machine=580-amdahl +		os=-sysv +		;; +	amiga | amiga-*) +		basic_machine=m68k-cbm +		;; +	amigados) +		basic_machine=m68k-cbm +		os=-amigados +		;; +	amigaunix | amix) +		basic_machine=m68k-cbm +		os=-sysv4 +		;; +	apollo68) +		basic_machine=m68k-apollo +		os=-sysv +		;; +	apollo68bsd)					# CYGNUS LOCAL +		basic_machine=m68k-apollo +		os=-bsd +		;; +	arm | armel | armeb) +		basic_machine=arm-arm +		os=-aout +		;; +	aux) +		basic_machine=m68k-apple +		os=-aux +		;; +	balance) +		basic_machine=ns32k-sequent +		os=-dynix +		;; +	convex-c1) +		basic_machine=c1-convex +		os=-bsd +		;; +	convex-c2) +		basic_machine=c2-convex +		os=-bsd +		;; +	convex-c32) +		basic_machine=c32-convex +		os=-bsd +		;; +	convex-c34) +		basic_machine=c34-convex +		os=-bsd +		;; +	convex-c38) +		basic_machine=c38-convex +		os=-bsd +		;; +	cray | ymp) +		basic_machine=ymp-cray +		os=-unicos +		;; +	cray2) +		basic_machine=cray2-cray +		os=-unicos +		;; +	crds | unos) +		basic_machine=m68k-crds +		;; +	da30 | da30-*) +		basic_machine=m68k-da30 +		;; +	decstation | decstation-3100 | pmax | pmax-* | pmin | dec3100 | decstatn) +		basic_machine=mips-dec +		;; +	delta | 3300 | motorola-3300 | motorola-delta \ +	      | 3300-motorola | delta-motorola) +		basic_machine=m68k-motorola +		;; +	delta88) +		basic_machine=m88k-motorola +		os=-sysv3 +		;; +	dpx20 | dpx20-*) +		basic_machine=rs6000-bull +		os=-bosx +		;; +	dpx2* | dpx2*-bull) +		basic_machine=m68k-bull +		os=-sysv3 +		;; +	ebmon29k) +		basic_machine=a29k-amd +		os=-ebmon +		;; +	elxsi) +		basic_machine=elxsi-elxsi +		os=-bsd +		;; +	encore | umax | mmax) +		basic_machine=ns32k-encore +		;; +	es1800 | OSE68k | ose68k | ose | OSE)		# CYGNUS LOCAL +		basic_machine=m68k-ericsson +		os=-ose +		;; +	fx2800) +		basic_machine=i860-alliant +		;; +	genix) +		basic_machine=ns32k-ns +		;; +	gmicro) +		basic_machine=tron-gmicro +		os=-sysv +		;; +	h3050r* | hiux*) +		basic_machine=hppa1.1-hitachi +		os=-hiuxwe2 +		;; +	h8300hms) +		basic_machine=h8300-hitachi +		os=-hms +		;; +	h8300xray)					# CYGNUS LOCAL +		basic_machine=h8300-hitachi +		os=-xray +		;; +	h8500hms)					# CYGNUS LOCAL +		basic_machine=h8500-hitachi +		os=-hms +		;; +	harris) +		basic_machine=m88k-harris +		os=-sysv3 +		;; +	hp300-*) +		basic_machine=m68k-hp +		;; +	hp300bsd) +		basic_machine=m68k-hp +		os=-bsd +		;; +	hp300hpux) +		basic_machine=m68k-hp +		os=-hpux +		;; +        w89k-*)						# CYGNUS LOCAL +                basic_machine=hppa1.1-winbond +                os=-proelf +                ;; +        op50n-*)					# CYGNUS LOCAL +                basic_machine=hppa1.1-oki +                os=-proelf +                ;; +        op60c-*)					# CYGNUS LOCAL +                basic_machine=hppa1.1-oki +                os=-proelf +                ;; +        hppro)						# CYGNUS LOCAL +                basic_machine=hppa1.1-hp +                os=-proelf +                ;; +	hp9k2[0-9][0-9] | hp9k31[0-9]) +		basic_machine=m68000-hp +		;; +	hp9k3[2-9][0-9]) +		basic_machine=m68k-hp +		;; +	hp9k7[0-9][0-9] | hp7[0-9][0-9] | hp9k8[0-9]7 | hp8[0-9]7) +		basic_machine=hppa1.1-hp +		;; +	hp9k8[0-9][0-9] | hp8[0-9][0-9]) +		basic_machine=hppa1.0-hp +		;; +	hppaosf)					# CYGNUS LOCAL +		basic_machine=hppa1.1-hp +		os=-osf +		;; +	i370-ibm* | ibm*) +		basic_machine=i370-ibm +		os=-mvs +		;; +# I'm not sure what "Sysv32" means.  Should this be sysv3.2? +	i[3456]86v32) +		basic_machine=`echo $1 | sed -e 's/86.*/86-unknown/'` +		os=-sysv32 +		;; +	i[3456]86v4*) +		basic_machine=`echo $1 | sed -e 's/86.*/86-unknown/'` +		os=-sysv4 +		;; +	i[3456]86v) +		basic_machine=`echo $1 | sed -e 's/86.*/86-unknown/'` +		os=-sysv +		;; +	i[3456]86sol2) +		basic_machine=`echo $1 | sed -e 's/86.*/86-unknown/'` +		os=-solaris2 +		;; +	i386mach)					# CYGNUS LOCAL +		basic_machine=i386-mach +		os=-mach +		;; +	i386-vsta | vsta)				# CYGNUS LOCAL +		basic_machine=i386-unknown +		os=-vsta +		;; +	i386-go32 | go32)				# CYGNUS LOCAL +		basic_machine=i386-unknown +		os=-go32 +		;; +	iris | iris4d) +		basic_machine=mips-sgi +		case $os in +		    -irix*) +			;; +		    *) +			os=-irix4 +			;; +		esac +		;; +	isi68 | isi) +		basic_machine=m68k-isi +		os=-sysv +		;; +	m88k-omron*) +		basic_machine=m88k-omron +		;; +	magnum | m3230) +		basic_machine=mips-mips +		os=-sysv +		;; +	merlin) +		basic_machine=ns32k-utek +		os=-sysv +		;; +	miniframe) +		basic_machine=m68000-convergent +		;; +	mips3*-*) +		basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'` +		;; +	mips3*) +		basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown +		;; +	monitor)					# CYGNUS LOCAL +		basic_machine=m68k-rom68k +		os=-coff +		;; +	msdos)						# CYGNUS LOCAL +		basic_machine=i386-unknown	 +		os=-msdos +		;; +	ncr3000) +		basic_machine=i486-ncr +		os=-sysv4 +		;; +	netbsd386) +		basic_machine=i386-unknown		# CYGNUS LOCAL +		os=-netbsd +		;; +	news | news700 | news800 | news900) +		basic_machine=m68k-sony +		os=-newsos +		;; +	news1000) +		basic_machine=m68030-sony +		os=-newsos +		;; +	news-3600 | risc-news) +		basic_machine=mips-sony +		os=-newsos +		;; +	necv70)						# CYGNUS LOCAL +		basic_machine=v70-nec +		os=-sysv +		;; +	next | m*-next ) +		basic_machine=m68k-next +		case $os in +		    -nextstep* ) +			;; +		    -ns2*) +		      os=-nextstep2 +			;; +		    *) +		      os=-nextstep3 +			;; +		esac +		;; +	nh3000) +		basic_machine=m68k-harris +		os=-cxux +		;; +	nh[45]000) +		basic_machine=m88k-harris +		os=-cxux +		;; +	nindy960) +		basic_machine=i960-intel +		os=-nindy +		;; +	mon960) +		basic_machine=i960-intel +		os=-mon960 +		;; +	np1) +		basic_machine=np1-gould +		;; +	OSE68000 | ose68000)				# CYGNUS LOCAL +		basic_machine=m68000-ericsson +		os=-ose +		;; +	os68k)						# CYGNUS LOCAL +		basic_machine=m68k-none +		os=-os68k +		;; +	pa-hitachi) +		basic_machine=hppa1.1-hitachi +		os=-hiuxwe2 +		;; +	paragon) +		basic_machine=i860-intel +		os=-osf +		;; +	pbd) +		basic_machine=sparc-tti +		;; +	pbb) +		basic_machine=m68k-tti +		;; +        pc532 | pc532-*) +		basic_machine=ns32k-pc532 +		;; +	pentium | p5) +		basic_machine=i586-intel +		;; +	pentiumpro | p6) +		basic_machine=i686-intel +		;; +	pentium-* | p5-*) +		basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'` +		;; +	pentiumpro-* | p6-*) +		basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'` +		;; +	k5) +		# We don't have specific support for AMD's K5 yet, so just call it a Pentium +		basic_machine=i586-amd +		;; +	nexen) +		# We don't have specific support for Nexgen yet, so just call it a Pentium +		basic_machine=i586-nexgen +		;; +	pn) +		basic_machine=pn-gould +		;; +	power)	basic_machine=rs6000-ibm +		;; +	ppc)	basic_machine=powerpc-unknown +	        ;; +	ppc-*)	basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'` +		;; +	ppcle | powerpclittle | ppc-le | powerpc-little) +		basic_machine=powerpcle-unknown +	        ;; +	ppcle-* | powerpclittle-*) +		basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'` +		;; +	ps2) +		basic_machine=i386-ibm +		;; +	rom68k)						# CYGNUS LOCAL +		basic_machine=m68k-rom68k +		os=-coff +		;; +	rm[46]00) +		basic_machine=mips-siemens +		;; +	rtpc | rtpc-*) +		basic_machine=romp-ibm +		;; +	sa29200)					# CYGNUS LOCAL +		basic_machine=a29k-amd +		os=-udi +		;; +	sequent) +		basic_machine=i386-sequent +		;; +	sh) +		basic_machine=sh-hitachi +		os=-hms +		;; +	sparclite-wrs)					# CYGNUS LOCAL +		basic_machine=sparclite-wrs +		os=-vxworks +		;; +	sps7) +		basic_machine=m68k-bull +		os=-sysv2 +		;; +	spur) +		basic_machine=spur-unknown +		;; +	st2000)						# CYGNUS LOCAL +		basic_machine=m68k-tandem +		;; +	stratus)					# CYGNUS LOCAL +		basic_machine=i860-stratus +		os=-sysv4 +		;; +	sun2) +		basic_machine=m68000-sun +		;; +	sun2os3) +		basic_machine=m68000-sun +		os=-sunos3 +		;; +	sun2os4) +		basic_machine=m68000-sun +		os=-sunos4 +		;; +	sun3os3) +		basic_machine=m68k-sun +		os=-sunos3 +		;; +	sun3os4) +		basic_machine=m68k-sun +		os=-sunos4 +		;; +	sun4os3) +		basic_machine=sparc-sun +		os=-sunos3 +		;; +	sun4os4) +		basic_machine=sparc-sun +		os=-sunos4 +		;; +	sun4sol2) +		basic_machine=sparc-sun +		os=-solaris2 +		;; +	sun3 | sun3-*) +		basic_machine=m68k-sun +		;; +	sun4) +		basic_machine=sparc-sun +		;; +	sun386 | sun386i | roadrunner) +		basic_machine=i386-sun +		;; +	symmetry) +		basic_machine=i386-sequent +		os=-dynix +		;; +	tower | tower-32) +		basic_machine=m68k-ncr +		;; +	udi29k) +		basic_machine=a29k-amd +		os=-udi +		;; +	ultra3) +		basic_machine=a29k-nyu +		os=-sym1 +		;; +	v810 | necv810)					# CYGNUS LOCAL +		basic_machine=v810-nec +		os=-none +		;; +	vaxv) +		basic_machine=vax-dec +		os=-sysv +		;; +	vms) +		basic_machine=vax-dec +		os=-vms +		;; +	vxworks960) +		basic_machine=i960-wrs +		os=-vxworks +		;; +	vxworks68) +		basic_machine=m68k-wrs +		os=-vxworks +		;; +	vxworks29k) +		basic_machine=a29k-wrs +		os=-vxworks +		;; +	w65*)						# CYGNUS LOCAL + 		basic_machine=w65-wdc + 		os=-none +		;; +	xmp) +		basic_machine=xmp-cray +		os=-unicos +		;; +        xps | xps100) +		basic_machine=xps100-honeywell +		;; +	z8k-*-coff)					# CYGNUS LOCAL +		basic_machine=z8k-unknown +		os=-sim +		;; +	none) +		basic_machine=none-none +		os=-none +		;; + +# Here we handle the default manufacturer of certain CPU types.  It is in +# some cases the only manufacturer, in others, it is the most popular. +	w89k)						# CYGNUS LOCAL +		basic_machine=hppa1.1-winbond +		;; +	op50n)						# CYGNUS LOCAL +		basic_machine=hppa1.1-oki +		;; +	op60c)						# CYGNUS LOCAL +		basic_machine=hppa1.1-oki +		;; +	mips) +		basic_machine=mips-mips +		;; +	romp) +		basic_machine=romp-ibm +		;; +	rs6000) +		basic_machine=rs6000-ibm +		;; +	vax) +		basic_machine=vax-dec +		;; +	pdp11) +		basic_machine=pdp11-dec +		;; +	we32k) +		basic_machine=we32k-att +		;; +	sparc) +		basic_machine=sparc-sun +		;; +        cydra) +		basic_machine=cydra-cydrome +		;; +	orion) +		basic_machine=orion-highlevel +		;; +	orion105) +		basic_machine=clipper-highlevel +		;; +	mac | mpw | mac-mpw)				# CYGNUS LOCAL +		basic_machine=m68k-apple +		;; +	pmac | pmac-mpw)				# CYGNUS LOCAL +		basic_machine=powerpc-apple +		;; +	*) +		echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2 +		exit 1 +		;; +esac + +# Here we canonicalize certain aliases for manufacturers. +case $basic_machine in +	*-digital*) +		basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'` +		;; +	*-commodore*) +		basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'` +		;; +	*) +		;; +esac + +# Decode manufacturer-specific aliases for certain operating systems. + +if [ x"$os" != x"" ] +then +case $os in +	# -solaris* is a basic system type, with this one exception. +	-solaris1 | -solaris1.*) +		os=`echo $os | sed -e 's|solaris1|sunos4|'` +		;; +	-solaris) +		os=-solaris2 +		;; +	-unixware* | svr4*) +		os=-sysv4 +		;; +	-gnu/linux*) +		os=`echo $os | sed -e 's|gnu/linux|linux|'` +		;; +	# First accept the basic system types. +	# The portable systems comes first. +	# Each alternative MUST END IN A *, to match a version number. +	# -sysv* is not here because it comes later, after sysvr4. +	-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \ +	      | -vms* | -sco* | -esix* | -isc* | -aix* | -sunos | -sunos[3456]* \ +	      | -hpux* | -unos* | -osf* | -luna* | -dgux* | -solaris* | -sym* \ +	      | -amigados* | -msdos* | -moss* | -newsos* | -unicos* | -aos* | -aof* \ +	      | -nindy* | -mon960* | -vxworks* | -ebmon* | -hms* | -mvs* | -clix* \ +	      | -riscos* | -linux* | -uniplus* | -iris* | -rtu* | -xenix* \ +	      | -hiux* | -386bsd* | -netbsd* | -freebsd* | -riscix* \ +	      | -lynxos* | -bosx* | -nextstep* | -cxux* | -aout* | -elf* \ +	      | -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \ +	      | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \ +	      | -cygwin32* | -pe* | -psos*) +	# Remember, each alternative MUST END IN *, to match a version number. +		;; +	# CYGNUS LOCAL +	-sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \ +	      | -windows* | -osx | -abug |  -netware* | -proelf | -os9* \ +	      | -macos* | -mpw* | -magic*) +		;; +	-mac*) +		os=`echo $os | sed -e 's|mac|macos|'` +		;; +	# END CYGNUS LOCAL +	-sunos5*) +		os=`echo $os | sed -e 's|sunos5|solaris2|'` +		;; +	-sunos6*) +		os=`echo $os | sed -e 's|sunos6|solaris3|'` +		;; +	-osfrose*) +		os=-osfrose +		;; +	-osf*) +		os=-osf +		;; +	-utek*) +		os=-bsd +		;; +	-dynix*) +		os=-bsd +		;; +	-acis*) +		os=-aos +		;; +	-386bsd)					# CYGNUS LOCAL +		os=-bsd +		;; +	-ctix* | -uts*) +		os=-sysv +		;; +	-ns2 ) +	        os=-nextstep2 +		;; +	# Preserve the version number of sinix5. +	-sinix5.*) +		os=`echo $os | sed -e 's|sinix|sysv|'` +		;; +	-sinix*) +		os=-sysv4 +		;; +	-triton*) +		os=-sysv3 +		;; +	-oss*) +		os=-sysv3 +		;; +	-svr4) +		os=-sysv4 +		;; +	-svr3) +		os=-sysv3 +		;; +	-sysvr4) +		os=-sysv4 +		;; +	# This must come after -sysvr4. +	-sysv*) +		;; +	-ose*)						# CYGNUS LOCAL +		os=-ose +		;; +	-es1800*)					# CYGNUS LOCAL +		os=-ose +		;; +	-xenix) +		os=-xenix +		;; +	-none) +		;; +	*) +		# Get rid of the `-' at the beginning of $os. +		os=`echo $os | sed 's/[^-]*-//'` +		echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2 +		exit 1 +		;; +esac +else + +# Here we handle the default operating systems that come with various machines. +# The value should be what the vendor currently ships out the door with their +# machine or put another way, the most popular os provided with the machine. + +# Note that if you're going to try to match "-MANUFACTURER" here (say, +# "-sun"), then you have to tell the case statement up towards the top +# that MANUFACTURER isn't an operating system.  Otherwise, code above +# will signal an error saying that MANUFACTURER isn't an operating +# system, and we'll never get to this point. + +case $basic_machine in +	*-acorn) +		os=-riscix1.2 +		;; +	arm*-semi) +		os=-aout +		;; +        pdp11-*) +		os=-none +		;; +	*-dec | vax-*) +		os=-ultrix4.2 +		;; +	m68*-apollo) +		os=-domain +		;; +	i386-sun) +		os=-sunos4.0.2 +		;; +	m68000-sun) +		os=-sunos3 +		# This also exists in the configure program, but was not the +		# default. +		# os=-sunos4 +		;; +	m68*-cisco)					# CYGNUS LOCAL +		os=-aout +		;; +	mips*-cisco)					# CYGNUS LOCAL +		os=-elf +		;; +	*-tti)	# must be before sparc entry or we get the wrong os. +		os=-sysv3 +		;; +	sparc-* | *-sun) +		os=-sunos4.1.1 +		;; +	*-ibm) +		os=-aix +		;; +	*-wec)						# CYGNUS LOCAL +		os=-proelf +		;; +	*-winbond)					# CYGNUS LOCAL +		os=-proelf +		;; +	*-oki)						# CYGNUS LOCAL +		os=-proelf +		;; +	*-hp) +		os=-hpux +		;; +	*-hitachi) +		os=-hiux +		;; +	i860-* | *-att | *-ncr | *-altos | *-motorola | *-convergent) +		os=-sysv +		;; +	*-cbm) +		os=-amigados +		;; +	*-dg) +		os=-dgux +		;; +	*-dolphin) +		os=-sysv3 +		;; +	m68k-ccur) +		os=-rtu +		;; +	m88k-omron*) +		os=-luna +		;; +	*-next ) +		os=-nextstep +		;; +	*-sequent) +		os=-ptx +		;; +	*-crds) +		os=-unos +		;; +	*-ns) +		os=-genix +		;; +	i370-*) +		os=-mvs +		;; +	*-next) +		os=-nextstep3 +		;; +        *-gould) +		os=-sysv +		;; +        *-highlevel) +		os=-bsd +		;; +	*-encore) +		os=-bsd +		;; +        *-sgi) +		os=-irix +		;; +        *-siemens) +		os=-sysv4 +		;; +	*-masscomp) +		os=-rtu +		;; +	*-rom68k)					# CYGNUS LOCAL +		os=-coff +		;; +	*-*bug)						# CYGNUS LOCAL +		os=-coff +		;; +	*-apple)					# CYGNUS LOCAL +		os=-macos +		;; +	*) +		os=-none +		;; +esac +fi + +# Here we handle the case where we know the os, and the CPU type, but not the +# manufacturer.  We pick the logical manufacturer. +vendor=unknown +case $basic_machine in +	*-unknown) +		case $os in +			-riscix*) +				vendor=acorn +				;; +			-sunos*) +				vendor=sun +				;; +			-bosx*)				# CYGNUS LOCAL +				vendor=bull +				;; +			-lynxos*) +				vendor=lynx +				;; +			-aix*) +				vendor=ibm +				;; +			-hpux*) +				vendor=hp +				;; +			-hiux*) +				vendor=hitachi +				;; +			-unos*) +				vendor=crds +				;; +			-dgux*) +				vendor=dg +				;; +			-luna*) +				vendor=omron +				;; +			-genix*) +				vendor=ns +				;; +			-mvs*) +				vendor=ibm +				;; +			-ptx*) +				vendor=sequent +				;; +			-vxworks*) +				vendor=wrs +				;; +			-aux*) +				vendor=apple +				;; +			-hms*)				# CYGNUS LOCAL +				vendor=hitachi +				;; +			-mpw* | -macos*)		# CYGNUS LOCAL +				vendor=apple +				;; +		esac +		basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"` +		;; +esac + +echo $basic_machine$os diff --git a/contrib/gdb/configure b/contrib/gdb/configure new file mode 100755 index 000000000000..f284be179c63 --- /dev/null +++ b/contrib/gdb/configure @@ -0,0 +1,1303 @@ +#!/bin/sh + +### WARNING: this file contains embedded tabs.  Do not run untabify on this file. + +# Configuration script +# Copyright (C) 1988, 90, 91, 92, 93, 94 Free Software Foundation, Inc. + +# This program 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 2 of the License, or +# (at your option) any later version. +#  +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +# This file was originally written by K. Richard Pixley. + +# +# Shell script to create proper links to machine-dependent files in +# preparation for compilation. +# +# If configure succeeds, it leaves its status in config.status. +# If configure fails after disturbing the status quo,  +#       config.status is removed. +# + +export PATH || (echo "OOPS, this isn't sh.  Desperation time.  I will feed myself to sh."; sh $0 $argv; kill $$) + +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. + +Makefile=Makefile +Makefile_in=Makefile.in +arguments= +build_alias= +cache_file= +cache_file_option= +configdirs= +exec_prefix= +exec_prefixoption= +fatal= +floating_point=default +gas=default +host_alias=NOHOST +host_makefile_frag= +moveifchange= +norecursion= +other_options= +package_makefile_frag= +prefix=/usr/local +progname= +program_prefix= +program_prefixoption= +program_suffix= +program_suffixoption= +program_transform_name= +program_transform_nameoption= +redirect=">/dev/null" +removing= +site= +site_makefile_frag= +site_option= +srcdir= +srctrigger= +subdirs= +target_alias=NOTARGET +target_makefile_frag= +undefs=NOUNDEFS +version="$Revision: 1.222.4.1 $" +x11=default + +### we might need to use some other shell than /bin/sh for running subshells +# +config_shell=${CONFIG_SHELL-/bin/sh} + +NO_EDIT="This file was generated automatically by configure.  Do not edit." + +## this is a little touchy and won't always work, but... +## +## if the argv[0] starts with a slash then it is an absolute name that can (and +## must) be used as is. +## +## otherwise, if argv[0] has no slash in it, we can assume that it is on the +## path.  Since PATH might include "." we also add `pwd` to the end of PATH. +## + +progname=$0 +# if PWD already has a value, it is probably wrong. +if [ -n "$PWD" ]; then PWD=`pwd`; fi + +case "${progname}" in +/*) ;; +*/*) ;; +*) +        PATH=$PATH:${PWD=`pwd`} ; export PATH +        ;; +esac + +# Loop over all args + +while : +do + +# Break out if there are no more args +	case $# in +	0) +		break +		;; +	esac + +# Get the first arg, and shuffle +	option=$1 +	shift + +# Make all options have two hyphens +	orig_option=$option	# Save original for error messages +	case $option in +	--*) ;; +	-*) option=-$option ;; +	esac +		 +# Split out the argument for options that take them +	case $option in +	--*=*) +		optarg=`echo $option | sed -e 's/^[^=]*=//'` +		arguments="$arguments $option" +		;; +# These options have mandatory values.  Since we didn't find an = sign, +# the value must be in the next argument +	--bu* | --cache* | --ex* | --ho* | --pre* | --program-p* | --program-s* | --program-t* | --si* | --sr* | --ta* | --tm* | --x-* | --bi* | --sb* | --li* | --da* | --sy* | --sh* | --lo* | --in* | --ol* | --ma*) +		optarg=$1 +		shift +		arguments="$arguments $option=$optarg" +		;; +	--v) +		arguments="$arguments -v" +		;; +	--*) +		arguments="$arguments $option" +		;; +	esac + +# Now, process the options +	case $option in + +	--build* | --bu*) +		case "$build_alias" in +		"") build_alias=$optarg ;; +		*) echo '***' Can only configure for one build machine at a time.  1>&2 +		   fatal=yes +		   ;; +		esac +		;; +	--cache*) +		cache_file=$optarg +		;; +	--disable-*) +		enableopt=`echo ${option} | sed 's:^--disable-:enable_:;s:-:_:g'` +		eval $enableopt=no +		disableoptions="$disableoptions $option" +		;; +	--enable-*) +		case "$option" in +		*=*)	;; +		*)	optarg=yes ;; +		esac + +		enableopt=`echo ${option} | sed 's:^--::;s:=.*$::;s:-:_:g'` +		eval "$enableopt='$optarg'" +		enableoptions="$enableoptions '$option'" +		;; +	--exec-prefix* | --ex*) +		exec_prefix=$optarg +		exec_prefixoption="--exec-prefix=$optarg" +		;; +	--gas | --g*) +		gas=yes +		;; +	--help | --he*) +		fatal=yes +		;; +	--host* | --ho*) +		case $host_alias in +		NOHOST) host_alias=$optarg ;; +		*) echo '***' Can only configure for one host at a time.  1>&2 +		   fatal=yes +		   ;; +		esac +		;; +	--nfp | --nf*) +		floating_point=no +		floating_pointoption="--nfp" +		;; +	--norecursion | --no*) +		norecursion=yes +		;; +	--prefix* | --pre*) +		prefix=$optarg +		prefixoption="--prefix=$optarg" +		;; +	--program-prefix* | --program-p*) +		program_prefix=$optarg +		program_prefixoption="--program-prefix=$optarg" +		;; +	--program-suffix* | --program-s*) +		program_suffix=$optarg +		program_suffixoption="--program-suffix=$optarg" +		;; +	--program-transform-name* | --program-t*) +		# Double any backslashes or dollar signs in the argument +		program_transform_name="${program_transform_name} -e `echo ${optarg} | sed -e 's/\\\\/\\\\\\\\/g' -e 's/\\\$/$$/g'`" +		program_transform_nameoption="${program_transform_nameoption} --program-transform-name='$optarg'" +		;; +	--rm) +		removing=--rm +		;; +	--silent | --sil* | --quiet | --q*) +		redirect=">/dev/null" +		verbose=--silent +		;; +	--site* | --sit*) +		site=$optarg +		site_option="--site=$optarg" +		;; +	--srcdir*/ | --sr*/) +                # Remove trailing slashes.  Otherwise, when the file name gets +                # bolted into an object file as debug info, it has two slashes +                # in it.  Ordinarily this is ok, but emacs takes double slash +                # to mean "forget the first part". +		srcdir=`echo $optarg | sed -e 's:/$::'` +		;; +	--srcdir* | --sr*) +		srcdir=$optarg +		;; +	--target* | --ta*) +		case $target_alias in +		NOTARGET) target_alias=$optarg ;; +		*) echo '***' Can only configure for one target at a time.  1>&2 +		   fatal=yes +		   ;; +		esac +		;; +	--tmpdir* | --tm*) +		TMPDIR=$optarg +		tmpdiroption="--tmpdir=$optarg" +		;; +	--verbose | --v | --verb*) +		redirect= +		verbose=--verbose +		;; +	--version | --V | --vers*) +		echo "This is Cygnus Configure version" `echo ${version} | sed 's/[ $:]//g'` +		exit 0 +		;; +	--with-*) +		case "$option" in +		*=*)	;; +		*)	optarg=yes ;; +		esac + +		withopt=`echo ${option} | sed 's:^--::;s:=.*$::;s:-:_:g'` +		eval $withopt="$optarg" +		withoptions="$withoptions $option" +		;; +	--without-*) +		withopt=`echo ${option} | sed 's:^--::;s:out::;s:-:_:g'` +		eval $withopt=no +		withoutoptions="$withoutoptions $option" +		;; +	--x)	with_x=yes +		withoptions="$withoptions --with-x" +		;; +	--x-i* | --x-l*) other_options="$other_options $orig_option" +		;; +	--bi* | --sb* | --li* | --da* | --sy* | --sh* | --lo* | --in* | --ol* | --ma*) +		# These options were added to autoconf for emacs. +		;; +	--*) +		echo "configure: Unrecognized option: \"$orig_option\"; use --help for usage." >&2 +		exit 1 +		;; +	*) +		case $undefs in +		NOUNDEFS) undefs=$option ;; +		*) echo '***' Can only configure for one host and one target at a time.  1>&2 +		   fatal=yes +		   ;; +		esac +		;; +	esac +done + +# process host and target + +# Do some error checking and defaulting for the host and target type. +# The inputs are: +#    configure --host=HOST --target=TARGET UNDEFS +# +# The rules are: +# 1. You aren't allowed to specify --host, --target, and undefs at the +#    same time. +# 2. Host defaults to undefs. +# 3. If undefs is not specified, then host defaults to the current host, +#    as determined by config.guess. +# 4. Target defaults to undefs. +# 5. If undefs is not specified, then target defaults to host. + +case "${fatal}" in +"") +	# Make sure that host, target & undefs aren't all specified at the +	# same time. +	case $host_alias---$target_alias---$undefs in +	NOHOST---*---* | *---NOTARGET---* | *---*---NOUNDEFS) +		;; +	*) echo '***' Can only configure for one host and one target at a time.  1>&2 +	   fatal=yes +	   break 2 +		;; +	esac + +	# Now, do defaulting for host. +	case $host_alias in +	NOHOST) +		case $undefs in +		NOUNDEFS) +			# Neither --host option nor undefs were present. +			# Call config.guess. +			guesssys=`echo ${progname} | sed 's/configure$/config.guess/'` +			if host_alias=`${guesssys}` +			then +				# If the string we are going to use for +				# the target is a prefix of the string +				# we just guessed for the host, then +				# assume we are running native, and force +				# the same string for both target and host. +				case $target_alias in +				NOTARGET) ;; +				*) +					if expr $host_alias : $target_alias >/dev/null +					then +						host_alias=$target_alias +					fi +					;; +				esac +				echo "Configuring for a ${host_alias} host." 1>&2 +				arguments="--host=$host_alias $arguments" +			else +				echo 'Config.guess failed to determine the host type.  You need to specify one.' 1>&2 +				fatal=yes +			fi +			;; +		*) +			host_alias=$undefs +			arguments="--host=$host_alias $arguments" +			undefs=NOUNDEFS +			;; +		esac +	esac + +	# Do defaulting for target.  If --target option isn't present, default +	# to undefs.  If undefs isn't present, default to host. +	case $target_alias in +	NOTARGET) +		case $undefs in +		NOUNDEFS) +			target_alias=$host_alias +			;; +		*) +			target_alias=$undefs +			arguments="--target=$target_alias $arguments" +			;; +		esac +	esac +	;; +*) ;; +esac + +if [ -n "${fatal}" -o "${host_alias}" = "help" ] ; then +	exec 1>&2 +	echo Usage: configure [OPTIONS] [HOST] +	echo +	echo Options: [defaults in brackets] +	echo ' --prefix=MYDIR		 install into MYDIR [/usr/local]' +	echo ' --exec-prefix=MYDIR	 install host-dependent files into MYDIR [/usr/local]' +	echo ' --help			 print this message [normal config]' +	echo ' --build=BUILD		 configure for building on BUILD [BUILD=HOST]' +	echo ' --host=HOST		 configure for HOST [determined via config.guess]' +	echo ' --norecursion		 configure this directory only [recurse]' +	echo ' --program-prefix=FOO	 prepend FOO to installed program names [""]' +	echo ' --program-suffix=FOO	 append FOO to installed program names [""]' +	echo ' --program-transform-name=P transform installed names by sed pattern P [""]' +	echo ' --site=SITE		 configure with site-specific makefile for SITE' +	echo ' --srcdir=DIR		 find the sources in DIR [. or ..]' +	echo ' --target=TARGET	 configure for TARGET [TARGET=HOST]' +	echo ' --tmpdir=TMPDIR	 create temporary files in TMPDIR [/tmp]' +	echo ' --nfp			 configure for software floating point [hard float]' +	echo ' --with-FOO, --with-FOO=BAR package FOO is available (parameter BAR)' +	echo ' --without-FOO		 package FOO is NOT available' +	echo ' --enable-FOO, --enable-FOO=BAR include feature FOO (parameter BAR)' +	echo ' --disable-FOO		 do not include feature FOO' +	echo +	echo 'Where HOST and TARGET are something like "sparc-sunos", "mips-sgi-irix5", etc.' +	echo +	if [ -r config.status ] ; then +		cat config.status +	fi + +	exit 1 +fi + +configsub=`echo ${progname} | sed 's/configure$/config.sub/'` +moveifchange=`echo ${progname} | sed 's/configure$/move-if-change/'` + +# this is a hack.  sun4 must always be a valid host alias or this will fail. +if ${configsub} sun4 >/dev/null 2>&1 ; then +        true +else +        echo '***' cannot find config.sub.  1>&2 +        exit 1 +fi + +touch config.junk +if ${moveifchange} config.junk config.trash ; then +        true +else +        echo '***' cannot find move-if-change.  1>&2 +        exit 1 +fi +rm -f config.junk config.trash + +case "${srcdir}" in +"") +        if [ -r configure.in ] ; then +                srcdir=. +        else +                if [ -r ${progname}.in ] ; then +                        srcdir=`echo ${progname} | sed 's:/configure$::'` +                else +                        echo '***' "Can't find configure.in.  Try using --srcdir=some_dir"  1>&2 +                        exit 1 +                fi +        fi +        ;; +*) +	# Set srcdir to "." if that's what it is. +	# This is important for multilib support. +	if [ ! -d ${srcdir} ] ; then +		echo "Invalid source directory ${srcdir}" >&2 +		exit 1 +	fi +	pwd=`pwd` +	srcpwd=`cd ${srcdir} ; pwd` +	if [ "${pwd}" = "${srcpwd}" ] ; then +		srcdir=. +	fi +esac + +### warn about some conflicting configurations. + +case "${srcdir}" in +".") ;; +*) +        if [ -f ${srcdir}/config.status ] ; then +                echo '***' Cannot configure here in \"${PWD=`pwd`}\" when \"${srcdir}\" is currently configured. 1>&2 +                exit 1 +        fi +esac + +# default exec_prefix +case "${exec_prefixoption}" in +"") exec_prefix="\$(prefix)" ;; +*) ;; +esac + +### break up ${srcdir}/configure.in. +case "`grep '^# per\-host:' ${srcdir}/configure.in`" in +"") +        echo '***' ${srcdir}/configure.in has no \"per-host:\" line. 1>&2 +	# Check for a directory that's been converted to use autoconf since +	# it was last configured. +	if grep AC_OUTPUT ${srcdir}/configure.in >/dev/null ; then +	  echo '***' Hmm, looks like this directory has been autoconfiscated. 1>&2 +	  if [ -r ${srcdir}/configure ] ; then +	    echo '***' Running the local configure script. 1>&2 +	    case "${cache_file}" in +	    "") cache_file_option= ;; +	    *)  cache_file_option="--cache-file=${cache_file}" ;; +	    esac +	    srcdiroption="--srcdir=${srcdir}" +	    case "${build_alias}" in +	    "") buildopt= ;; +	    *)  buildopt="--build=${build_alias}" ;; +	    esac +	    eval exec ${config_shell} ${srcdir}/configure ${verbose} \ +		${buildopt} --host=${host_alias} --target=${target_alias} \ +		${prefixoption} ${tmpdiroption} ${exec_prefixoption} \ +		${srcdiroption} \ +		${program_prefixoption} ${program_suffixoption} \ +		${program_transform_nameoption} ${site_option} \ +		${withoptions} ${withoutoptions} \ +		${enableoptions} ${disableoptions} ${floating_pointoption} \ +		${cache_file_option} ${removing} ${other_options} ${redirect} +	  else +	    echo '***' There is no configure script present though. 1>&2 +	  fi +	fi +        exit 1 +        ;; +*) ;; +esac + +case "`grep '^# per\-target:' ${srcdir}/configure.in`" in +"") +        echo '***' ${srcdir}/configure.in has no \"per-target:\" line. 1>&2 +        exit 1 +        ;; +*) ;; +esac + +case "${TMPDIR}" in +"") TMPDIR=/tmp ; export TMPDIR ;; +*) ;; +esac + +# keep this filename short for &%*%$*# 14 char file names +tmpfile=${TMPDIR}/cONf$$ +# Note that under many versions of sh a trap handler for 0 will *override* any +# exit status you explicitly specify!  At this point, the only non-error exit +# is at the end of the script; these actions are duplicated there, minus +# the "exit 1".  Don't use "exit 0" anywhere after this without resetting the +# trap handler, or you'll lose. +trap "rm -f Makefile.tem ${tmpfile}.com ${tmpfile}.tgt ${tmpfile}.hst ${tmpfile}.pos; exit 1" 0 1 2 15 + +# split ${srcdir}/configure.in into common, per-host, per-target, +# and post-target parts.  Post-target is optional. +sed -e '/^# per\-host:/,$d' ${srcdir}/configure.in > ${tmpfile}.com +sed -e '1,/^# per\-host:/d' -e '/^# per\-target:/,$d' ${srcdir}/configure.in > ${tmpfile}.hst +if grep '^# post-target:' ${srcdir}/configure.in >/dev/null ; then +  sed -e '1,/^# per\-target:/d' -e '/^# post\-target:/,$d' ${srcdir}/configure.in > ${tmpfile}.tgt +  sed -e '1,/^# post\-target:/d' ${srcdir}/configure.in > ${tmpfile}.pos +else +  sed -e '1,/^# per\-target:/d' ${srcdir}/configure.in > ${tmpfile}.tgt +  echo >${tmpfile}.pos +fi + +### do common part of configure.in + +. ${tmpfile}.com + +# some sanity checks on configure.in +case "${srctrigger}" in +"") +        echo '***' srctrigger not set in ${PWD=`pwd`}/configure.in.  1>&2 +        exit 1 +        ;; +*) ;; +esac + +case "${build_alias}" in +"") +	if result=`${config_shell} ${configsub} ${host_alias}` ; then +	    build_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +	    build_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +	    build_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +	    build=${build_cpu}-${build_vendor}-${build_os} +	    build_alias=${host_alias} +	fi +	;; +*) +	if result=`${config_shell} ${configsub} ${build_alias}` ; then +	    buildopt="--build=${build_alias}" +	    build_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +	    build_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +	    build_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +	    build=${build_cpu}-${build_vendor}-${build_os} +	else +	    echo "Unrecognized build system name ${build_alias}." 1>&2 +	    exit 1 +	fi +	;; +esac + +if result=`${config_shell} ${configsub} ${host_alias}` ; then +    true +else +    echo "Unrecognized host system name ${host_alias}." 1>&2 +    exit 1 +fi +host_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +host_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +host_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +host=${host_cpu}-${host_vendor}-${host_os} + +. ${tmpfile}.hst + +if result=`${config_shell} ${configsub} ${target_alias}` ; then +    true +else +    echo "Unrecognized target system name ${target_alias}." 1>&2 +    exit 1 +fi +target_cpu=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +target_vendor=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +target_os=`echo $result | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +target=${target_cpu}-${target_vendor}-${target_os} + +. ${tmpfile}.tgt + +# Find the source files, if location was not specified. +case "${srcdir}" in +"") +        srcdirdefaulted=1 +        srcdir=. +        if [ ! -r ${srctrigger} ] ; then +                srcdir=.. +        fi +        ;; +*) ;; +esac + +if [ ! -r ${srcdir}/${srctrigger} ] ; then +        case "${srcdirdefaulted}" in +        "") echo '***' "${progname}: Can't find ${srcname} sources in ${PWD=`pwd`}/${srcdir}" 1>&2 ;; +        *)  echo '***' "${progname}: Can't find ${srcname} sources in ${PWD=`pwd`}/. or ${PWD=`pwd`}/.." 1>&2 ;; +        esac + +        echo '***' \(At least ${srctrigger} is missing.\) 1>&2 +        exit 1 +fi + +# Some systems (e.g., one of the i386-aix systems the gas testers are +# using) don't handle "\$" correctly, so don't use it here. +tooldir='$(exec_prefix)'/${target_alias} + +if [ "${host_alias}" != "${target_alias}" ] ; then +    if [ "${program_prefixoption}" = "" ] ; then +        if [ "${program_suffixoption}" = "" ] ; then  +            if [ "${program_transform_nameoption}" = "" ] ; then +                program_prefix=${target_alias}- ; +            fi +        fi +    fi +fi + +# Merge program_prefix and program_suffix onto program_transform_name. +# (program_suffix used to use $, but it's hard to preserve $ through both +# make and sh.) +if [ "${program_suffix}" != "" ] ; then +    program_transform_name="-e s,\\\\(.*\\\\),\\\\1${program_suffix}, ${program_transform_name}" +fi + +if [ "${program_prefix}" != "" ] ; then +    program_transform_name="-e s,^,${program_prefix}, ${program_transform_name}" +fi + +# If CC and CXX are not set in the environment, and the Makefile +# exists, try to extract them from it.  This is to handle running +# ./config.status by hand. +if [ -z "${CC}" -a -r Makefile ]; then +  sed -n -e ':loop +/\\$/ N +/\\$/ b loop +s/\\\n//g +/^CC[ 	]*=/ s/CC[ 	]*=[ 	]*\(.*\)/\1/p' < Makefile > Makefile.cc +  CC=`tail -1 Makefile.cc` +  rm -f Makefile.cc +fi + +if [ -z "${CXX}" -a -r Makefile ]; then +  sed -n -e ':loop +/\\$/ N +/\\$/ b loop +s/\\\n//g +/^CXX[ 	]*=/ s/CXX[ 	]*=[ 	]*\(.*\)/\1/p' < Makefile > Makefile.cc +  CXX=`tail -1 Makefile.cc` +  rm -f Makefile.cc +fi + +# Generate a default definition for YACC.  This is used if the makefile can't +# locate bison or byacc in objdir. + +for prog in 'bison -y' byacc yacc +do +  set dummy $prog; tmp=$2 +  IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +  for dir in $PATH; do +    test -z "$dir" && dir=. +    if test -f $dir/$tmp; then +      DEFAULT_YACC="$prog" +      break +    fi +  done +  IFS="$save_ifs" + +  test -n "$DEFAULT_YACC" && break +done + +# Generate a default definition for LEX.  This is used if the makefile can't +# locate flex in objdir. + +for prog in flex lex +do +  set dummy $prog; tmp=$2 +  IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +  for dir in $PATH; do +    test -z "$dir" && dir=. +    if test -f $dir/$tmp; then +      DEFAULT_LEX="$prog" +      break +    fi +  done +  IFS="$save_ifs" + +  test -n "$DEFAULT_LEX" && break +done + +if [ "${build}" != "${host}" ]; then +  # If we are doing a Canadian Cross, in which the host and build systems +  # are not the same, we set reasonable default values for the tools. + +  tools="AR AR_FOR_TARGET AS AS_FOR_TARGET BISON CC_FOR_BUILD" +  tools="${tools} CC_FOR_TARGET CXX_FOR_TARGET" +  tools="${tools} DLLTOOL DLLTOOL_FOR_TARGET HOST_PREFIX" +  tools="${tools} HOST_PREFIX_1 LD LD_FOR_TARGET LEX MAKEINFO NM" +  tools="${tools} NM_FOR_TARGET RANLIB RANLIB_FOR_TARGET" + +  for var in ${tools}; do +    if [ -z "`eval 'echo $'"${var}"`" -a -r Makefile ]; then +      sed -n -e ':loop +/\\$/ N +/\\$/ b loop +s/\\\n//g +/^'"${var}"'[ 	]*=/ s/'"${var}"'[ 	]*=[ 	]*\(.*\)/\1/p' \ +	< Makefile > Makefile.v +      t=`tail -1 Makefile.v` +      if [ -n "${t}" ]; then +	eval "${var}='${t}'" +      fi +      rm -f Makefile.v +    fi +  done + +  AR=${AR-${host_alias}-ar} +  AR_FOR_TARGET=${AR_FOR_TARGET-${target_alias}-ar} +  AS=${AS-${host_alias}-as} +  AS_FOR_TARGET=${AS_FOR_TARGET-${target_alias}-as} +  CC=${CC-${host_alias}-gcc} +  CXX=${CXX-${host_alias}-gcc} +  CC_FOR_BUILD=${CC_FOR_BUILD-gcc} +  CC_FOR_TARGET=${CC_FOR_TARGET-${target_alias}-gcc} +  CXX_FOR_TARGET=${CXX_FOR_TARGET-${target_alias}-gcc} +  DLLTOOL=${DLLTOOL-${host_alias}-dlltool} +  DLLTOOL_FOR_TARGET=${DLLTOOL_FOR_TARGET-${target_alias}-dlltool} +  HOST_PREFIX=${build_alias}- +  HOST_PREFIX_1=${build_alias}- +  LD=${LD-${host_alias}-ld} +  LD_FOR_TARGET=${LD_FOR_TARGET-${target_alias}-ld} +  MAKEINFO=${MAKEINFO-makeinfo} +  NM=${NM-${host_alias}-nm} +  NM_FOR_TARGET=${NM_FOR_TARGET-${target_alias}-nm} +  RANLIB=${RANLIB-${host_alias}-ranlib} +  RANLIB_FOR_TARGET=${RANLIB_FOR_TARGET-${target_alias}-ranlib} + +  if [ -z "${BISON}" ]; then +    IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +    for dir in $PATH; do +      test -z "$dir" && dir=. +      if test -f $dir/byacc; then +	BISON=byacc +	break +      fi +      if test -f $dir/bison; then +	BISON=bison +	break +      fi +      if test -f $dir/yacc; then +	BISON=yacc +	break +      fi +    done +    IFS="$save_ifs" +    BISON=${BISON-bison} +  fi + +  if [ -z "${LEX}" ]; then +    IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +    for dir in $PATH; do +      test -z "$dir" && dir=. +      if test -f $dir/flex; then +	LEX=flex +	break +      fi +      if test -f $dir/lex; then +	LEX=lex +	break +      fi +    done +    IFS="$save_ifs" +    LEX=${LEX-flex} +  fi + +  # Export variables which autoconf might try to set. +  export AS +  export AR +  export CC_FOR_BUILD +  export DLLTOOL +  export LD +  export NM +  export RANLIB +else +  # If CC is still not set, try to get gcc. +  if [ -z "${CC}" ]; then +    IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +    for dir in $PATH; do +      test -z "$dir" && dir=. +      if test -f $dir/gcc; then +	CC="gcc -O2" +	break +      fi +    done +    IFS="$save_ifs" +    CC=${CC-cc} +  fi + +  CXX=${CXX-"gcc"} +fi + +export CC +export CXX + +case "$host" in +	*go32*) +	    enable_gdbtk=no ;; +esac + +# Determine whether gdb needs tk/tcl or not. +if [ "$enable_gdbtk" != "no" ]; then +	GDB_TK="all-tcl all-tk" +else +	GDB_TK="" +fi + +for subdir in . ${subdirs} ; do + +    # ${subdir} is relative path from . to the directory we're currently +    # configuring. +    # ${invsubdir} is inverse of ${subdir), *with* trailing /, if needed. +    invsubdir=`echo ${subdir}/ | sed -e 's|\./||g' -e 's|[^/]*/|../|g'` + +    ### figure out what to do with srcdir +    case "${srcdir}" in +        ".")  # no -srcdir option.  We're building in place. +                makesrcdir=. ;; +        /*) # absolute path +                makesrcdir=`echo ${srcdir}/${subdir} | sed -e 's|/\.$||'` +                ;; +        *) # otherwise relative +                case "${subdir}" in +                .) makesrcdir=${srcdir} ;; +                *) makesrcdir=${invsubdir}${srcdir}/${subdir} ;; +                esac +                ;; +    esac + +    if [ "${subdir}/" != "./" ] ; then +        Makefile=${subdir}/Makefile +    fi + +    if [ ! -d ${subdir} ] ; then +        if mkdir ${subdir} ; then +                true +        else +                echo '***' "${progname}: could not make ${PWD=`pwd`}/${subdir}" 1>&2 +                exit 1 +        fi +    fi + +    case "${removing}" in +    "") +        case "${subdir}" in +        .) ;; +        *) eval echo Building in ${subdir} ${redirect} ;; +        esac + +        # FIXME Should this be done recursively ??? (Useful for e.g. gdbtest) +        # 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. +        configlinks="${links}" +        if [ -r ${subdir}/config.status ] ; then +                mv -f ${subdir}/config.status ${subdir}/config.back +        fi +        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}/${file} ] ; then +                        echo '***' "${progname}: cannot create a link \"${link}\"," 1>&2 +                        echo '***' "since the file \"${srcdir}/${file}\" does not exist." 1>&2 +                        exit 1 +                fi + +                ${remove} -f ${link} +		# Make a symlink if possible, otherwise try a hard link +		if ${symbolic_link} ${srcdir}/${file} ${link} >/dev/null 2>&1 ; then +			true +		else +			# We need to re-remove the file because Lynx leaves a  +			# very strange directory there when it fails an NFS symlink. +			${remove} -r -f ${link} +			${hard_link} ${srcdir}/${file} ${link} +		fi +                if [ ! -r ${link} ] ; then +                        echo '***' "${progname}: unable to link \"${link}\" to \"${srcdir}/${file}\"." 1>&2 +                        exit 1 +                fi + +                echo "Linked \"${link}\" to \"${srcdir}/${file}\"." +        done + +        # Create a .gdbinit file which runs the one in srcdir +        # and tells GDB to look there for source files. + +        if [ -r ${srcdir}/${subdir}/.gdbinit ] ; then +                case ${srcdir} in +                .) ;; +                *) cat > ${subdir}/.gdbinit <<EOF +# ${NO_EDIT} +dir ${makesrcdir} +dir . +source ${makesrcdir}/.gdbinit +EOF +                        ;; +                esac +        fi + +        # Install a makefile, and make it set VPATH +        # if necessary so that the sources are found. +        # Also change its value of srcdir. +        # NOTE: Makefile generation constitutes the majority of the time in configure.  Hence, this section has +        # been somewhat optimized and is perhaps a bit twisty. + +        # code is order so as to try to sed the smallest input files we know. + +        # the four makefile fragments MUST end up in the resulting Makefile in this order:  +        # package, target, host, and site.  so do these separately because I don't trust the +        #  order of sed -e expressions. + +        if [ -f ${srcdir}/${subdir}/${Makefile_in} ] ; then + +            # Conditionalize for this site from "Makefile.in" (or whatever it's called) into Makefile.tem +            rm -f ${subdir}/Makefile.tem +              case "${site}" in +              "") cp ${srcdir}/${subdir}/${Makefile_in} ${subdir}/Makefile.tem ;; +              *) +                      site_makefile_frag=${srcdir}/config/ms-${site} + +                      if [ -f ${site_makefile_frag} ] ; then +                              sed -e "/^####/  r ${site_makefile_frag}" ${srcdir}/${subdir}/${Makefile_in} \ +                                      > ${subdir}/Makefile.tem +                      else +                              cp ${srcdir}/${subdir}/${Makefile_in} ${subdir}/Makefile.tem +                              site_makefile_frag= +                      fi +                      ;; +            esac +            # working copy now in ${subdir}/Makefile.tem + +            # Conditionalize the makefile for this host. +            rm -f ${Makefile} +            case "${host_makefile_frag}" in +              "") mv ${subdir}/Makefile.tem ${Makefile} ;; +              *) +                      if [ ! -f ${host_makefile_frag} ] ; then +                              host_makefile_frag=${srcdir}/${host_makefile_frag} +                      fi +                      if [ -f ${host_makefile_frag} ] ; then +                              sed -e "/^####/  r ${host_makefile_frag}" ${subdir}/Makefile.tem > ${Makefile} +                      else +                              echo '***' Expected host makefile fragment \"${host_makefile_frag}\" 1>&2 +                              echo '***' is missing in ${PWD=`pwd`}. 1>&2 +                              mv ${subdir}/Makefile.tem ${Makefile} +                      fi +            esac +            # working copy now in ${Makefile} + +            # Conditionalize the makefile for this target. +            rm -f ${subdir}/Makefile.tem +            case "${target_makefile_frag}" in +              "") mv ${Makefile} ${subdir}/Makefile.tem ;; +              *) +                      if [ ! -f ${target_makefile_frag} ] ; then +                              target_makefile_frag=${srcdir}/${target_makefile_frag} +                      fi +                      if [ -f ${target_makefile_frag} ] ; then +                              sed -e "/^####/  r ${target_makefile_frag}" ${Makefile} > ${subdir}/Makefile.tem +                      else +                              mv ${Makefile} ${subdir}/Makefile.tem +                              target_makefile_frag= +                      fi +                      ;; +            esac +            # real copy now in ${subdir}/Makefile.tem + +            # Conditionalize the makefile for this package. +            rm -f ${Makefile} +            case "${package_makefile_frag}" in +              "") mv ${subdir}/Makefile.tem ${Makefile} ;; +              *) +                      if [ ! -f ${package_makefile_frag} ] ; then +                              package_makefile_frag=${srcdir}/${package_makefile_frag} +                      fi +                      if [ -f ${package_makefile_frag} ] ; then +                              sed -e "/^####/  r ${package_makefile_frag}" ${subdir}/Makefile.tem > ${Makefile} +			      rm -f ${subdir}/Makefile.tem +                      else +                              echo '***' Expected package makefile fragment \"${package_makefile_frag}\" 1>&2 +                              echo '***' is missing in ${PWD=`pwd`}. 1>&2 +                              mv ${subdir}/Makefile.tem ${Makefile} +                      fi +            esac +            # working copy now in ${Makefile} + +            mv ${Makefile} ${subdir}/Makefile.tem + +            # real copy now in ${subdir}/Makefile.tem + +            # prepend warning about editting, and a bunch of variables. +            rm -f ${Makefile} +            cat > ${Makefile} <<EOF +# ${NO_EDIT} +VPATH = ${makesrcdir} +links = ${configlinks} +host_alias = ${host_alias} +host_cpu = ${host_cpu} +host_vendor = ${host_vendor} +host_os = ${host_os} +host_canonical = ${host_cpu}-${host_vendor}-${host_os} +target_alias = ${target_alias} +target_cpu = ${target_cpu} +target_vendor = ${target_vendor} +target_os = ${target_os} +target_canonical = ${target_cpu}-${target_vendor}-${target_os} +EOF +	    case "${build}" in +	      "") ;; +	      *)  cat >> ${Makefile} << EOF +build_alias = ${build_alias} +build_cpu = ${build_cpu} +build_vendor = ${build_vendor} +build_os = ${build_os} +build_canonical = ${build_cpu}-${build_vendor}-${build_os} +EOF +	    esac + +            case "${package_makefile_frag}" in +              "") ;; +              /*) echo package_makefile_frag = ${package_makefile_frag} >>${Makefile} ;; +              *)  echo package_makefile_frag = ${invsubdir}${package_makefile_frag} >>${Makefile} ;; +            esac + +            case "${target_makefile_frag}" in +              "") ;; +              /*) echo target_makefile_frag = ${target_makefile_frag} >>${Makefile} ;; +              *)  echo target_makefile_frag = ${invsubdir}${target_makefile_frag} >>${Makefile} ;; +            esac + +            case "${host_makefile_frag}" in +              "") ;; +              /*) echo host_makefile_frag = ${host_makefile_frag} >>${Makefile} ;; +              *)  echo host_makefile_frag = ${invsubdir}${host_makefile_frag} >>${Makefile} ;; +            esac + +            if [ "${site_makefile_frag}" != "" ] ; then +                echo site_makefile_frag = ${invsubdir}${site_makefile_frag} >>${Makefile} +            fi  + +            # reset prefix, exec_prefix, srcdir, SUBDIRS, NONSUBDIRS, +            # remove any form feeds. +            if [ -z "${subdirs}" ]; then +                rm -f ${subdir}/Makefile.tem2 +                sed -e "s:^SUBDIRS[ 	]*=.*$:SUBDIRS = ${configdirs}:" \ +                    -e "s:^NONSUBDIRS[ 	]*=.*$:NONSUBDIRS = ${noconfigdirs}:" \ +                    ${subdir}/Makefile.tem > ${subdir}/Makefile.tem2 +                rm -f ${subdir}/Makefile.tem +                mv ${subdir}/Makefile.tem2 ${subdir}/Makefile.tem +            fi +            sed -e "s:^prefix[ 	]*=.*$:prefix = ${prefix}:" \ +                    -e "s:^exec_prefix[ 	]*=.*$:exec_prefix = ${exec_prefix}:" \ +		    -e "/^CC[ 	]*=/{ +			:loop1 +			/\\\\$/ N +			/\\\\$/ b loop1 +			s/\\\\\\n//g +			s%^CC[ 	]*=.*$%CC = ${CC}% +			}" \ +		    -e "/^CXX[ 	]*=/{ +			:loop2 +			/\\\\$/ N +			/\\\\$/ b loop2 +			s/\\\\\\n//g +			s%^CXX[ 	]*=.*$%CXX = ${CXX}% +			}" \ +		    -e "s:^SHELL[	 ]*=.*$:SHELL = ${config_shell}:" \ +		    -e "s:^GDB_TK[	 ]*=.*$:GDB_TK = ${GDB_TK}:" \ +                    -e "s:^srcdir[ 	]*=.*$:srcdir = ${makesrcdir}:" \ +                    -e "s///" \ +                    -e "s:^program_prefix[ 	]*=.*$:program_prefix = ${program_prefix}:" \ +                    -e "s:^program_suffix[ 	]*=.*$:program_suffix = ${program_suffix}:" \ +                    -e "s:^program_transform_name[ 	]*=.*$:program_transform_name = ${program_transform_name}:" \ +                    -e "s:^tooldir[ 	]*=.*$:tooldir = ${tooldir}:" \ +		    -e "s:^DEFAULT_YACC[	 ]*=.*$:DEFAULT_YACC = ${DEFAULT_YACC}:" \ +		    -e "s:^DEFAULT_LEX[	 ]*=.*$:DEFAULT_LEX = ${DEFAULT_LEX}:" \ +                    ${subdir}/Makefile.tem >> ${Makefile} + +	    # If this is a Canadian Cross, preset the values of many more +	    # tools. +	    if [ "${build}" != "${host}" ]; then +		for var in ${tools}; do +		    val=`eval 'echo $'"${var}"` +		    sed -e "/^${var}[ 	]*=/{ +			   :loop1 +			   /\\\\$/ N +			   /\\\\$/ b loop1 +			   s/\\\\\\n//g +			   s%^${var}[ 	]*=.*$%${var} = ${val}% +			   }" ${Makefile} > ${Makefile}.tem +		    mv -f ${Makefile}.tem ${Makefile} +		done +	    fi + +            # final copy now in ${Makefile} + +        else +           echo "No Makefile.in found in ${srcdir}/${subdir}, unable to configure" 1>&2 +        fi + +        rm -f ${subdir}/Makefile.tem + +        case "${host_makefile_frag}" in +        "") using= ;; +        *) using="and \"${host_makefile_frag}\"" ;; +        esac + +        case "${target_makefile_frag}" in +        "") ;; +        *) using="${using} and \"${target_makefile_frag}\"" ;; +        esac + +        case "${site_makefile_frag}" in +        "") ;; +        *) using="${using} and \"${site_makefile_frag}\"" ;; +        esac + +        newusing=`echo "${using}" | sed 's/and/using/'` +        using=${newusing} +        echo "Created \"${Makefile}\" in" ${PWD=`pwd`} ${using} + +        . ${tmpfile}.pos + +        # describe the chosen configuration in config.status. +        # Make that file a shellscript which will reestablish +        # the same configuration.  Used in Makefiles to rebuild +        # Makefiles. + +        case "${norecursion}" in +        "") arguments="${arguments} --norecursion" ;; +        *) ;; +        esac + +        if [ ${subdir} = . ] ; then +            echo "#!/bin/sh +# ${NO_EDIT} +# This directory was configured as follows: +${progname}" ${arguments}  " +# ${using}" > ${subdir}/config.new +        else +            echo "#!/bin/sh +# ${NO_EDIT} +# This directory was configured as follows: +cd ${invsubdir} +${progname}" ${arguments}  " +# ${using}" > ${subdir}/config.new +        fi +        chmod a+x ${subdir}/config.new +        if [ -r ${subdir}/config.back ] ; then +                mv -f ${subdir}/config.back ${subdir}/config.status +        fi +        ${moveifchange} ${subdir}/config.new ${subdir}/config.status +        ;; + +    *)  rm -f ${Makefile} ${subdir}/config.status ${links} ;; +    esac +done + +# If there are subdirectories, then recur.  +if [ -z "${norecursion}" -a -n "${configdirs}" ] ; then  +        for configdir in ${configdirs} ; do + +                if [ -d ${srcdir}/${configdir} ] ; then +                        eval echo Configuring ${configdir}... ${redirect} +                        case "${srcdir}" in +                        ".") ;; +                        *) +                                if [ ! -d ./${configdir} ] ; then +                                        if mkdir ./${configdir} ; then +                                                true +                                        else +                                                echo '***' "${progname}: could not make ${PWD=`pwd`}/${configdir}" 1>&2 +                                                exit 1 +                                        fi +                                fi +                                ;; +                        esac + +                        POPDIR=${PWD=`pwd`} +                        cd ${configdir}  + +### figure out what to do with srcdir +                        case "${srcdir}" in +                        ".") newsrcdir=${srcdir} ;; # no -srcdir option.  We're building in place. +                        /*) # absolute path +                                newsrcdir=${srcdir}/${configdir} +                                srcdiroption="--srcdir=${newsrcdir}" +                                ;; +                        *) # otherwise relative +                                newsrcdir=../${srcdir}/${configdir} +                                srcdiroption="--srcdir=${newsrcdir}" +                                ;; +                        esac + +			# Handle --cache-file=../XXX +			case "${cache_file}" in +			"") # empty +				;; +			/*) # absolute path +				cache_file_option="--cache-file=${cache_file}" +				;; +			*) # relative path +				cache_file_option="--cache-file=../${cache_file}" +				;; +			esac + +### check for guested configure, otherwise fix possibly relative progname +                        if [ -f ${newsrcdir}/configure ] ; then +                                recprog=${newsrcdir}/configure +                        elif [ -f ${newsrcdir}/configure.in ] ; then +                                case "${progname}" in +                                /*)     recprog=${progname} ;; +                                *)      recprog=../${progname} ;; +                                esac +			else +				eval echo No configuration information in ${configdir} ${redirect} +				recprog= +                        fi + +### The recursion line is here. +			if [ ! -z "${recprog}" ] ; then +	                        if eval ${config_shell} ${recprog} ${verbose} ${buildopt} --host=${host_alias} --target=${target_alias} \ +        	                        ${prefixoption} ${tmpdiroption} ${exec_prefixoption} \ +                	                ${srcdiroption} ${program_prefixoption} ${program_suffixoption} ${program_transform_nameoption} ${site_option} ${withoptions} ${withoutoptions} ${enableoptions} ${disableoptions} ${floating_pointoption} ${cache_file_option} ${removing} ${other_options} ${redirect} ; then +	                                true +        	                else +					echo Configure in `pwd` failed, exiting. 1>&2 +                	                exit 1 +                        	fi +			fi + +                        cd ${POPDIR} +                fi +        done +fi + +# Perform the same cleanup as the trap handler, minus the "exit 1" of course, +# and reset the trap handler. +rm -f ${tmpfile}.com ${tmpfile}.tgt ${tmpfile}.hst ${tmpfile}.pos +trap 0 + +exit 0 + +# +# Local Variables: +# fill-column: 131 +# End: +# + +# end of configure diff --git a/contrib/gdb/configure.in b/contrib/gdb/configure.in new file mode 100644 index 000000000000..fd35114de07e --- /dev/null +++ b/contrib/gdb/configure.in @@ -0,0 +1,763 @@ +############################################################################## + +## 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.   + +## Be warned, there are two types of configure.in files.  There are those +## used by Autoconf, which are macros which are expanded into a configure +## script by autoconf.  The other sort, of which this is one, is executed +## by Cygnus configure.   + +## For more information on these two systems, check out the documentation +## for 'Autoconf' (autoconf.texi) and 'Configure' (configure.texi).   + +############################################################################## + +### To add a new directory to the tree, first choose whether it is a target +### or a host dependent tool.  Then put it into the appropriate list +### (library or tools, host or target), doing a dependency sort.  For +### example, gdb requires that byacc (or bison) be built first, so it is in +### the ${host_tools} list after byacc and bison.   + + +# these libraries are used by various programs built for the host environment +# +host_libs="mmalloc libiberty opcodes bfd readline gash tcl tk tclX" + +if [ "${enable_gdbgui}" = "yes" ] ; then +	host_libs="${host_libs} libgui" +fi + +# these tools are built for the host environment +# +host_tools="byacc flex bison binutils ld gas gcc gdb make patch +	    prms send-pr gprof gdbtest tgas etc expect dejagnu sim +            m4 autoconf ispell grep diff rcs cvs fileutils shellutils +	    textutils wdiff find emacs emacs19 uudecode hello tar gzip indent +	    recode release sed utils" + + +# these libraries are built for the target environment, and are built after +# the host libraries and the host tools (which may be a cross compiler) +# +target_libs="target-libiberty target-libgloss target-newlib target-libio target-librx target-libstdc++ target-libg++" + + +# these tools are built using the target libs, and are intended to run only +# in the target environment +# +# note: any program that *uses* libraries that are in the "target_libs" +# list belongs in this list.  those programs are also very likely +# candidates for the "native_only" list which follows +# +target_tools="target-examples target-groff" + +################################################################################ + +## These two lists are of directories that are to be removed from the +## ${configdirs} list for either cross-compilations or for native- +## compilations.  For example, it doesn't make that much sense to +## cross-compile Emacs, nor is it terribly useful to compile target-libiberty in +## a native environment.   + +# directories to be built in the native environment only +# +native_only="autoconf cvs emacs emacs19 fileutils find grep gzip hello +	     indent ispell m4 rcs recode sed shellutils tar textutils gash +	     uudecode wdiff gprof target-groff" + +# directories to be built in a cross environment only +# +cross_only="target-libiberty target-libgloss target-newlib" + +## All tools belong in one of the four categories, and are assigned above +## We assign ${configdirs} this way to remove all embedded newlines.  This +## is important because configure will choke if they ever get through. +## ${configdirs} is directories we build using the host tools. +## ${target_configdirs} is directories we build using the target tools. +# +configdirs=`echo ${host_libs} ${host_tools}` +target_configdirs=`echo ${target_libs} ${target_tools}` + +################################################################################ + +srctrigger=move-if-change +srcname="gnu development package" + +# This gets set non-empty for some net releases of packages. +appdirs="" + +# per-host: + +# Work in distributions that contain no compiler tools, like Autoconf. +if [ -d ${srcdir}/config ]; then +case "${host}" in +  m68k-hp-hpux*)	  host_makefile_frag=config/mh-hp300 ;; +  m68k-apollo-sysv*)      host_makefile_frag=config/mh-apollo68 ;; +  m68k-apollo-bsd*)       host_makefile_frag=config/mh-a68bsd ;; +  m68k-*-linux*)	  host_makefile_frag=config/mh-linux ;; +  m88k-dg-dgux*)	  host_makefile_frag=config/mh-dgux ;; +  m88k-harris-cxux*)	  host_makefile_frag=config/mh-cxux ;; +  m88k-motorola-sysv*)    host_makefile_frag=config/mh-delta88;; +  mips*-dec-ultrix*)      host_makefile_frag=config/mh-decstation ;; +  mips*-nec-sysv4*)	  host_makefile_frag=config/mh-necv4 ;; +  mips*-sgi-irix[56]*)    host_makefile_frag=config/mh-irix5 ;; +  mips*-sgi-irix4*)       host_makefile_frag=config/mh-irix4 ;; +  mips*-sgi-irix3*)       host_makefile_frag=config/mh-sysv ;; +  mips*-*-sysv4*)	  host_makefile_frag=config/mh-sysv4 ;; +  mips*-*-sysv*)	  host_makefile_frag=config/mh-riscos ;; +  i[345]86-ncr-sysv4.3)   host_makefile_frag=config/mh-ncrsvr43 ;; +  i[345]86-ncr-sysv4*)    host_makefile_frag=config/mh-ncr3000 ;; +  i[345]86-*-sco3.2v5*)   host_makefile_frag=config/mh-sysv ;; +  i[345]86-*-sco*)        host_makefile_frag=config/mh-sco ;; +  i[345]86-*-isc*)	  host_makefile_frag=config/mh-sysv ;; +  i[345]86-*-linux*)      host_makefile_frag=config/mh-linux ;; +  i[345]86-*-solaris2*)   host_makefile_frag=config/mh-sysv4 ;; +  i[345]86-*-aix*)	  host_makefile_frag=config/mh-aix386 ;; +  i[345]86-*-go32*)	  host_makefile_frag=config/mh-go32 ;; +  vax-*-ultrix2*)         host_makefile_frag=config/mh-vaxult2 ;; +  *-*-solaris2*)          host_makefile_frag=config/mh-solaris ;; +  m68k-sun-sunos*)	  host_makefile_frag=config/mh-sun3 ;; +  *-hp-hpux[78]*)         host_makefile_frag=config/mh-hpux8 ;; +  *-hp-hpux*)             host_makefile_frag=config/mh-hpux ;; +  *-*-hiux*)              host_makefile_frag=config/mh-hpux ;; +  rs6000-*-lynxos*)	  host_makefile_frag=config/mh-lynxrs6k ;; +  *-*-lynxos*)	  	  host_makefile_frag=config/mh-lynxos ;; +  *-*-sysv4*)             host_makefile_frag=config/mh-sysv4 ;; +  *-*-sysv*)              host_makefile_frag=config/mh-sysv ;; +esac +fi + +# If we aren't going to be using gcc, see if we can extract a definition +# of CC from the fragment. +if [ -z "${CC}" -a "${build}" = "${host}" ]; then +  IFS="${IFS= 	}"; save_ifs="$IFS"; IFS="${IFS}:" +  found= +  for dir in $PATH; do +    test -z "$dir" && dir=. +    if test -f $dir/gcc; then +      found=yes +      break +    fi +  done +  IFS="$save_ifs" +  if [ -z "${found}" -a -n "${host_makefile_frag}" -a -f "${srcdir}/${host_makefile_frag}" ]; then +    xx=`sed -n -e 's/^[ 	]*CC[ 	]*=[ 	]*\(.*\)$/\1/p' < ${srcdir}/${host_makefile_frag}` +    if [ -n "${xx}" ] ; then +      CC=$xx +    fi +  fi +fi + +# We default to --with-shared on platforms where -fpic is meaningless. +# Well, we don't yet, but we will. +if false && [ "${host}" = "${target}" ] && [ x${enable_shared} = x ]; then +  case "${target}" in +    alpha-dec-osf*)	enable_shared=yes ;; +    mips-sgi-irix5*)	enable_shared=yes ;; +    *)			enable_shared=no ;; +  esac +fi + +if [ x${enable_shared} = xyes ]; then +  waugh= +  case "${host}" in +    hppa*)		waugh=config/mh-papic ;; +    i[345]86-*)		waugh=config/mh-x86pic ;; +    sparc64-*)		waugh=config/mh-sparcpic ;; +    *)			waugh=config/mh-${host_cpu}pic ;; +  esac +  if [ -f ${srcdir}/${waugh} ]; then +    if [ -n "${host_makefile_frag}" ] ; then +      cat ${srcdir}/${host_makefile_frag} > mh-frag +      cat ${srcdir}/${waugh} >> mh-frag +      host_makefile_frag=mh-frag +    else +      host_makefile_frag=${waugh} +    fi +  fi +fi + +# per-target: + +case "${target}" in +  v810*)		target_makefile_frag=config/mt-v810 ;; +  i[345]86-*-netware*)  target_makefile_frag=config/mt-netware ;; +  powerpc-*-netware*)   target_makefile_frag=config/mt-netware ;; +esac + +skipdirs= +gasdir=gas +use_gnu_ld= +use_gnu_as= + +# some tools are so dependent upon X11 that if we're not building with X,  +# it's not even worth trying to configure, much less build, that tool. + +case ${with_x} in +  yes | "")  # the default value for this tree is that X11 is available +	;; +  no) +	skipdirs="${skipdirs} tk gash" +	;; +  *) +    	echo "*** bad value \"${with_x}\" for -with-x flag; ignored" 1>&2 +    	;; +esac + +# Some tools are only suitable for building in a "native" situation. +# Those are added when we have a host==target configuration.  For cross +# toolchains, we add some directories that should only be useful in a +# cross-compiler. + +is_cross_compiler= + +if [ x"${host}" = x"${target}" ] ; then +	# when doing a native toolchain, don't build the targets +	# that are in the 'cross only' list +	skipdirs="${skipdirs} ${cross_only}" +	is_cross_compiler=no +	target_subdir=. +else +	# similarly, don't build the targets in the 'native only'  +	# list when building a cross compiler +	skipdirs="${skipdirs} ${native_only}" +	is_cross_compiler=yes +	target_subdir=${target_alias} +	if [ ! -d ${target_subdir} ] ; then +	    if mkdir ${target_subdir} ; then true +	    else +		echo "'*** could not make ${PWD=`pwd`}/${target_subdir}" 1>&2 +                exit 1 +	    fi +	fi +fi	 + +copy_dirs= + +# Handle --with-headers=XXX.  The contents of the named directory are +# copied to $(tooldir)/sys-include. +if [ x"${with_headers}" != x ]; then +  if [ x${is_cross_compiler} = xno ]; then +    echo 1>&2 '***' --with-headers is only supported when cross compiling +    exit 1 +  fi +  case "${exec_prefixoption}" in +  "") x=${prefix} ;; +  *) x=${exec_prefix} ;; +  esac +  copy_dirs="${copy_dirs} ${with_headers} $x/${target_alias}/sys-include" +fi + +# Handle --with-libs=XXX.  Multiple directories are permitted.  The +# contents are copied to $(tooldir)/lib. +if [ x"${with_libs}" != x ]; then +  if [ x${is_cross_compiler} = xno ]; then +    echo 1>&2 '***' --with-libs is only supported when cross compiling +    exit 1 +  fi +  # Copy the libraries in reverse order, so that files in the first named +  # library override files in subsequent libraries. +  case "${exec_prefixoption}" in +  "") x=${prefix} ;; +  *) x=${exec_prefix} ;; +  esac +  for l in ${with_libs}; do +    copy_dirs="$l $x/${target_alias}/lib ${copy_dirs}" +  done +fi + +# If both --with-headers and --with-libs are specified, default to +# --without-newlib. +if [ x"${with_headers}" != x ] && [ x"${with_libs}" != x ]; then +  if [ x"${with_newlib}" = x ]; then +    with_newlib=no +  fi +fi + +# Recognize --with-newlib/--without-newlib. +if [ x${with_newlib} = xno ]; then +  skipdirs="${skipdirs} target-newlib" +elif [ x${with_newlib} = xyes ]; then +  skipdirs=`echo " ${skipdirs} " | sed -e 's/ target-newlib / /'` +fi + +# Default to using --with-stabs for certain targets. +if [ x${with_stabs} = x ]; then +  case "${target}" in +  mips*-*-* | alpha*-*-osf* | i[345]86*-*-sysv4* | i[345]86*-*-unixware*) +    with_stabs=yes; +    withoptions="${withoptions} --with-stabs" +    ;; +  esac +fi + +# Handle ${copy_dirs} +set fnord ${copy_dirs} +shift +while [ $# != 0 ]; do +  if [ -f $2/COPIED ] && [ x"`cat $2/COPIED`" = x"$1" ]; then +    : +  else +    echo Copying $1 to $2 + +    # Use the install script to create the directory and all required +    # parent directories. +    if [ -d $2 ]; then +      : +    else +      echo >config.temp +      ${srcdir}/install.sh -c -m 644 config.temp $2/COPIED +    fi + +    # Copy the directory, assuming we have tar. +    # FIXME: Should we use B in the second tar?  Not all systems support it. +    (cd $1; tar -cf - .) | (cd $2; tar -xpf -) + +    # It is the responsibility of the user to correctly adjust all +    # symlinks.  If somebody can figure out how to handle them correctly +    # here, feel free to add the code. + +    echo $1 > $2/COPIED +  fi +  shift; shift +done + +# Configure extra directories which are host specific + +case "${host}" in +	i[345]86-*-go32*) +	  configdirs="$configdirs dosrel" ;; +esac + +# Remove more programs from consideration, based on the host or  +# target this usually means that a port of the program doesn't +# exist yet. + +noconfigdirs="" + +case "${host}" in +  i[345]86-*-vsta) +    noconfigdirs="tcl expect dejagnu make texinfo bison patch flex byacc send-pr gprof uudecode dejagnu diff" +    ;; +  i[345]86-*-go32) +    noconfigdirs="tcl tk expect dejagnu make texinfo bison patch flex byacc send-pr gprof uudecode dejagnu diff" +	;; +  *-*-cygwin32) +     noconfigdirs="patch diff make tk tcl expect dejagnu cvs autoconf texinfo bison send-pr gprof rcs" +    ;; +  ppc*-*-pe) +     noconfigdirs="patch diff  make tk tcl expect dejagnu cvs autoconf texinfo bison send-pr gprof rcs" +    ;; +esac + + +case "${target}" in +  *-*-netware) +    noconfigdirs="$noconfigdirs target-libg++ target-libstdc++ target-librx target-newlib target-libiberty" +    ;; +  *-*-vxworks*) +    noconfigdirs="$noconfigdirs target-newlib" +    ;; +  alpha-dec-osf*) +    # ld works, but does not support shared libraries.  emacs doesn't +    # work.  newlib is not 64 bit ready.  I'm not sure about fileutils or grep. +    # gas doesn't generate exception information. +    noconfigdirs="$noconfigdirs gas ld emacs fileutils grep target-newlib" +    ;; +  alpha*-*-*) +    # newlib is not 64 bit ready +    noconfigdirs="$noconfigdirs target-newlib" +    ;; +  arm-*-pe*) +    ;; +  arm-*-riscix*) +    noconfigdirs="$noconfigdirs ld" +    ;; +  h8300*-*-* | \ +  h8500-*-*) +    noconfigdirs="$noconfigdirs target-libg++ target-libstdc++ target-libio target-librx" +    ;; +  hppa*-*-*elf* | \ +  hppa*-*-lites*) +    # Do configure ld/binutils/gas for this case. +    ;; +  hppa*-*-*) +    # HP's C compiler doesn't handle Emacs correctly (but on BSD and Mach +    # cc is gcc, and on any system a user should be able to link cc to +    # whatever they want.  FIXME, emacs emacs19). +    case "${CC}" in +	"" | cc*) noconfigdirs="$noconfigdirs emacs emacs19" ;; +        *) ;; +    esac +    noconfigdirs="$noconfigdirs ld shellutils" +    ;; +  i[345]86-*-go32) +    # but don't build gdb +    noconfigdirs="$noconfigdirs gdb target-libg++ target-libstdc++ target-libio target-librx" +    ;; +  *-*-cygwin32) + +    # make/glob's configure uses some AC_TRY_RUN type tests +    target_configdirs="$target_configdirs target-winsup" +    noconfigdirs="$noconfigdirs tcl tk expect make" +    # always build newlib. +    skipdirs=`echo " ${skipdirs} " | sed -e 's/ target-newlib / /'` + +    # Can't build gdb for cygwin32 if not native. +    case "${host}:${build}" in +      *-*-cygwin32 | *-*-cygwin32:*-*-cygwin32) ;; # keep gdb +      *) noconfigdirs="$noconfigdirs gdb" +    esac + +    ;;     +  i[345]86-*-pe) +    noconfigdirs="$noconfigdirs target-libg++ target-libstdc++ target-libio target-librx" +    ;; +  i[345]86-*-sco3.2v5*) +    # The linker does not yet know about weak symbols in COFF, +    # and is not configured to handle mixed ELF and COFF. +    noconfigdirs="$noconfigdirs gprof ld" +    ;; +  i[345]86-*-sco*) +    noconfigdirs="$noconfigdirs gprof" +    ;; +  i[345]86-*-solaris2*) +    # The linker does static linking correctly, but the Solaris C library +    # has bugs such that some important functions won't work when statically +    # linked.  (See man pages for getpwuid, for example.) +    noconfigdirs="$noconfigdirs ld" +    ;; +  i[345]86-*-sysv4*) +    # The SYSV4 C compiler doesn't handle Emacs correctly +    case "${CC}" in +	"" | cc*) noconfigdirs="$noconfigdirs emacs emacs19" ;; +        *) ;; +    esac +    # but that's okay since emacs doesn't work anyway +    noconfigdirs="$noconfigdirs emacs emacs19" +    ;; +  powerpc-*-aix*) +    # copied from rs6000-*-* entry +    noconfigdirs="$noconfigdirs gprof cvs" +    ;; +  powerpc*-*-winnt* | powerpc*-*-pe* | ppc*-*-pe) +    target_configdirs="$target_configdirs target-winsup" +    noconfigdirs="$noconfigdirs gdb tcl tk make expect" +    # always build newlib. +    skipdirs=`echo " ${skipdirs} " | sed -e 's/ target-newlib / /'` +    ;; +  rs6000-*-lynxos*) +    # The CVS server code doesn't work on the RS/6000 +    # Newlib makes problems for libg++ in crosses. +    noconfigdirs="$noconfigdirs target-newlib gprof cvs" +    ;; +  rs6000-*-*) +    noconfigdirs="$noconfigdirs gprof" +    ;; +  m68k-apollo-*) +    noconfigdirs="$noconfigdirs ld binutils gprof" +    ;; +  mips*-*-irix5*) +    # The GNU linker does not support shared libraries. +    # emacs is emacs 18, which does not work on Irix 5 (emacs19 does work) +    noconfigdirs="$noconfigdirs ld gprof emacs" +    ;; +  mips*-dec-bsd*) +    noconfigdirs="$noconfigdirs gprof" +    ;; +  mips*-*-bsd*) +    noconfigdirs="$noconfigdirs gprof" +    ;; +  mips*-*-*) +    noconfigdirs="$noconfigdirs gprof" +    ;; +  romp-*-*) +    noconfigdirs="$noconfigdirs bfd binutils ld gas opcodes" +    ;; +  sh-*-*) +    case "${host}" in +      i[345]86-*-vsta) ;; # don't add gprof back in +      i[345]86-*-go32) ;; # don't add gprof back in +      *) skipdirs=`echo " ${skipdirs} " | sed -e 's/ gprof / /'` ;; +    esac +    ;; +  sparc-*-sunos4*) +    if [ x${is_cross_compiler} != xno ] ; then +           noconfigdirs="$noconfigdirs gdb gdbtest target-newlib" +    else +           use_gnu_ld=no +    fi +    ;; +  v810-*-*) +    noconfigdirs="$noconfigdirs bfd binutils gas gcc gdb ld target-libio target-libg++ target-libstdc++ opcodes" +    ;; +  vax-*-vms) +    noconfigdirs="$noconfigdirs bfd binutils gdb ld target-newlib opcodes" +    ;; +  vax-*-*) +    noconfigdirs="$noconfigdirs target-newlib" +    ;; +  *-*-lynxos*) +    # Newlib makes problems for libg++ in crosses. +    noconfigdirs="$noconfigdirs target-newlib" +    ;;  +  *-*-macos* | \ +  *-*-mpw*) +    # Macs want a resource compiler. +    configdirs="$configdirs grez" +    ;;     +esac + +# targets that need a second pass +case "${target}" in +  *-gm-magic*) +    noconfigdirs="$noconfigdirs libgloss" +    ;; +esac + +# If we are building a Canadian Cross, discard tools that can not be built +# using a cross compiler.  FIXME: These tools should be fixed. +if [ "${build}" != "${host}" ]; then +  noconfigdirs="$noconfigdirs expect dejagnu make texinfo diff" +fi + +# Make sure we don't let GNU ld be added if we didn't want it. +if [ x$with_gnu_ld = xno ]; then +  use_gnu_ld=no +  noconfigdirs="$noconfigdirs ld" +fi + +# Make sure we don't let GNU as be added if we didn't want it. +if [ x$with_gnu_as = xno ]; then +  use_gnu_as=no +  noconfigdirs="$noconfigdirs gas" +fi + +# Remove the entries in $skipdirs and $noconfigdirs from $configdirs and +# $target_configdirs. +# If we have the source for $noconfigdirs entries, add them to $notsupp. + +notsupp="" +for dir in . $skipdirs $noconfigdirs ; do +  dirname=`echo $dir | sed -e s/target-//g` +  if [ $dir != . ]  && echo " ${configdirs} " | grep " ${dir} " >/dev/null 2>&1; then +    configdirs=`echo " ${configdirs} " | sed -e "s/ ${dir} / /"` +    if [ -r $srcdir/$dirname/configure ] \ +	|| [ -r $srcdir/$dirname/configure.in ]; then +      if echo " ${skipdirs} " | grep " ${dir} " >/dev/null 2>&1; then +	true +      else +	notsupp="$notsupp $dir" +      fi +    fi +  fi +  if [ $dir != . ]  && echo " ${target_configdirs} " | grep " ${dir} " >/dev/null 2>&1; then +    target_configdirs=`echo " ${target_configdirs} " | sed -e "s/ ${dir} / /"` +    if [ -r $srcdir/$dirname/configure ] \ +	|| [ -r $srcdir/$dirname/configure.in ]; then +      if echo " ${skipdirs} " | grep " ${dir} " >/dev/null 2>&1; then +	true +      else +	notsupp="$notsupp $dir" +      fi +    fi +  fi +done + +# Sometimes the tools are distributed with libiberty but with no other +# libraries.  In that case, we don't want to build target-libiberty. +if [ -n "${target_configdirs}" ]; then +  others= +  for i in `echo ${target_configdirs} | sed -e s/target-//g` ; do +    if [ "$i" != "libiberty" ]; then +      if [ -r $srcdir/$i/configure ] || [ -r $srcdir/$i/configure.in ]; then +	others=yes; +	break; +      fi +    fi +  done +  if [ -z "${others}" ]; then +    target_configdirs= +  fi +fi + +# Deconfigure all subdirectories, in case we are changing the +# configuration from one where a subdirectory is supported to one where it +# is not. +if [ -z "${norecursion}" -a -n "${configdirs}" ]; then +  for i in `echo ${configdirs} | sed -e s/target-//g` ; do +    rm -f $i/Makefile +  done +fi +if [ -z "${norecursion}" -a -n "${target_configdirs}" ]; then +  for i in `echo ${target_configdirs} | sed -e s/target-//g` ; do +    rm -f ${target_subdir}/$i/Makefile +  done +fi + +# Produce a warning message for the subdirs we can't configure. +# This isn't especially interesting in the Cygnus tree, but in the individual +# FSF releases, it's important to let people know when their machine isn't +# supported by the one or two programs in a package. + +if [ -n "${notsupp}" ] && [ -z "${norecursion}" ]; then +  # If $appdirs is non-empty, at least one of those directories must still +  # be configured, or we error out.  (E.g., if the gas release supports a +  # specified target in some subdirs but not the gas subdir, we shouldn't +  # pretend that all is well.) +  if [ -n "$appdirs" ]; then +    for dir in $appdirs ; do +      if [ -r $dir/Makefile.in ]; then +	if echo " ${configdirs} " | grep " ${dir} " >/dev/null 2>&1; then +	  appdirs="" +	  break +	fi +	if echo " ${target_configdirs} " | grep " ${dir} " >/dev/null 2>&1; then +	  appdirs="" +	  break +	fi +      fi +    done +    if [ -n "$appdirs" ]; then +      echo "*** This configuration is not supported by this package." 1>&2 +      exit 1 +    fi +  fi +  # Okay, some application will build, or we don't care to check.  Still +  # notify of subdirs not getting built. +  echo "*** This configuration is not supported in the following subdirectories:" 1>&2 +  echo "    ${notsupp}" 1>&2 +  echo "    (Any other directories should still work fine.)" 1>&2 +fi + +# Set with_gnu_as and with_gnu_ld as appropriate. +# +# This is done by determining whether or not the appropriate directory +# is available, and by checking whether or not specific configurations +# have requested that this magic not happen. +#  +# The command line options always override the explicit settings in  +# configure.in, and the settings in configure.in override this magic. +# +# If the default for a toolchain is to use GNU as and ld, and you don't  +# want to do that, then you should use the --without-gnu-as and +# --without-gnu-ld options for the configure script. + +if [ x${use_gnu_as} = x ] ; then +  if [ x${with_gnu_as} != xno ] && echo " ${configdirs} " | grep " ${gasdir} " > /dev/null 2>&1 && [ -d ${srcdir}/${gasdir} ] ; then +    with_gnu_as=yes +    withoptions="$withoptions --with-gnu-as" +  fi +fi + +if [ x${use_gnu_ld} = x ] ; then +  if [ x${with_gnu_ld} != xno ] && echo " ${configdirs} " | grep " ld " > /dev/null 2>&1 && [ -d ${srcdir}/ld ] ; then +    with_gnu_ld=yes +    withoptions="$withoptions --with-gnu-ld" +  fi +fi + +if [ x${enable_shared} = xyes ]; then +  case "${target}" in +    hppa*)		target_makefile_frag=config/mt-papic ;; +    i[345]86-*)		target_makefile_frag=config/mt-x86pic ;; +    *)			target_makefile_frag=config/mt-${target_cpu}pic ;; +  esac +fi + +# post-target: + +# Make sure that the compiler is able to generate an executable.  If it +# can't, we are probably in trouble.  We don't care whether we can run the +# executable--we might be using a cross compiler--we only care whether it +# can be created.  At this point the main configure script has set CC. +echo "int main () { return 0; }" > conftest.c +${CC} -o conftest ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} conftest.c +if [ $? = 0 ] && [ -s conftest ]; then +  : +else +  echo 1>&2 "*** The command '${CC} -o conftest ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} conftest.c' failed." +  echo 1>&2 "*** You must set the environment variable CC to a working compiler." +  rm -f conftest* +  exit 1 +fi +rm -f conftest* + +# The Solaris /usr/ucb/cc compiler does not appear to work. +case "${host}" in +  sparc-sun-solaris2*) +      if [ "`/usr/bin/which ${CC-cc}`" = "/usr/ucb/cc" ] ; then +          could_use= +          [ -d /opt/SUNWspro/bin ] && could_use="/opt/SUNWspro/bin" +          if [ -d /opt/cygnus/bin ] ; then +              if [ "$could_use" = "" ] ; then +                  could_use="/opt/cygnus/bin" +              else +                  could_use="$could_use or /opt/cygnus/bin" +              fi +          fi +        if [ "$could_use" = "" ] ; then +            echo "Warning: compilation may fail because you're using" +            echo "/usr/ucb/cc.  You should change your PATH or CC " +            echo "variable and rerun configure." +        else +            echo "Warning: compilation may fail because you're using" +            echo "/usr/ucb/cc, when you should use the C compiler from" +            echo "$could_use.  You should change your" +            echo "PATH or CC variable and rerun configure." +        fi +      fi +  ;; +esac + +# If --enable-shared was set, we must set LD_LIBRARY_PATH so that the +# binutils tools will find libbfd.so. +if [ "${enable_shared}" = "yes" ]; then +  sed -e 's/^SET_LIB_PATH[ 	]*=.*$/SET_LIB_PATH = $(REALLY_SET_LIB_PATH)/' \ +      Makefile > Makefile.tem +  rm -f Makefile +  mv -f Makefile.tem Makefile + +  case "${host}" in +  *-*-hpux*) +    sed -e 's/RPATH_ENVVAR[ 	]*=.*$/RPATH_ENVVAR = SHLIB_PATH/' \ +	Makefile > Makefile.tem +    rm -f Makefile +    mv -f Makefile.tem Makefile +    ;; +  esac +fi + +# Record target_configdirs and the configure arguments in Makefile. +target_configdirs=`echo "${target_configdirs}" | sed -e 's/target-//g'` +targargs=`echo "${arguments}" | \ +	sed -e 's/--norecursion//' \ +	    -e 's/--cache[a-z-]*=[^ 	]*//' \ +	    -e 's/--ho[a-z-]*=[^ 	]*//' \ +	    -e 's/--ta[a-z-]*=[^ 	]*//'` + +# Passing a --with-cross-host argument lets the target libraries know +# whether they are being built with a cross-compiler or being built +# native.  However, it would be better to use other mechanisms to make the +# sorts of decisions they want to make on this basis.  Please consider +# this option to be deprecated.  FIXME. +if [ x${is_cross_compiler} = xyes ]; then +  targargs="--with-cross-host=${host_alias} ${targargs}" +fi + +targargs="--host=${target_alias} ${targargs}" +sed -e "s:^TARGET_CONFIGDIRS[ 	]*=.*$:TARGET_CONFIGDIRS = ${target_configdirs}:" \ +    -e "s%^CONFIG_ARGUMENTS[ 	]*=.*$%CONFIG_ARGUMENTS = ${targargs}%" \ +    -e "s%^TARGET_SUBDIR[ 	]*=.*$%TARGET_SUBDIR = ${target_subdir}%" \ +       Makefile > Makefile.tem +rm -f Makefile +mv -f Makefile.tem Makefile + +# +# Local Variables: +# fill-column: 131 +# End: +# diff --git a/contrib/gdb/install.sh b/contrib/gdb/install.sh new file mode 100755 index 000000000000..c92d510dd11b --- /dev/null +++ b/contrib/gdb/install.sh @@ -0,0 +1,236 @@ +#!/bin/sh +# +# install - install a program, script, or datafile +# This comes from X11R5. +# +# $XConsortium: install.sh,v 1.2 89/12/18 14:47:22 jim Exp $ +# +# This script is compatible with the BSD install script, but was written +# from scratch. +# + + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" + + +# put in absolute paths if you don't have them in your path; or use env. vars. + +mvprog="${MVPROG-mv}" +cpprog="${CPPROG-cp}" +chmodprog="${CHMODPROG-chmod}" +chownprog="${CHOWNPROG-chown}" +chgrpprog="${CHGRPPROG-chgrp}" +stripprog="${STRIPPROG-strip}" +rmprog="${RMPROG-rm}" +mkdirprog="${MKDIRPROG-mkdir}" + +transformbasename="" +transform_arg="" +instcmd="$mvprog" +chmodcmd="$chmodprog 0755" +chowncmd="" +chgrpcmd="" +stripcmd="" +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src="" +dst="" +dir_arg="" + +while [ x"$1" != x ]; do +    case $1 in +	-c) instcmd="$cpprog" +	    shift +	    continue;; + +	-d) dir_arg=true +	    shift +	    continue;; + +	-m) chmodcmd="$chmodprog $2" +	    shift +	    shift +	    continue;; + +	-o) chowncmd="$chownprog $2" +	    shift +	    shift +	    continue;; + +	-g) chgrpcmd="$chgrpprog $2" +	    shift +	    shift +	    continue;; + +	-s) stripcmd="$stripprog" +	    shift +	    continue;; + +	-t=*) transformarg=`echo $1 | sed 's/-t=//'` +	    shift +	    continue;; + +	-b=*) transformbasename=`echo $1 | sed 's/-b=//'` +	    shift +	    continue;; + +	*)  if [ x"$src" = x ] +	    then +		src=$1 +	    else +		# this colon is to work around a 386BSD /bin/sh bug +		: +		dst=$1 +	    fi +	    shift +	    continue;; +    esac +done + +if [ x"$src" = x ] +then +	echo "install:	no input file specified" +	exit 1 +else +	true +fi + +if [ x"$dir_arg" != x ]; then +	dst=$src +	src="" +	 +	if [ -d $dst ]; then +		instcmd=: +	else +		instcmd=mkdir +	fi +else + +# Waiting for this to be detected by the "$instcmd $src $dsttmp" command +# might cause directories to be created, which would be especially bad  +# if $src (and thus $dsttmp) contains '*'. + +	if [ -f $src -o -d $src ] +	then +		true +	else +		echo "install:  $src does not exist" +		exit 1 +	fi +	 +	if [ x"$dst" = x ] +	then +		echo "install:	no destination specified" +		exit 1 +	else +		true +	fi + +# If destination is a directory, append the input filename; if your system +# does not like double slashes in filenames, you may need to add some logic + +	if [ -d $dst ] +	then +		dst="$dst"/`basename $src` +	else +		true +	fi +fi + +## this sed command emulates the dirname command +dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'` + +# Make sure that the destination directory exists. +#  this part is taken from Noah Friedman's mkinstalldirs script + +# Skip lots of stat calls in the usual case. +if [ ! -d "$dstdir" ]; then +defaultIFS='	 +' +IFS="${IFS-${defaultIFS}}" + +oIFS="${IFS}" +# Some sh's can't handle IFS=/ for some reason. +IFS='%' +set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'` +IFS="${oIFS}" + +pathcomp='' + +while [ $# -ne 0 ] ; do +	pathcomp="${pathcomp}${1}" +	shift + +	if [ ! -d "${pathcomp}" ] ; +        then +		$mkdirprog "${pathcomp}" +	else +		true +	fi + +	pathcomp="${pathcomp}/" +done +fi + +if [ x"$dir_arg" != x ] +then +	$doit $instcmd $dst && + +	if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else true ; fi && +	if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else true ; fi && +	if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else true ; fi && +	if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else true ; fi +else + +# If we're going to rename the final executable, determine the name now. + +	if [ x"$transformarg" = x ]  +	then +		dstfile=`basename $dst` +	else +		dstfile=`basename $dst $transformbasename |  +			sed $transformarg`$transformbasename +	fi + +# don't allow the sed command to completely eliminate the filename + +	if [ x"$dstfile" = x ]  +	then +		dstfile=`basename $dst` +	else +		true +	fi + +# Make a temp file name in the proper directory. + +	dsttmp=$dstdir/#inst.$$# + +# Move or copy the file name to the temp name + +	$doit $instcmd $src $dsttmp && + +	trap "rm -f ${dsttmp}" 0 && + +# and set any options; do chmod last to preserve setuid bits + +# If any of these fail, we abort the whole thing.  If we want to +# ignore errors from any of these, just make sure not to ignore +# errors from the above "$doit $instcmd $src $dsttmp" command. + +	if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else true;fi && +	if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else true;fi && +	if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else true;fi && +	if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else true;fi && + +# Now rename the file to the real destination. + +	$doit $rmcmd -f $dstdir/$dstfile && +	$doit $mvcmd $dsttmp $dstdir/$dstfile  + +fi && + + +exit 0 diff --git a/contrib/gdb/move-if-change b/contrib/gdb/move-if-change new file mode 100755 index 000000000000..ee9e355e3e61 --- /dev/null +++ b/contrib/gdb/move-if-change @@ -0,0 +1,15 @@ +#!/bin/sh +if +test -r $2 +then +if +cmp $1 $2 > /dev/null +then +echo $2 is unchanged +rm -f $1 +else +mv -f $1 $2 +fi +else +mv -f $1 $2 +fi diff --git a/contrib/gdb/opcodes/config.in b/contrib/gdb/opcodes/config.in new file mode 100644 index 000000000000..ea534ec66ce2 --- /dev/null +++ b/contrib/gdb/opcodes/config.in @@ -0,0 +1,7 @@ +/* config.in.  Generated automatically from configure.in by autoheader.  */ + +/* Define if you have the <string.h> header file.  */ +#undef HAVE_STRING_H + +/* Define if you have the <strings.h> header file.  */ +#undef HAVE_STRINGS_H diff --git a/contrib/gdb/opcodes/configure b/contrib/gdb/opcodes/configure new file mode 100755 index 000000000000..5f19335a3af0 --- /dev/null +++ b/contrib/gdb/opcodes/configure @@ -0,0 +1,1538 @@ +#! /bin/sh + +# Guess values for system-dependent variables and create Makefiles. +# Generated automatically using autoconf version 2.8  +# Copyright (C) 1992, 1993, 1994 Free Software Foundation, Inc. +# +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. + +# Defaults: +ac_help= +ac_default_prefix=/usr/local +# Any additions from configure.in: +ac_help="$ac_help +  --enable-targets        alternative target configurations" +ac_help="$ac_help +  --enable-shared         build shared opcodes library" +ac_help="$ac_help +  --enable-commonbfdlib   build shared BFD/opcodes/libiberty library" + +# Initialize some variables set by options. +# The variables have the same names as the options, with +# dashes changed to underlines. +build=NONE +cache_file=./config.cache +exec_prefix=NONE +host=NONE +no_create= +nonopt=NONE +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +target=NONE +verbose= +x_includes=NONE +x_libraries=NONE +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datadir='${prefix}/share' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +libdir='${exec_prefix}/lib' +includedir='${prefix}/include' +oldincludedir='/usr/include' +infodir='${prefix}/info' +mandir='${prefix}/man' + +# Initialize some other variables. +subdirs= +MFLAGS= MAKEFLAGS= + +ac_prev= +for ac_option +do + +  # If the previous option needs an argument, assign it. +  if test -n "$ac_prev"; then +    eval "$ac_prev=\$ac_option" +    ac_prev= +    continue +  fi + +  case "$ac_option" in +  -*=*) ac_optarg=`echo "$ac_option" | sed 's/[-_a-zA-Z0-9]*=//'` ;; +  *) ac_optarg= ;; +  esac + +  # Accept the important Cygnus configure options, so we can diagnose typos. + +  case "$ac_option" in + +  -bindir | --bindir | --bindi | --bind | --bin | --bi) +    ac_prev=bindir ;; +  -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) +    bindir="$ac_optarg" ;; + +  -build | --build | --buil | --bui | --bu) +    ac_prev=build ;; +  -build=* | --build=* | --buil=* | --bui=* | --bu=*) +    build="$ac_optarg" ;; + +  -cache-file | --cache-file | --cache-fil | --cache-fi \ +  | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) +    ac_prev=cache_file ;; +  -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ +  | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) +    cache_file="$ac_optarg" ;; + +  -datadir | --datadir | --datadi | --datad | --data | --dat | --da) +    ac_prev=datadir ;; +  -datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* \ +  | --da=*) +    datadir="$ac_optarg" ;; + +  -disable-* | --disable-*) +    ac_feature=`echo $ac_option|sed -e 's/-*disable-//'` +    # Reject names that are not valid shell variable names. +    if test -n "`echo $ac_feature| sed 's/[-a-zA-Z0-9_]//g'`"; then +      { echo "configure: error: $ac_feature: invalid feature name" 1>&2; exit 1; } +    fi +    ac_feature=`echo $ac_feature| sed 's/-/_/g'` +    eval "enable_${ac_feature}=no" ;; + +  -enable-* | --enable-*) +    ac_feature=`echo $ac_option|sed -e 's/-*enable-//' -e 's/=.*//'` +    # Reject names that are not valid shell variable names. +    if test -n "`echo $ac_feature| sed 's/[-_a-zA-Z0-9]//g'`"; then +      { echo "configure: error: $ac_feature: invalid feature name" 1>&2; exit 1; } +    fi +    ac_feature=`echo $ac_feature| sed 's/-/_/g'` +    case "$ac_option" in +      *=*) ;; +      *) ac_optarg=yes ;; +    esac +    eval "enable_${ac_feature}='$ac_optarg'" ;; + +  -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ +  | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ +  | --exec | --exe | --ex) +    ac_prev=exec_prefix ;; +  -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ +  | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ +  | --exec=* | --exe=* | --ex=*) +    exec_prefix="$ac_optarg" ;; + +  -gas | --gas | --ga | --g) +    # Obsolete; use --with-gas. +    with_gas=yes ;; + +  -help | --help | --hel | --he) +    # Omit some internal or obsolete options to make the list less imposing. +    # This message is too long to be a string in the A/UX 3.1 sh. +    cat << EOF +Usage: configure [options] [host] +Options: [defaults in brackets after descriptions] +Configuration: +  --cache-file=FILE       cache test results in FILE +  --help                  print this message +  --no-create             do not create output files +  --quiet, --silent       do not print \`checking...' messages +  --version               print the version of autoconf that created configure +Directory and file names: +  --prefix=PREFIX         install architecture-independent files in PREFIX +                          [$ac_default_prefix] +  --exec-prefix=EPREFIX   install architecture-dependent files in EPREFIX +                          [same as prefix] +  --bindir=DIR            user executables in DIR [EPREFIX/bin] +  --sbindir=DIR           system admin executables in DIR [EPREFIX/sbin] +  --libexecdir=DIR        program executables in DIR [EPREFIX/libexec] +  --datadir=DIR           read-only architecture-independent data in DIR +                          [PREFIX/share] +  --sysconfdir=DIR        read-only single-machine data in DIR [PREFIX/etc] +  --sharedstatedir=DIR    modifiable architecture-independent data in DIR +                          [PREFIX/com] +  --localstatedir=DIR     modifiable single-machine data in DIR [PREFIX/var] +  --libdir=DIR            object code libraries in DIR [EPREFIX/lib] +  --includedir=DIR        C header files in DIR [PREFIX/include] +  --oldincludedir=DIR     C header files for non-gcc in DIR [/usr/include] +  --infodir=DIR           info documentation in DIR [PREFIX/info] +  --mandir=DIR            man documentation in DIR [PREFIX/man] +  --srcdir=DIR            find the sources in DIR [configure dir or ..] +  --program-prefix=PREFIX prepend PREFIX to installed program names +  --program-suffix=SUFFIX append SUFFIX to installed program names +  --program-transform-name=PROGRAM +                          run sed PROGRAM on installed program names +EOF +    cat << EOF +Host type: +  --build=BUILD           configure for building on BUILD [BUILD=HOST] +  --host=HOST             configure for HOST [guessed] +  --target=TARGET         configure for TARGET [TARGET=HOST] +Features and packages: +  --disable-FEATURE       do not include FEATURE (same as --enable-FEATURE=no) +  --enable-FEATURE[=ARG]  include FEATURE [ARG=yes] +  --with-PACKAGE[=ARG]    use PACKAGE [ARG=yes] +  --without-PACKAGE       do not use PACKAGE (same as --with-PACKAGE=no) +  --x-includes=DIR        X include files are in DIR +  --x-libraries=DIR       X library files are in DIR +EOF +    if test -n "$ac_help"; then +      echo "--enable and --with options recognized:$ac_help" +    fi +    exit 0 ;; + +  -host | --host | --hos | --ho) +    ac_prev=host ;; +  -host=* | --host=* | --hos=* | --ho=*) +    host="$ac_optarg" ;; + +  -includedir | --includedir | --includedi | --included | --include \ +  | --includ | --inclu | --incl | --inc) +    ac_prev=includedir ;; +  -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ +  | --includ=* | --inclu=* | --incl=* | --inc=*) +    includedir="$ac_optarg" ;; + +  -infodir | --infodir | --infodi | --infod | --info | --inf) +    ac_prev=infodir ;; +  -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) +    infodir="$ac_optarg" ;; + +  -libdir | --libdir | --libdi | --libd) +    ac_prev=libdir ;; +  -libdir=* | --libdir=* | --libdi=* | --libd=*) +    libdir="$ac_optarg" ;; + +  -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ +  | --libexe | --libex | --libe) +    ac_prev=libexecdir ;; +  -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ +  | --libexe=* | --libex=* | --libe=*) +    libexecdir="$ac_optarg" ;; + +  -localstatedir | --localstatedir | --localstatedi | --localstated \ +  | --localstate | --localstat | --localsta | --localst \ +  | --locals | --local | --loca | --loc | --lo) +    ac_prev=localstatedir ;; +  -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ +  | --localstate=* | --localstat=* | --localsta=* | --localst=* \ +  | --locals=* | --local=* | --loca=* | --loc=* | --lo=*) +    localstatedir="$ac_optarg" ;; + +  -mandir | --mandir | --mandi | --mand | --man | --ma | --m) +    ac_prev=mandir ;; +  -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) +    mandir="$ac_optarg" ;; + +  -nfp | --nfp | --nf) +    # Obsolete; use --without-fp. +    with_fp=no ;; + +  -no-create | --no-create | --no-creat | --no-crea | --no-cre \ +  | --no-cr | --no-c) +    no_create=yes ;; + +  -no-recursion | --no-recursion | --no-recursio | --no-recursi \ +  | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) +    no_recursion=yes ;; + +  -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ +  | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ +  | --oldin | --oldi | --old | --ol | --o) +    ac_prev=oldincludedir ;; +  -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ +  | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ +  | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) +    oldincludedir="$ac_optarg" ;; + +  -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) +    ac_prev=prefix ;; +  -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) +    prefix="$ac_optarg" ;; + +  -program-prefix | --program-prefix | --program-prefi | --program-pref \ +  | --program-pre | --program-pr | --program-p) +    ac_prev=program_prefix ;; +  -program-prefix=* | --program-prefix=* | --program-prefi=* \ +  | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) +    program_prefix="$ac_optarg" ;; + +  -program-suffix | --program-suffix | --program-suffi | --program-suff \ +  | --program-suf | --program-su | --program-s) +    ac_prev=program_suffix ;; +  -program-suffix=* | --program-suffix=* | --program-suffi=* \ +  | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) +    program_suffix="$ac_optarg" ;; + +  -program-transform-name | --program-transform-name \ +  | --program-transform-nam | --program-transform-na \ +  | --program-transform-n | --program-transform- \ +  | --program-transform | --program-transfor \ +  | --program-transfo | --program-transf \ +  | --program-trans | --program-tran \ +  | --progr-tra | --program-tr | --program-t) +    ac_prev=program_transform_name ;; +  -program-transform-name=* | --program-transform-name=* \ +  | --program-transform-nam=* | --program-transform-na=* \ +  | --program-transform-n=* | --program-transform-=* \ +  | --program-transform=* | --program-transfor=* \ +  | --program-transfo=* | --program-transf=* \ +  | --program-trans=* | --program-tran=* \ +  | --progr-tra=* | --program-tr=* | --program-t=*) +    program_transform_name="$ac_optarg" ;; + +  -q | -quiet | --quiet | --quie | --qui | --qu | --q \ +  | -silent | --silent | --silen | --sile | --sil) +    silent=yes ;; + +  -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) +    ac_prev=sbindir ;; +  -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ +  | --sbi=* | --sb=*) +    sbindir="$ac_optarg" ;; + +  -sharedstatedir | --sharedstatedir | --sharedstatedi \ +  | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ +  | --sharedst | --shareds | --shared | --share | --shar \ +  | --sha | --sh) +    ac_prev=sharedstatedir ;; +  -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ +  | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ +  | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ +  | --sha=* | --sh=*) +    sharedstatedir="$ac_optarg" ;; + +  -site | --site | --sit) +    ac_prev=site ;; +  -site=* | --site=* | --sit=*) +    site="$ac_optarg" ;; + +  -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) +    ac_prev=srcdir ;; +  -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) +    srcdir="$ac_optarg" ;; + +  -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ +  | --syscon | --sysco | --sysc | --sys | --sy) +    ac_prev=sysconfdir ;; +  -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ +  | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) +    sysconfdir="$ac_optarg" ;; + +  -target | --target | --targe | --targ | --tar | --ta | --t) +    ac_prev=target ;; +  -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) +    target="$ac_optarg" ;; + +  -v | -verbose | --verbose | --verbos | --verbo | --verb) +    verbose=yes ;; + +  -version | --version | --versio | --versi | --vers) +    echo "configure generated by autoconf version 2.8" +    exit 0 ;; + +  -with-* | --with-*) +    ac_package=`echo $ac_option|sed -e 's/-*with-//' -e 's/=.*//'` +    # Reject names that are not valid shell variable names. +    if test -n "`echo $ac_package| sed 's/[-_a-zA-Z0-9]//g'`"; then +      { echo "configure: error: $ac_package: invalid package name" 1>&2; exit 1; } +    fi +    ac_package=`echo $ac_package| sed 's/-/_/g'` +    case "$ac_option" in +      *=*) ;; +      *) ac_optarg=yes ;; +    esac +    eval "with_${ac_package}='$ac_optarg'" ;; + +  -without-* | --without-*) +    ac_package=`echo $ac_option|sed -e 's/-*without-//'` +    # Reject names that are not valid shell variable names. +    if test -n "`echo $ac_package| sed 's/[-a-zA-Z0-9_]//g'`"; then +      { echo "configure: error: $ac_package: invalid package name" 1>&2; exit 1; } +    fi +    ac_package=`echo $ac_package| sed 's/-/_/g'` +    eval "with_${ac_package}=no" ;; + +  --x) +    # Obsolete; use --with-x. +    with_x=yes ;; + +  -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ +  | --x-incl | --x-inc | --x-in | --x-i) +    ac_prev=x_includes ;; +  -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ +  | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) +    x_includes="$ac_optarg" ;; + +  -x-libraries | --x-libraries | --x-librarie | --x-librari \ +  | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) +    ac_prev=x_libraries ;; +  -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ +  | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) +    x_libraries="$ac_optarg" ;; + +  -*) { echo "configure: error: $ac_option: invalid option; use --help to show usage" 1>&2; exit 1; } +    ;; + +  *) +    if test -n "`echo $ac_option| sed 's/[-a-z0-9.]//g'`"; then +      echo "configure: warning: $ac_option: invalid host type" 1>&2 +    fi +    if test "x$nonopt" != xNONE; then +      { echo "configure: error: can only configure for one host and one target at a time" 1>&2; exit 1; } +    fi +    nonopt="$ac_option" +    ;; + +  esac +done + +if test -n "$ac_prev"; then +  { echo "configure: error: missing argument to --`echo $ac_prev | sed 's/_/-/g'`" 1>&2; exit 1; } +fi + +trap 'rm -fr conftest* confdefs* core core.* *.core $ac_clean_files; exit 1' 1 2 15 + +# File descriptor usage: +# 0 standard input +# 1 file creation +# 2 errors and warnings +# 3 some systems may open it to /dev/tty +# 4 used on the Kubota Titan +# 6 checking for... messages and results +# 5 compiler messages saved in config.log +if test "$silent" = yes; then +  exec 6>/dev/null +else +  exec 6>&1 +fi +exec 5>./config.log + +echo "\ +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. +" 1>&5 + +# Strip out --no-create and --no-recursion so they do not pile up. +# Also quote any args containing shell metacharacters. +ac_configure_args= +for ac_arg +do +  case "$ac_arg" in +  -no-create | --no-create | --no-creat | --no-crea | --no-cre \ +  | --no-cr | --no-c) ;; +  -no-recursion | --no-recursion | --no-recursio | --no-recursi \ +  | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) ;; +  *" "*|*"	"*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?]*) +  ac_configure_args="$ac_configure_args '$ac_arg'" ;; +  *) ac_configure_args="$ac_configure_args $ac_arg" ;; +  esac +done + +# NLS nuisances. +# Only set LANG and LC_ALL to C if already set. +# These must not be set unconditionally because not all systems understand +# e.g. LANG=C (notably SCO). +if test "${LC_ALL+set}" = set; then LC_ALL=C; export LC_ALL; fi +if test "${LANG+set}"   = set; then LANG=C;   export LANG;   fi + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -rf conftest* confdefs.h +# AIX cpp loses on an empty file, so make sure it contains at least a newline. +echo > confdefs.h + +# A filename unique to this package, relative to the directory that +# configure is in, which we can look for to find out if srcdir is correct. +ac_unique_file=z8k-dis.c + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then +  ac_srcdir_defaulted=yes +  # Try the directory containing this script, then its parent. +  ac_prog=$0 +  ac_confdir=`echo $ac_prog|sed 's%/[^/][^/]*$%%'` +  test "x$ac_confdir" = "x$ac_prog" && ac_confdir=. +  srcdir=$ac_confdir +  if test ! -r $srcdir/$ac_unique_file; then +    srcdir=.. +  fi +else +  ac_srcdir_defaulted=no +fi +if test ! -r $srcdir/$ac_unique_file; then +  if test "$ac_srcdir_defaulted" = yes; then +    { echo "configure: error: can not find sources in $ac_confdir or .." 1>&2; exit 1; } +  else +    { echo "configure: error: can not find sources in $srcdir" 1>&2; exit 1; } +  fi +fi +srcdir=`echo "${srcdir}" | sed 's%\([^/]\)/*$%\1%'` + +# Prefer explicitly selected file to automatically selected ones. +if test -z "$CONFIG_SITE"; then +  if test "x$prefix" != xNONE; then +    CONFIG_SITE="$prefix/share/config.site $prefix/etc/config.site" +  else +    CONFIG_SITE="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" +  fi +fi +for ac_site_file in $CONFIG_SITE; do +  if test -r "$ac_site_file"; then +    echo "loading site script $ac_site_file" +    . "$ac_site_file" +  fi +done + +if test -r "$cache_file"; then +  echo "loading cache $cache_file" +  . $cache_file +else +  echo "creating cache $cache_file" +  > $cache_file +fi + +ac_ext=c +# CFLAGS is not in ac_cpp because -g, -O, etc. are not valid cpp options. +ac_cpp='$CPP $CPPFLAGS' +ac_compile='${CC-cc} -c $CFLAGS $CPPFLAGS conftest.$ac_ext 1>&5' +ac_link='${CC-cc} -o conftest $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&5' + +if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then +  # Stardent Vistra SVR4 grep lacks -e, says ghazi@caip.rutgers.edu. +  if (echo -n testing; echo 1,2,3) | sed s/-n/xn/ | grep xn >/dev/null; then +    ac_n= ac_c=' +' ac_t='	' +  else +    ac_n=-n ac_c= ac_t= +  fi +else +  ac_n= ac_c='\c' ac_t= +fi + + +#    configure.in script for the opcodes library. +#    Copyright (C) 1995, 1996 Free Software Foundation, Inc. +#    Written by Cygnus Support. +#  +# This program 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 2 of the License, or +# (at your option) any later version. +#  +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +# Check whether --enable-targets or --disable-targets was given. +if test "${enable_targets+set}" = set; then +  enableval="$enable_targets" +  case "${enableval}" in +  yes | "") { echo "configure: error: enable-targets option must specify target names or 'all'" 1>&2; exit 1; } +            ;; +  no)       enable_targets= ;; +  *)        enable_targets=$enableval ;; +esac +fi +# Check whether --enable-shared or --disable-shared was given. +if test "${enable_shared+set}" = set; then +  enableval="$enable_shared" +  case "${enableval}" in +  yes) shared=true ;; +  no)  shared=false ;; +  *)   { echo "configure: error: bad value ${enableval} for opcodes shared option" 1>&2; exit 1; } ;; +esac +fi +# Check whether --enable-commonbfdlib or --disable-commonbfdlib was given. +if test "${enable_commonbfdlib+set}" = set; then +  enableval="$enable_commonbfdlib" +  case "${enableval}" in +  yes) commonbfdlib=true ;; +  no)  commonbfdlib=false ;; +  *)   { echo "configure: error: bad value ${enableval} for opcodes commonbfdlib option" 1>&2; exit 1; } ;; +esac +fi + + + +ac_aux_dir= +for ac_dir in `cd $srcdir/..;pwd` $srcdir/`cd $srcdir/..;pwd`; do +  if test -f $ac_dir/install-sh; then +    ac_aux_dir=$ac_dir +    ac_install_sh="$ac_aux_dir/install-sh -c" +    break +  elif test -f $ac_dir/install.sh; then +    ac_aux_dir=$ac_dir +    ac_install_sh="$ac_aux_dir/install.sh -c" +    break +  fi +done +if test -z "$ac_aux_dir"; then +  { echo "configure: error: can not find install-sh or install.sh in `cd $srcdir/..;pwd` $srcdir/`cd $srcdir/..;pwd`" 1>&2; exit 1; } +fi +ac_config_guess=$ac_aux_dir/config.guess +ac_config_sub=$ac_aux_dir/config.sub +ac_configure=$ac_aux_dir/configure # This should be Cygnus configure. + + +# Do some error checking and defaulting for the host and target type. +# The inputs are: +#    configure --host=HOST --target=TARGET --build=BUILD NONOPT +# +# The rules are: +# 1. You are not allowed to specify --host, --target, and nonopt at the +#    same time. +# 2. Host defaults to nonopt. +# 3. If nonopt is not specified, then host defaults to the current host, +#    as determined by config.guess. +# 4. Target and build default to nonopt. +# 5. If nonopt is not specified, then target and build default to host. + +# The aliases save the names the user supplied, while $host etc. +# will get canonicalized. +case $host---$target---$nonopt in +NONE---*---* | *---NONE---* | *---*---NONE) ;; +*) { echo "configure: error: can only configure for one host and one target at a time" 1>&2; exit 1; } ;; +esac + + +# Make sure we can run config.sub. +if $ac_config_sub sun4 >/dev/null 2>&1; then : +else { echo "configure: error: can not run $ac_config_sub" 1>&2; exit 1; } +fi + +echo $ac_n "checking host system type""... $ac_c" 1>&6 + +host_alias=$host +case "$host_alias" in +NONE) +  case $nonopt in +  NONE) +    if host_alias=`$ac_config_guess`; then : +    else { echo "configure: error: can not guess host type; you must specify one" 1>&2; exit 1; } +    fi ;; +  *) host_alias=$nonopt ;; +  esac ;; +esac + +host=`$ac_config_sub $host_alias` +host_cpu=`echo $host | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +host_vendor=`echo $host | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +host_os=`echo $host | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +echo "$ac_t""$host" 1>&6 + +echo $ac_n "checking target system type""... $ac_c" 1>&6 + +target_alias=$target +case "$target_alias" in +NONE) +  case $nonopt in +  NONE) target_alias=$host_alias ;; +  *) target_alias=$nonopt ;; +  esac ;; +esac + +target=`$ac_config_sub $target_alias` +target_cpu=`echo $target | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +target_vendor=`echo $target | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +target_os=`echo $target | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +echo "$ac_t""$target" 1>&6 + +echo $ac_n "checking build system type""... $ac_c" 1>&6 + +build_alias=$build +case "$build_alias" in +NONE) +  case $nonopt in +  NONE) build_alias=$host_alias ;; +  *) build_alias=$nonopt ;; +  esac ;; +esac + +build=`$ac_config_sub $build_alias` +build_cpu=`echo $build | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'` +build_vendor=`echo $build | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\2/'` +build_os=`echo $build | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\3/'` +echo "$ac_t""$build" 1>&6 + +test "$host_alias" != "$target_alias" && +  test "$program_prefix$program_suffix$program_transform_name" = \ +    NONENONEs,x,x, && +  program_prefix=${target_alias}- + +if test -z "$target" ; then +    { echo "configure: error: Unrecognized target system type; please check config.sub." 1>&2; exit 1; } +fi +if test "$program_transform_name" = s,x,x,; then +  program_transform_name= +else +  # Double any \ or $.  echo might interpret backslashes. +  cat <<\EOF_SED > conftestsed +s,\\,\\\\,g; s,\$,$$,g +EOF_SED +  program_transform_name="`echo $program_transform_name|sed -f conftestsed`" +  rm -f conftestsed +fi +test "$program_prefix" != NONE && +  program_transform_name="s,^,${program_prefix},; $program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && +  program_transform_name="s,\$\$,${program_suffix},; $program_transform_name" + +# sed with no file args requires a program. +test "$program_transform_name" = "" && program_transform_name="s,x,x," + + +# host-specific stuff: + +ALLLIBS='$(TARGETLIB)' +PICFLAG= +SHLIB=unused-shlib +SHLINK=unused-shlink +if test "${shared}" = "true"; then +  ALLLIBS='$(TARGETLIB) $(SHLIB) $(SHLINK)' +  PICFLAG=-fpic +  if test "${commonbfdlib}" = "true"; then +    SHLIB=../bfd/libbfd.so.`sed -e 's/[^0-9]*\([0-9.]*\).*/\1/' ${srcdir}/../bfd/VERSION` +    SHLINK=../bfd/libbfd.so +  else +    SHLIB=libopcodes.so.`sed -e 's/[^0-9]*\([0-9.]*\).*/\1/' ${srcdir}/../bfd/VERSION` +    SHLINK=libopcodes.so +  fi +fi + +# Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  if test -n "$CC"; then +  ac_cv_prog_CC="$CC" # Let the user override the test. +else +  IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  for ac_dir in $PATH; do +    test -z "$ac_dir" && ac_dir=. +    if test -f $ac_dir/$ac_word; then +      ac_cv_prog_CC="gcc" +      break +    fi +  done +  IFS="$ac_save_ifs" +fi +fi +CC="$ac_cv_prog_CC" +if test -n "$CC"; then +  echo "$ac_t""$CC" 1>&6 +else +  echo "$ac_t""no" 1>&6 +fi + +if test -z "$CC"; then +  # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  if test -n "$CC"; then +  ac_cv_prog_CC="$CC" # Let the user override the test. +else +  IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  ac_prog_rejected=no +  for ac_dir in $PATH; do +    test -z "$ac_dir" && ac_dir=. +    if test -f $ac_dir/$ac_word; then +      if test "$ac_dir/$ac_word" = "/usr/ucb/cc"; then +        ac_prog_rejected=yes +	continue +      fi +      ac_cv_prog_CC="cc" +      break +    fi +  done +  IFS="$ac_save_ifs" +if test $ac_prog_rejected = yes; then +  # We found a bogon in the path, so make sure we never use it. +  set dummy $ac_cv_prog_CC +  shift +  if test $# -gt 0; then +    # We chose a different compiler from the bogus one. +    # However, it has the same basename, so the bogon will be chosen +    # first if we set CC to just the basename; use the full file name. +    shift +    set dummy "$ac_dir/$ac_word" "$@" +    shift +    ac_cv_prog_CC="$@" +  fi +fi +fi +fi +CC="$ac_cv_prog_CC" +if test -n "$CC"; then +  echo "$ac_t""$CC" 1>&6 +else +  echo "$ac_t""no" 1>&6 +fi + +  test -z "$CC" && { echo "configure: error: no acceptable cc found in \$PATH" 1>&2; exit 1; } +fi + +echo $ac_n "checking whether we are using GNU C""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_gcc'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  cat > conftest.c <<EOF +#ifdef __GNUC__ +  yes; +#endif +EOF +if { ac_try='${CC-cc} -E conftest.c'; { (eval echo configure:803: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; }; } | egrep yes >/dev/null 2>&1; then +  ac_cv_prog_gcc=yes +else +  ac_cv_prog_gcc=no +fi +fi + +echo "$ac_t""$ac_cv_prog_gcc" 1>&6 +if test $ac_cv_prog_gcc = yes; then +  GCC=yes +  if test "${CFLAGS+set}" != set; then +    echo $ac_n "checking whether ${CC-cc} accepts -g""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_gcc_g'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  echo 'void f(){}' > conftest.c +if test -z "`${CC-cc} -g -c conftest.c 2>&1`"; then +  ac_cv_prog_gcc_g=yes +else +  ac_cv_prog_gcc_g=no +fi +rm -f conftest* + +fi + +echo "$ac_t""$ac_cv_prog_gcc_g" 1>&6 +    if test $ac_cv_prog_gcc_g = yes; then +      CFLAGS="-g -O" +    else +      CFLAGS="-O" +    fi +  fi +else +  GCC= +  test "${CFLAGS+set}" = set || CFLAGS="-g" +fi + + +. ${srcdir}/../bfd/configure.host + + +if test $host != $build; then +  ac_tool_prefix=${host_alias}- +else +  ac_tool_prefix= +fi + +# Extract the first word of "${ac_tool_prefix}ar", so it can be a program name with args. +set dummy ${ac_tool_prefix}ar; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_AR'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  if test -n "$AR"; then +  ac_cv_prog_AR="$AR" # Let the user override the test. +else +  IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  for ac_dir in $PATH; do +    test -z "$ac_dir" && ac_dir=. +    if test -f $ac_dir/$ac_word; then +      ac_cv_prog_AR="${ac_tool_prefix}ar" +      break +    fi +  done +  IFS="$ac_save_ifs" +  test -z "$ac_cv_prog_AR" && ac_cv_prog_AR="ar" +fi +fi +AR="$ac_cv_prog_AR" +if test -n "$AR"; then +  echo "$ac_t""$AR" 1>&6 +else +  echo "$ac_t""no" 1>&6 +fi + + + +# Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. +set dummy ${ac_tool_prefix}ranlib; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_RANLIB'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  if test -n "$RANLIB"; then +  ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +  IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  for ac_dir in $PATH; do +    test -z "$ac_dir" && ac_dir=. +    if test -f $ac_dir/$ac_word; then +      ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" +      break +    fi +  done +  IFS="$ac_save_ifs" +fi +fi +RANLIB="$ac_cv_prog_RANLIB" +if test -n "$RANLIB"; then +  echo "$ac_t""$RANLIB" 1>&6 +else +  echo "$ac_t""no" 1>&6 +fi + + +if test -z "$ac_cv_prog_RANLIB"; then +if test -n "$ac_tool_prefix"; then +  # Extract the first word of "ranlib", so it can be a program name with args. +set dummy ranlib; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_prog_RANLIB'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  if test -n "$RANLIB"; then +  ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. +else +  IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  for ac_dir in $PATH; do +    test -z "$ac_dir" && ac_dir=. +    if test -f $ac_dir/$ac_word; then +      ac_cv_prog_RANLIB="ranlib" +      break +    fi +  done +  IFS="$ac_save_ifs" +  test -z "$ac_cv_prog_RANLIB" && ac_cv_prog_RANLIB=":" +fi +fi +RANLIB="$ac_cv_prog_RANLIB" +if test -n "$RANLIB"; then +  echo "$ac_t""$RANLIB" 1>&6 +else +  echo "$ac_t""no" 1>&6 +fi + +else +  RANLIB=":" +fi +fi + +# Find a good install program.  We prefer a C program (faster), +# so one script is as good as another.  But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# ./install, which can be erroneously created by make from ./install.sh. +echo $ac_n "checking for a BSD compatible install""... $ac_c" 1>&6 +if test -z "$INSTALL"; then +if eval "test \"`echo '$''{'ac_cv_path_install'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +    IFS="${IFS= 	}"; ac_save_ifs="$IFS"; IFS="${IFS}:" +  for ac_dir in $PATH; do +    # Account for people who put trailing slashes in PATH elements. +    case "$ac_dir/" in +    /|./|.//|/etc/*|/usr/sbin/*|/usr/etc/*|/sbin/*|/usr/afsws/bin/*|/usr/ucb/*) ;; +    *) +      # OSF1 and SCO ODT 3.0 have their own names for install. +      for ac_prog in ginstall installbsd scoinst install; do +        if test -f $ac_dir/$ac_prog; then +	  if test $ac_prog = install && +            grep dspmsg $ac_dir/$ac_prog >/dev/null 2>&1; then +	    # AIX install.  It has an incompatible calling convention. +	    # OSF/1 installbsd also uses dspmsg, but is usable. +	    : +	  else +	    ac_cv_path_install="$ac_dir/$ac_prog -c" +	    break 2 +	  fi +	fi +      done +      ;; +    esac +  done +  IFS="$ac_save_ifs" + +fi +  if test "${ac_cv_path_install+set}" = set; then +    INSTALL="$ac_cv_path_install" +  else +    # As a last resort, use the slow shell script.  We don't cache a +    # path for INSTALL within a source directory, because that will +    # break other packages using the cache if that directory is +    # removed, or if the path is relative. +    INSTALL="$ac_install_sh" +  fi +fi +echo "$ac_t""$INSTALL" 1>&6 + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + + +if test "${shared}" = "true"; then +  if test "${GCC}" != "yes" && test "${shared_non_gcc}" != "yes"; then +    echo "configure: warning: opcodes --enable-shared only supported when using gcc" 1>&2 +    shared=false +    ALLLIBS='$(TARGETLIB)' +    PICFLAG= +    SHLIB=unused-shlib +  fi +fi + + + + + + +if test "${commonbfdlib}" = "true"; then +  COMMON_SHLIB=yes +  # Rebuild the shared library if libiberty or libbfd changes. +  SHLIB_DEP="../libiberty/libiberty.a ../bfd/libbfd.a" +else +  COMMON_SHLIB= +  SHLIB_DEP= +fi + + + + +echo $ac_n "checking how to run the C preprocessor""... $ac_c" 1>&6 +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then +  CPP= +fi +if test -z "$CPP"; then +if eval "test \"`echo '$''{'ac_cv_prog_CPP'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +    # This must be in double quotes, not single quotes, because CPP may get +  # substituted into the Makefile and "${CC-cc}" will confuse make. +  CPP="${CC-cc} -E" +  # On the NeXT, cc -E runs the code through the compiler's parser, +  # not just through cpp. +  cat > conftest.$ac_ext <<EOF +#line 1045 "configure" +#include "confdefs.h" +#include <assert.h> +Syntax Error +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1051: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out` +if test -z "$ac_err"; then +  : +else +  echo "$ac_err" >&5 +  rm -rf conftest* +  CPP="${CC-cc} -E -traditional-cpp" +  cat > conftest.$ac_ext <<EOF +#line 1060 "configure" +#include "confdefs.h" +#include <assert.h> +Syntax Error +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1066: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out` +if test -z "$ac_err"; then +  : +else +  echo "$ac_err" >&5 +  rm -rf conftest* +  CPP=/lib/cpp +fi +rm -f conftest* +fi +rm -f conftest* +  ac_cv_prog_CPP="$CPP" +fi +  CPP="$ac_cv_prog_CPP" +else +  ac_cv_prog_CPP="$CPP" +fi +echo "$ac_t""$CPP" 1>&6 + +for ac_hdr in string.h strings.h +do +ac_safe=`echo "$ac_hdr" | tr './\055' '___'` +echo $ac_n "checking for $ac_hdr""... $ac_c" 1>&6 +if eval "test \"`echo '$''{'ac_cv_header_$ac_safe'+set}'`\" = set"; then +  echo $ac_n "(cached) $ac_c" 1>&6 +else +  cat > conftest.$ac_ext <<EOF +#line 1094 "configure" +#include "confdefs.h" +#include <$ac_hdr> +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1099: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out` +if test -z "$ac_err"; then +  rm -rf conftest* +  eval "ac_cv_header_$ac_safe=yes" +else +  echo "$ac_err" >&5 +  rm -rf conftest* +  eval "ac_cv_header_$ac_safe=no" +fi +rm -f conftest* +fi +if eval "test \"`echo '$ac_cv_header_'$ac_safe`\" = yes"; then +  echo "$ac_t""yes" 1>&6 +    ac_tr_hdr=HAVE_`echo $ac_hdr | tr 'abcdefghijklmnopqrstuvwxyz./\055' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ___'` +  cat >> confdefs.h <<EOF +#define $ac_tr_hdr 1 +EOF +  +else +  echo "$ac_t""no" 1>&6 +fi +done + + +# target-specific stuff: + +# Canonicalize the secondary target names. +if test -n "$enable_targets" ; then +    for targ in `echo $enable_targets | sed 's/,/ /g'` +    do +	result=`$ac_config_sub $targ 2>/dev/null` +	if test -n "$result" ; then +	    canon_targets="$canon_targets $result" +	else +	    # Allow targets that config.sub doesn't recognize, like "all". +	    canon_targets="$canon_targets $targ" +	fi +    done +fi + +all_targets=false +selarchs= +for targ in $target $canon_targets +do +    if test "x$targ" = "xall" ; then +        all_targets=true +    else +	. $srcdir/../bfd/config.bfd +	selarchs="$selarchs $targ_archs" +    fi +done	 + +# We don't do any links based on the target system, just makefile config. + +if test x${all_targets} = xfalse ; then + +    # Target architecture .o files. +    ta= + +    for arch in $selarchs +    do +	ad=`echo $arch | sed -e s/bfd_//g -e s/_arch//g` +	archdefs="$archdefs -DARCH_$ad" +	case "$arch" in +	bfd_a29k_arch)		ta="$ta a29k-dis.o" ;; +	bfd_alliant_arch)	;; +	bfd_alpha_arch)		ta="$ta alpha-dis.o" ;; +	bfd_arm_arch)		ta="$ta arm-dis.o" ;; +	bfd_convex_arch)	;; +	bfd_h8300_arch)		ta="$ta h8300-dis.o" ;; +	bfd_h8500_arch)		ta="$ta h8500-dis.o" ;; +	bfd_hppa_arch)		ta="$ta hppa-dis.o" ;; +	bfd_i386_arch)		ta="$ta i386-dis.o" ;; +	bfd_i860_arch)		;; +	bfd_i960_arch)		ta="$ta i960-dis.o" ;; +	bfd_m68k_arch)		ta="$ta m68k-dis.o m68k-opc.o" ;; +	bfd_m88k_arch)		ta="$ta m88k-dis.o" ;; +	bfd_mips_arch)		ta="$ta mips-dis.o mips-opc.o" ;; +	bfd_ns32k_arch)		ta="$ta ns32k-dis.o" ;; +	bfd_powerpc_arch)	ta="$ta ppc-dis.o ppc-opc.o" ;; +	bfd_pyramid_arch)	;; +	bfd_romp_arch)		;; +	bfd_rs6000_arch)	ta="$ta ppc-dis.o ppc-opc.o" ;; +	bfd_sh_arch)		ta="$ta sh-dis.o" ;; +	bfd_sparc_arch)		ta="$ta sparc-dis.o sparc-opc.o" ;; +	bfd_tahoe_arch)		;; +	bfd_vax_arch)		;; +	bfd_w65_arch)		ta="$ta w65-dis.o" ;; +	bfd_we32k_arch)		;; +	bfd_z8k_arch)		ta="$ta z8k-dis.o" ;; + +	"")			;; +	*)		{ echo "configure: error: *** unknown target architecture $arch" 1>&2; exit 1; } ;; +	esac +    done + +    # Weed out duplicate .o files. +    f="" +    for i in $ta ; do +	case " $f " in +	*" $i "*) ;; +	*) f="$f $i" ;; +	esac +    done +    ta="$f" + +    # And duplicate -D flags. +    f="" +    for i in $archdefs ; do +	case " $f " in +	*" $i "*) ;; +	*) f="$f $i" ;; +	esac +    done +    archdefs="$f" + +    BFD_MACHINES="$ta" + +else	# all_targets is true +    archdefs=-DARCH_all +    BFD_MACHINES='$(ALL_MACHINES)' +fi + + + + +trap '' 1 2 15 +cat > confcache <<\EOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs.  It is not useful on other systems. +# If it contains results you don't want to keep, you may remove or edit it. +# +# By default, configure uses ./config.cache as the cache file, +# creating it if it does not exist already.  You can give configure +# the --cache-file=FILE option to use a different cache file; that is +# what configure does when it calls configure scripts in +# subdirectories, so they share the cache. +# Giving --cache-file=/dev/null disables caching, for debugging configure. +# config.status only pays attention to the cache file if you give it the +# --recheck option to rerun configure. +# +EOF +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +(set) 2>&1 | +  sed -n "s/^\([a-zA-Z0-9_]*_cv_[a-zA-Z0-9_]*\)=\(.*\)/\1=\${\1='\2'}/p" \ +  >> confcache +if cmp -s $cache_file confcache; then +  : +else +  if test -w $cache_file; then +    echo "updating cache $cache_file" +    cat confcache > $cache_file +  else +    echo "not updating unwritable cache $cache_file" +  fi +fi +rm -f confcache + +trap 'rm -fr conftest* confdefs* core core.* *.core $ac_clean_files; exit 1' 1 2 15 + +test "x$prefix" = xNONE && prefix=$ac_default_prefix +# Let make expand exec_prefix. +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' + +# Any assignment to VPATH causes Sun make to only execute +# the first set of double-colon rules, so remove it if not needed. +# If there is a colon in the path, we need to keep it. +if test "x$srcdir" = x.; then +  ac_vpsub='/^[ 	]*VPATH[ 	]*=[^:]*$/d' +fi + +trap 'rm -f $CONFIG_STATUS conftest*; exit 1' 1 2 15 + +DEFS=-DHAVE_CONFIG_H + +# Without the "./", some shells look in PATH for config.status. +: ${CONFIG_STATUS=./config.status} + +echo creating $CONFIG_STATUS +rm -f $CONFIG_STATUS +cat > $CONFIG_STATUS <<EOF +#! /bin/sh +# Generated automatically by configure. +# Run this file to recreate the current configuration. +# This directory was configured as follows, +# on host `(hostname || uname -n) 2>/dev/null | sed 1q`: +# +# $0 $ac_configure_args +# +# Compiler output produced by configure, useful for debugging +# configure, is in ./config.log if it exists. + +ac_cs_usage="Usage: $CONFIG_STATUS [--recheck] [--version] [--help]" +for ac_option +do +  case "\$ac_option" in +  -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) +    echo "running \${CONFIG_SHELL-/bin/sh} $0 $ac_configure_args --no-create --no-recursion" +    exec \${CONFIG_SHELL-/bin/sh} $0 $ac_configure_args --no-create --no-recursion ;; +  -version | --version | --versio | --versi | --vers | --ver | --ve | --v) +    echo "$CONFIG_STATUS generated by autoconf version 2.8" +    exit 0 ;; +  -help | --help | --hel | --he | --h) +    echo "\$ac_cs_usage"; exit 0 ;; +  *) echo "\$ac_cs_usage"; exit 1 ;; +  esac +done + +ac_given_srcdir=$srcdir +ac_given_INSTALL="$INSTALL" + +trap 'rm -fr `echo "Makefile config.h:config.in" | sed "s/:[^ ]*//g"` conftest*; exit 1' 1 2 15 +EOF +cat >> $CONFIG_STATUS <<EOF + +# Protect against being on the right side of a sed subst in config.status. +sed 's/%@/@@/; s/@%/@@/; s/%g\$/@g/; /@g\$/s/[\\\\&%]/\\\\&/g; + s/@@/%@/; s/@@/@%/; s/@g\$/%g/' > conftest.subs <<\\CEOF +$ac_vpsub +$extrasub +s%@CFLAGS@%$CFLAGS%g +s%@CPPFLAGS@%$CPPFLAGS%g +s%@CXXFLAGS@%$CXXFLAGS%g +s%@DEFS@%$DEFS%g +s%@LDFLAGS@%$LDFLAGS%g +s%@LIBS@%$LIBS%g +s%@exec_prefix@%$exec_prefix%g +s%@prefix@%$prefix%g +s%@program_transform_name@%$program_transform_name%g +s%@bindir@%$bindir%g +s%@sbindir@%$sbindir%g +s%@libexecdir@%$libexecdir%g +s%@datadir@%$datadir%g +s%@sysconfdir@%$sysconfdir%g +s%@sharedstatedir@%$sharedstatedir%g +s%@localstatedir@%$localstatedir%g +s%@libdir@%$libdir%g +s%@includedir@%$includedir%g +s%@oldincludedir@%$oldincludedir%g +s%@infodir@%$infodir%g +s%@mandir@%$mandir%g +s%@host@%$host%g +s%@host_alias@%$host_alias%g +s%@host_cpu@%$host_cpu%g +s%@host_vendor@%$host_vendor%g +s%@host_os@%$host_os%g +s%@target@%$target%g +s%@target_alias@%$target_alias%g +s%@target_cpu@%$target_cpu%g +s%@target_vendor@%$target_vendor%g +s%@target_os@%$target_os%g +s%@build@%$build%g +s%@build_alias@%$build_alias%g +s%@build_cpu@%$build_cpu%g +s%@build_vendor@%$build_vendor%g +s%@build_os@%$build_os%g +s%@CC@%$CC%g +s%@HDEFINES@%$HDEFINES%g +s%@AR@%$AR%g +s%@RANLIB@%$RANLIB%g +s%@INSTALL_PROGRAM@%$INSTALL_PROGRAM%g +s%@INSTALL_DATA@%$INSTALL_DATA%g +s%@ALLLIBS@%$ALLLIBS%g +s%@PICFLAG@%$PICFLAG%g +s%@SHLIB@%$SHLIB%g +s%@SHLIB_CC@%$SHLIB_CC%g +s%@SHLIB_CFLAGS@%$SHLIB_CFLAGS%g +s%@COMMON_SHLIB@%$COMMON_SHLIB%g +s%@SHLIB_DEP@%$SHLIB_DEP%g +s%@SHLINK@%$SHLINK%g +s%@CPP@%$CPP%g +s%@archdefs@%$archdefs%g +s%@BFD_MACHINES@%$BFD_MACHINES%g + +CEOF +EOF +cat >> $CONFIG_STATUS <<EOF + +CONFIG_FILES=\${CONFIG_FILES-"Makefile"} +EOF +cat >> $CONFIG_STATUS <<\EOF +for ac_file in .. $CONFIG_FILES; do if test "x$ac_file" != x..; then +  # Support "outfile[:infile]", defaulting infile="outfile.in". +  case "$ac_file" in +  *:*) ac_file_in=`echo "$ac_file"|sed 's%.*:%%'` +       ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; +  *) ac_file_in="${ac_file}.in" ;; +  esac + +  # Adjust relative srcdir, etc. for subdirectories. + +  # Remove last slash and all that follows it.  Not all systems have dirname. +  ac_dir=`echo $ac_file|sed 's%/[^/][^/]*$%%'` +  if test "$ac_dir" != "$ac_file" && test "$ac_dir" != .; then +    # The file is in a subdirectory. +    test ! -d "$ac_dir" && mkdir "$ac_dir" +    ac_dir_suffix="/`echo $ac_dir|sed 's%^\./%%'`" +    # A "../" for each directory in $ac_dir_suffix. +    ac_dots=`echo $ac_dir_suffix|sed 's%/[^/]*%../%g'` +  else +    ac_dir_suffix= ac_dots= +  fi + +  case "$ac_given_srcdir" in +  .)  srcdir=. +      if test -z "$ac_dots"; then top_srcdir=. +      else top_srcdir=`echo $ac_dots|sed 's%/$%%'`; fi ;; +  /*) srcdir="$ac_given_srcdir$ac_dir_suffix"; top_srcdir="$ac_given_srcdir" ;; +  *) # Relative path. +    srcdir="$ac_dots$ac_given_srcdir$ac_dir_suffix" +    top_srcdir="$ac_dots$ac_given_srcdir" ;; +  esac + +  case "$ac_given_INSTALL" in +  [/$]*) INSTALL="$ac_given_INSTALL" ;; +  *) INSTALL="$ac_dots$ac_given_INSTALL" ;; +  esac +  echo creating "$ac_file" +  rm -f "$ac_file" +  configure_input="Generated automatically from `echo $ac_file_in|sed 's%.*/%%'` by configure." +  case "$ac_file" in +  *Makefile*) ac_comsub="1i\\ +# $configure_input" ;; +  *) ac_comsub= ;; +  esac +  sed -e "$ac_comsub +s%@configure_input@%$configure_input%g +s%@srcdir@%$srcdir%g +s%@top_srcdir@%$top_srcdir%g +s%@INSTALL@%$INSTALL%g +" -f conftest.subs $ac_given_srcdir/$ac_file_in > $ac_file +fi; done +rm -f conftest.subs + +# These sed commands are passed to sed as "A NAME B NAME C VALUE D", where +# NAME is the cpp macro being defined and VALUE is the value it is being given. +# +# ac_d sets the value in "#define NAME VALUE" lines. +ac_dA='s%^\([ 	]*\)#\([ 	]*define[ 	][ 	]*\)' +ac_dB='\([ 	][ 	]*\)[^ 	]*%\1#\2' +ac_dC='\3' +ac_dD='%g' +# ac_u turns "#undef NAME" with trailing blanks into "#define NAME VALUE". +ac_uA='s%^\([ 	]*\)#\([ 	]*\)undef\([ 	][ 	]*\)' +ac_uB='\([ 	]\)%\1#\2define\3' +ac_uC=' ' +ac_uD='\4%g' +# ac_e turns "#undef NAME" without trailing blanks into "#define NAME VALUE". +ac_eA='s%^\([ 	]*\)#\([ 	]*\)undef\([ 	][ 	]*\)' +ac_eB='$%\1#\2define\3' +ac_eC=' ' +ac_eD='%g' + +CONFIG_HEADERS=${CONFIG_HEADERS-"config.h:config.in"} +for ac_file in .. $CONFIG_HEADERS; do if test "x$ac_file" != x..; then +  # Support "outfile[:infile]", defaulting infile="outfile.in". +  case "$ac_file" in +  *:*) ac_file_in=`echo "$ac_file"|sed 's%.*:%%'` +       ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; +  *) ac_file_in="${ac_file}.in" ;; +  esac + +  echo creating $ac_file + +  rm -f conftest.frag conftest.in conftest.out +  cp $ac_given_srcdir/$ac_file_in conftest.in + +EOF + +# Transform confdefs.h into a sed script conftest.vals that substitutes +# the proper values into config.h.in to produce config.h.  And first: +# Protect against being on the right side of a sed subst in config.status. +# Protect against being in an unquoted here document in config.status. +rm -f conftest.vals +cat > conftest.hdr <<\EOF +s/[\\&%]/\\&/g +s%[\\$`]%\\&%g +s%#define \([A-Za-z_][A-Za-z0-9_]*\) \(.*\)%${ac_dA}\1${ac_dB}\1${ac_dC}\2${ac_dD}%gp +s%ac_d%ac_u%gp +s%ac_u%ac_e%gp +EOF +sed -n -f conftest.hdr confdefs.h > conftest.vals +rm -f conftest.hdr + +# This sed command replaces #undef with comments.  This is necessary, for +# example, in the case of _POSIX_SOURCE, which is predefined and required +# on some systems where configure will not decide to define it. +cat >> conftest.vals <<\EOF +s%^[ 	]*#[ 	]*undef[ 	][ 	]*[a-zA-Z_][a-zA-Z_0-9]*%/* & */% +EOF + +# Break up conftest.vals because some shells have a limit on +# the size of here documents, and old seds have small limits too. +# Maximum number of lines to put in a single here document. +ac_max_here_lines=12 + +rm -f conftest.tail +while : +do +  ac_lines=`grep -c . conftest.vals` +  # grep -c gives empty output for an empty file on some AIX systems. +  if test -z "$ac_lines" || test "$ac_lines" -eq 0; then break; fi +  # Write a limited-size here document to conftest.frag. +  echo '  cat > conftest.frag <<CEOF' >> $CONFIG_STATUS +  sed ${ac_max_here_lines}q conftest.vals >> $CONFIG_STATUS +  echo 'CEOF +  sed -f conftest.frag conftest.in > conftest.out +  rm -f conftest.in +  mv conftest.out conftest.in +' >> $CONFIG_STATUS +  sed 1,${ac_max_here_lines}d conftest.vals > conftest.tail +  rm -f conftest.vals +  mv conftest.tail conftest.vals +done +rm -f conftest.vals + +cat >> $CONFIG_STATUS <<\EOF +  rm -f conftest.frag conftest.h +  echo "/* $ac_file.  Generated automatically by configure.  */" > conftest.h +  cat conftest.in >> conftest.h +  rm -f conftest.in +  if cmp -s $ac_file conftest.h 2>/dev/null; then +    echo "$ac_file is unchanged" +    rm -f conftest.h +  else +    rm -f $ac_file +    mv conftest.h $ac_file +  fi +fi; done + + +case x$CONFIG_HEADERS in xconfig.h:config.in) echo > stamp-h ;; esac +exit 0 +EOF +chmod +x $CONFIG_STATUS +rm -fr confdefs* $ac_clean_files +test "$no_create" = yes || ${CONFIG_SHELL-/bin/sh} $CONFIG_STATUS || exit 1 + diff --git a/contrib/gdb/opcodes/configure.in b/contrib/gdb/opcodes/configure.in new file mode 100644 index 000000000000..e0c4f58e7c29 --- /dev/null +++ b/contrib/gdb/opcodes/configure.in @@ -0,0 +1,216 @@ +AC_PREREQ(2.0) +AC_INIT(z8k-dis.c) +#    configure.in script for the opcodes library. +#    Copyright (C) 1995, 1996 Free Software Foundation, Inc. +#    Written by Cygnus Support. +#  +# This program 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 2 of the License, or +# (at your option) any later version. +#  +# This program 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 this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + +AC_ARG_ENABLE(targets, +[  --enable-targets        alternative target configurations], +[case "${enableval}" in +  yes | "") AC_ERROR(enable-targets option must specify target names or 'all') +            ;; +  no)       enable_targets= ;; +  *)        enable_targets=$enableval ;; +esac])dnl +AC_ARG_ENABLE(shared, +[  --enable-shared         build shared opcodes library], +[case "${enableval}" in +  yes) shared=true ;; +  no)  shared=false ;; +  *)   AC_MSG_ERROR([bad value ${enableval} for opcodes shared option]) ;; +esac])dnl +AC_ARG_ENABLE(commonbfdlib, +[  --enable-commonbfdlib   build shared BFD/opcodes/libiberty library], +[case "${enableval}" in +  yes) commonbfdlib=true ;; +  no)  commonbfdlib=false ;; +  *)   AC_MSG_ERROR([bad value ${enableval} for opcodes commonbfdlib option]) ;; +esac])dnl + +AC_CONFIG_HEADER(config.h:config.in) + +AC_CONFIG_AUX_DIR(`cd $srcdir/..;pwd`) +AC_CANONICAL_SYSTEM +if test -z "$target" ; then +    AC_MSG_ERROR(Unrecognized target system type; please check config.sub.) +fi +AC_ARG_PROGRAM + +# host-specific stuff: + +ALLLIBS='$(TARGETLIB)' +PICFLAG= +SHLIB=unused-shlib +SHLINK=unused-shlink +if test "${shared}" = "true"; then +  ALLLIBS='$(TARGETLIB) $(SHLIB) $(SHLINK)' +  PICFLAG=-fpic +  if test "${commonbfdlib}" = "true"; then +changequote(,)dnl +    SHLIB=../bfd/libbfd.so.`sed -e 's/[^0-9]*\([0-9.]*\).*/\1/' ${srcdir}/../bfd/VERSION` +changequote([,])dnl +    SHLINK=../bfd/libbfd.so +  else +changequote(,)dnl +    SHLIB=libopcodes.so.`sed -e 's/[^0-9]*\([0-9.]*\).*/\1/' ${srcdir}/../bfd/VERSION` +changequote([,])dnl +    SHLINK=libopcodes.so +  fi +fi + +AC_PROG_CC + +. ${srcdir}/../bfd/configure.host + +AC_SUBST(HDEFINES) +AC_CHECK_TOOL(AR, ar) +AC_CHECK_TOOL(RANLIB, ranlib, :) +AC_PROG_INSTALL + +if test "${shared}" = "true"; then +  if test "${GCC}" != "yes" && test "${shared_non_gcc}" != "yes"; then +    AC_MSG_WARN([opcodes --enable-shared only supported when using gcc]) +    shared=false +    ALLLIBS='$(TARGETLIB)' +    PICFLAG= +    SHLIB=unused-shlib +  fi +fi + +AC_SUBST(ALLLIBS) +AC_SUBST(PICFLAG) +AC_SUBST(SHLIB) +AC_SUBST(SHLIB_CC) +AC_SUBST(SHLIB_CFLAGS) +if test "${commonbfdlib}" = "true"; then +  COMMON_SHLIB=yes +  # Rebuild the shared library if libiberty or libbfd changes. +  SHLIB_DEP="../libiberty/libiberty.a ../bfd/libbfd.a" +else +  COMMON_SHLIB= +  SHLIB_DEP= +fi +AC_SUBST(COMMON_SHLIB) +AC_SUBST(SHLIB_DEP) +AC_SUBST(SHLINK) + +AC_CHECK_HEADERS(string.h strings.h) + +# target-specific stuff: + +# Canonicalize the secondary target names. +if test -n "$enable_targets" ; then +    for targ in `echo $enable_targets | sed 's/,/ /g'` +    do +	result=`$ac_config_sub $targ 2>/dev/null` +	if test -n "$result" ; then +	    canon_targets="$canon_targets $result" +	else +	    # Allow targets that config.sub doesn't recognize, like "all". +	    canon_targets="$canon_targets $targ" +	fi +    done +fi + +all_targets=false +selarchs= +for targ in $target $canon_targets +do +    if test "x$targ" = "xall" ; then +        all_targets=true +    else +	. $srcdir/../bfd/config.bfd +	selarchs="$selarchs $targ_archs" +    fi +done	 + +# We don't do any links based on the target system, just makefile config. + +if test x${all_targets} = xfalse ; then + +    # Target architecture .o files. +    ta= + +    for arch in $selarchs +    do +	ad=`echo $arch | sed -e s/bfd_//g -e s/_arch//g` +	archdefs="$archdefs -DARCH_$ad" +	case "$arch" in +	bfd_a29k_arch)		ta="$ta a29k-dis.o" ;; +	bfd_alliant_arch)	;; +	bfd_alpha_arch)		ta="$ta alpha-dis.o" ;; +	bfd_arm_arch)		ta="$ta arm-dis.o" ;; +	bfd_convex_arch)	;; +	bfd_h8300_arch)		ta="$ta h8300-dis.o" ;; +	bfd_h8500_arch)		ta="$ta h8500-dis.o" ;; +	bfd_hppa_arch)		ta="$ta hppa-dis.o" ;; +	bfd_i386_arch)		ta="$ta i386-dis.o" ;; +	bfd_i860_arch)		;; +	bfd_i960_arch)		ta="$ta i960-dis.o" ;; +	bfd_m68k_arch)		ta="$ta m68k-dis.o m68k-opc.o" ;; +	bfd_m88k_arch)		ta="$ta m88k-dis.o" ;; +	bfd_mips_arch)		ta="$ta mips-dis.o mips-opc.o" ;; +	bfd_ns32k_arch)		ta="$ta ns32k-dis.o" ;; +	bfd_powerpc_arch)	ta="$ta ppc-dis.o ppc-opc.o" ;; +	bfd_pyramid_arch)	;; +	bfd_romp_arch)		;; +	bfd_rs6000_arch)	ta="$ta ppc-dis.o ppc-opc.o" ;; +	bfd_sh_arch)		ta="$ta sh-dis.o" ;; +	bfd_sparc_arch)		ta="$ta sparc-dis.o sparc-opc.o" ;; +	bfd_tahoe_arch)		;; +	bfd_vax_arch)		;; +	bfd_w65_arch)		ta="$ta w65-dis.o" ;; +	bfd_we32k_arch)		;; +	bfd_z8k_arch)		ta="$ta z8k-dis.o" ;; + +	"")			;; +	*)		AC_MSG_ERROR(*** unknown target architecture $arch) ;; +	esac +    done + +    # Weed out duplicate .o files. +    f="" +    for i in $ta ; do +	case " $f " in +	*" $i "*) ;; +	*) f="$f $i" ;; +	esac +    done +    ta="$f" + +    # And duplicate -D flags. +    f="" +    for i in $archdefs ; do +	case " $f " in +	*" $i "*) ;; +	*) f="$f $i" ;; +	esac +    done +    archdefs="$f" + +    BFD_MACHINES="$ta" + +else	# all_targets is true +    archdefs=-DARCH_all +    BFD_MACHINES='$(ALL_MACHINES)' +fi + +AC_SUBST(archdefs) +AC_SUBST(BFD_MACHINES) + +AC_OUTPUT(Makefile, +[case x$CONFIG_HEADERS in xconfig.h:config.in) echo > stamp-h ;; esac]) diff --git a/contrib/gdb/opcodes/z8k-dis.c b/contrib/gdb/opcodes/z8k-dis.c new file mode 100644 index 000000000000..8890e123120c --- /dev/null +++ b/contrib/gdb/opcodes/z8k-dis.c @@ -0,0 +1,571 @@ +/* +This file is part of GNU Binutils. + +This program 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 2 of the License, or +(at your option) any later version. + +This program 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 this program; if not, write to the Free Software +Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ + +#include <ansidecl.h> +#include "sysdep.h" +#include "dis-asm.h" + +#define DEFINE_TABLE +#include "z8k-opc.h" + + +#include <setjmp.h> + + +typedef struct +{ +  /* These are all indexed by nibble number (i.e only every other entry +     of bytes is used, and every 4th entry of words).  */ +  unsigned char nibbles[24]; +  unsigned char bytes[24]; +  unsigned short words[24]; + +  /* Nibble number of first word not yet fetched.  */ +  int max_fetched; +  bfd_vma insn_start; +  jmp_buf bailout; + +  long tabl_index; +  char instr_asmsrc[80]; +  unsigned long arg_reg[0x0f]; +  unsigned long immediate; +  unsigned long displacement; +  unsigned long address; +  unsigned long cond_code; +  unsigned long ctrl_code; +  unsigned long flags; +  unsigned long interrupts; +} +instr_data_s; + +/* Make sure that bytes from INFO->PRIVATE_DATA->BUFFER (inclusive) +   to ADDR (exclusive) are valid.  Returns 1 for success, longjmps +   on error.  */ +#define FETCH_DATA(info, nibble) \ +  ((nibble) < ((instr_data_s *)(info->private_data))->max_fetched \ +   ? 1 : fetch_data ((info), (nibble))) + +static int +fetch_data (info, nibble) +     struct disassemble_info *info; +     int nibble; +{ +  unsigned char mybuf[20]; +  int status; +  instr_data_s *priv = (instr_data_s *)info->private_data; +  bfd_vma start; + +  if ((nibble % 4) != 0) +    abort (); + +  status = (*info->read_memory_func) (priv->insn_start, +				      (bfd_byte *) mybuf, +				      nibble / 2, +				      info); +  if (status != 0) +    { +      (*info->memory_error_func) (status, priv->insn_start, info); +      longjmp (priv->bailout, 1); +    } + +  { +    int i; +    unsigned char *p = mybuf ; +     +    for (i = 0; i < nibble;) +      { +	priv->words[i] = (p[0] << 8) | p[1]; +	 +	priv->bytes[i] = *p; +	priv->nibbles[i++] = *p >> 4; +	priv->nibbles[i++] = *p &0xf; + +	++p; +	priv->bytes[i] = *p; +	priv->nibbles[i++] = *p >> 4; +	priv->nibbles[i++] = *p & 0xf; + +	++p; +      } +  } +  priv->max_fetched = nibble; +  return 1; +} + +static char *codes[16] = +{ +  "f", +  "lt", +  "le", +  "ule", +  "ov/pe", +  "mi", +  "eq", +  "c/ult", +  "t", +  "ge", +  "gt", +  "ugt", +  "nov/po", +  "pl", +  "ne", +  "nc/uge" +}; + +int z8k_lookup_instr PARAMS ((unsigned char*, disassemble_info *)); +static void output_instr +  PARAMS ((instr_data_s *, unsigned long, disassemble_info *)); +static void unpack_instr PARAMS ((instr_data_s *, int, disassemble_info *)); +static void unparse_instr PARAMS ((instr_data_s *)); + +static int +print_insn_z8k (addr, info, is_segmented) +     bfd_vma addr; +     disassemble_info *info; +     int is_segmented; +{ +  instr_data_s instr_data; + +  info->private_data = (PTR) &instr_data; +  instr_data.max_fetched = 0; +  instr_data.insn_start = addr; +  if (setjmp (instr_data.bailout) != 0) +    /* Error return.  */ +    return -1; + +  instr_data.tabl_index = z8k_lookup_instr (instr_data.nibbles, info); +  if (instr_data.tabl_index > 0) +    { +      unpack_instr (&instr_data, is_segmented, info); +      unparse_instr (&instr_data); +      output_instr (&instr_data, addr, info); +      return z8k_table[instr_data.tabl_index].length; +    } +  else +    { +      FETCH_DATA (info, 4); +      (*info->fprintf_func) (info->stream, ".word %02x%02x", +			     instr_data.bytes[0], instr_data.bytes[2]); +      return 2; +    } +} + +print_insn_z8001 (addr, info) +     bfd_vma addr; +     disassemble_info *info; +{ +  return print_insn_z8k (addr, info, 1); +} + +print_insn_z8002 (addr, info) +     bfd_vma addr; +     disassemble_info *info; +{ +  return print_insn_z8k (addr, info, 0); +} + +int +z8k_lookup_instr (nibbles, info) +     unsigned char *nibbles; +     disassemble_info *info; +{ + +  int nibl_index, tabl_index; +  int nibl_matched; +  unsigned short instr_nibl; +  unsigned short tabl_datum, datum_class, datum_value; + +  nibl_matched = 0; +  tabl_index = 0; +  while (!nibl_matched && z8k_table[tabl_index].name) +    { +      nibl_matched = 1; +      for (nibl_index = 0; nibl_index < z8k_table[tabl_index].length * 2 && nibl_matched; nibl_index++) +	{ +	  if ((nibl_index % 4) == 0) +	    /* Fetch one word at a time.  */ +	    FETCH_DATA (info, nibl_index + 4); +	  instr_nibl = nibbles[nibl_index]; + +	  tabl_datum = z8k_table[tabl_index].byte_info[nibl_index]; +	  datum_class = tabl_datum & CLASS_MASK; +	  datum_value = ~CLASS_MASK & tabl_datum; + +	  switch (datum_class) +	    { +	    case CLASS_BIT: +	      if (datum_value != instr_nibl) +		nibl_matched = 0; +	      break; +	    case CLASS_00II: +	      if (!((~instr_nibl) & 0x4)) +		nibl_matched = 0; +	      break; +	    case CLASS_01II: +	      if (!(instr_nibl & 0x4)) +		nibl_matched = 0; +	      break; +	    case CLASS_0CCC: +	      if (!((~instr_nibl) & 0x8)) +		nibl_matched = 0; +	      break; +	    case CLASS_1CCC: +	      if (!(instr_nibl & 0x8)) +		nibl_matched = 0; +	      break; +	    case CLASS_0DISP7: +	      if (!((~instr_nibl) & 0x8)) +		nibl_matched = 0; +	      nibl_index += 1; +	      break; +	    case CLASS_1DISP7: +	      if (!(instr_nibl & 0x8)) +		nibl_matched = 0; +	      nibl_index += 1; +	      break; +	    case CLASS_REGN0: +	      if (instr_nibl == 0) +		nibl_matched = 0; +	      break; +	    case CLASS_BIT_1OR2: +	      if ((instr_nibl | 0x2) != (datum_value | 0x2)) +		nibl_matched = 0; +	      break; +	    default: +	      break; +	    } +	} +      if (nibl_matched) +	{ +	  return tabl_index; +	} + +      tabl_index++; +    } +  return -1; + +} + +static void +output_instr (instr_data, addr, info) +     instr_data_s *instr_data; +     unsigned long addr; +     disassemble_info *info; +{ +  int loop, loop_limit; +  char tmp_str[20]; +  char out_str[100]; + +  strcpy (out_str, "\t"); + +  loop_limit = z8k_table[instr_data->tabl_index].length * 2; +  FETCH_DATA (info, loop_limit); +  for (loop = 0; loop < loop_limit; loop++) +    { +      sprintf (tmp_str, "%x", instr_data->nibbles[loop]); +      strcat (out_str, tmp_str); +    } + +  while (loop++ < 8) +    { +      strcat (out_str, " "); +    } + +  strcat (out_str, instr_data->instr_asmsrc); + +  (*info->fprintf_func) (info->stream, "%s", out_str); +} + +static void +unpack_instr (instr_data, is_segmented, info) +     instr_data_s *instr_data; +     int is_segmented; +     disassemble_info *info; +{ +  int nibl_count, loop; +  unsigned short instr_nibl, instr_byte, instr_word; +  long instr_long; +  unsigned short tabl_datum, datum_class, datum_value; + +  nibl_count = 0; +  loop = 0; +  while (z8k_table[instr_data->tabl_index].byte_info[loop] != 0) +    { +      FETCH_DATA (info, nibl_count + 4 - (nibl_count % 4)); +      instr_nibl = instr_data->nibbles[nibl_count]; +      instr_byte = instr_data->bytes[nibl_count]; +      instr_word = instr_data->words[nibl_count]; + +      tabl_datum = z8k_table[instr_data->tabl_index].byte_info[loop]; +      datum_class = tabl_datum & CLASS_MASK; +      datum_value = tabl_datum & ~CLASS_MASK; + +      switch (datum_class) +	{ +	case CLASS_X: +	  instr_data->address = instr_nibl; +	  break; +	case CLASS_BA: +	  instr_data->displacement = instr_nibl; +	  break; +	case CLASS_BX: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_DISP: +	  switch (datum_value) +	    { +	    case ARG_DISP16: +	      instr_data->displacement = instr_word; +	      nibl_count += 3; +	      break; +	    case ARG_DISP12: +	      instr_data->displacement = instr_word & 0x0fff; +	      nibl_count += 2; +	      break; +	    default: +	      break; +	    } +	  break; +	case CLASS_IMM: +	  switch (datum_value) +	    { +	    case ARG_IMM4: +	      instr_data->immediate = instr_nibl; +	      break; +	    case ARG_NIM8: +	      instr_data->immediate = (-instr_byte); +	      nibl_count += 1; +	      break; +	    case ARG_IMM8: +	      instr_data->immediate = instr_byte; +	      nibl_count += 1; +	      break; +	    case ARG_IMM16: +	      instr_data->immediate = instr_word; +	      nibl_count += 3; +	      break; +	    case ARG_IMM32: +	      FETCH_DATA (info, nibl_count + 8); +	      instr_long = (instr_data->words[nibl_count] << 16) +		| (instr_data->words[nibl_count + 4]); +	      instr_data->immediate = instr_long; +	      nibl_count += 7; +	      break; +	    case ARG_IMMN: +	      instr_data->immediate = instr_nibl - 1; +	      break; +	    case ARG_IMM4M1: +	      instr_data->immediate = instr_nibl + 1; +	      break; +	    case ARG_IMM_1: +	      instr_data->immediate = 1; +	      break; +	    case ARG_IMM_2: +	      instr_data->immediate = 2; +	      break; +	    case ARG_IMM2: +	      instr_data->immediate = instr_nibl & 0x3; +	      break; +	    default: +	      break; +	    } +	  break; +	case CLASS_CC: +	  instr_data->cond_code = instr_nibl; +	  break; +	case CLASS_CTRL: +	  instr_data->ctrl_code = instr_nibl; +	  break; +	case CLASS_DA: +	case CLASS_ADDRESS: +	  if (is_segmented) +	    { +	      if (instr_nibl & 0x8) +		{ +		  FETCH_DATA (info, nibl_count + 8); +		  instr_long = (instr_data->words[nibl_count] << 16) +		    | (instr_data->words[nibl_count + 4]); +		  instr_data->address = ((instr_word & 0x7f00) << 8) + +		    (instr_long & 0xffff); +		  nibl_count += 7; +		} +	      else +		{ +		  instr_data->address = ((instr_word & 0x7f00) << 8) + +		    (instr_word & 0x00ff); +		  nibl_count += 3; +		} +	    } +	  else +	    { +	      instr_data->address = instr_word; +	      nibl_count += 3; +	    } +	  break; +	case CLASS_0CCC: +	  instr_data->cond_code = instr_nibl & 0x7; +	  break; +	case CLASS_1CCC: +	  instr_data->cond_code = instr_nibl & 0x7; +	  break; +	case CLASS_0DISP7: +	  instr_data->displacement = instr_byte & 0x7f; +	  nibl_count += 1; +	  break; +	case CLASS_1DISP7: +	  instr_data->displacement = instr_byte & 0x7f; +	  nibl_count += 1; +	  break; +	case CLASS_01II: +	  instr_data->interrupts = instr_nibl & 0x3; +	  break; +	case CLASS_00II: +	  instr_data->interrupts = instr_nibl & 0x3; +	  break; +	case CLASS_BIT: +	  /* do nothing */ +	  break; +	case CLASS_IR: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_FLAGS: +	  instr_data->flags = instr_nibl; +	  break; +	case CLASS_REG: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_REG_BYTE: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_REG_WORD: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_REG_QUAD: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_REG_LONG: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	case CLASS_REGN0: +	  instr_data->arg_reg[datum_value] = instr_nibl; +	  break; +	default: +	  break; +	} + +      loop += 1; +      nibl_count += 1; +    } +} + +static void +unparse_instr (instr_data) +     instr_data_s *instr_data; +{ +  unsigned short tabl_datum, datum_class, datum_value; +  int loop, loop_limit; +  char out_str[80], tmp_str[25]; + +  sprintf (out_str, "\t%s\t", z8k_table[instr_data->tabl_index].name); + +  loop_limit = z8k_table[instr_data->tabl_index].noperands; +  for (loop = 0; loop < loop_limit; loop++) +    { +      if (loop) +	strcat (out_str, ","); + +      tabl_datum = z8k_table[instr_data->tabl_index].arg_info[loop]; +      datum_class = tabl_datum & CLASS_MASK; +      datum_value = tabl_datum & ~CLASS_MASK; + +      switch (datum_class) +	{ +	case CLASS_X: +	  sprintf (tmp_str, "0x%0x(R%d)", instr_data->address, +		   instr_data->arg_reg[datum_value]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_BA: +	  sprintf (tmp_str, "r%d(#%x)", instr_data->arg_reg[datum_value], +		   instr_data->immediate); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_BX: +	  sprintf (tmp_str, "r%d(R%d)", instr_data->arg_reg[datum_value], +		   instr_data->arg_reg[ARG_RX]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_DISP: +	  sprintf (tmp_str, "#0x%0x", instr_data->displacement); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_IMM: +	  sprintf (tmp_str, "#0x%0x", instr_data->immediate); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_CC: +	  sprintf (tmp_str, "%s", codes[instr_data->cond_code]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_CTRL: +	  sprintf (tmp_str, "0x%0x", instr_data->ctrl_code); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_DA: +	case CLASS_ADDRESS: +	  sprintf (tmp_str, "#0x%0x", instr_data->address); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_IR: +	  sprintf (tmp_str, "@R%d", instr_data->arg_reg[datum_value]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_FLAGS: +	  sprintf (tmp_str, "0x%0x", instr_data->flags); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_REG_BYTE: +	  if (instr_data->arg_reg[datum_value] >= 0x8) +	    { +	      sprintf (tmp_str, "rl%d", +		       instr_data->arg_reg[datum_value] - 0x8); +	    } +	  else +	    { +	      sprintf (tmp_str, "rh%d", instr_data->arg_reg[datum_value]); +	    } +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_REG_WORD: +	  sprintf (tmp_str, "r%d", instr_data->arg_reg[datum_value]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_REG_QUAD: +	  sprintf (tmp_str, "rq%d", instr_data->arg_reg[datum_value]); +	  strcat (out_str, tmp_str); +	  break; +	case CLASS_REG_LONG: +	  sprintf (tmp_str, "rr%d", instr_data->arg_reg[datum_value]); +	  strcat (out_str, tmp_str); +	  break; +	default: +	  break; +	} +    } + +  strcpy (instr_data->instr_asmsrc, out_str); +} | 
