-configdirs="doc"
+configdirs="doc testsuite"
srcname="GDB"
srctrigger=main.c
# per-host:
+# Map host cpu into the config cpu subdirectory name.
+# The default is $host_cpu.
+
+case "${host_cpu}" in
+
+c[12]) gdb_host_cpu=convex ;;
+hppa*) gdb_host_cpu=pa ;;
+i[34]86) gdb_host_cpu=i386 ;;
+m68*) gdb_host_cpu=m68k ;;
+np1) gdb_host_cpu=gould ;;
+pyramid) gdb_host_cpu=pyr ;;
+*) gdb_host_cpu=$host_cpu ;;
+
+esac
+
# map host info into gdb names.
case "${host}" in
a29k-*-*) gdb_host=ultra3 ;;
+alpha-*-osf*) gdb_host=alpha-osf1 ;;
+
arm-*-*) gdb_host=arm ;;
c[12]-*-*) gdb_host=convex ;;
-hppa*-hp-bsd) gdb_host=hppabsd ;;
-hppa*-hp-hpux) gdb_host=hppahpux ;;
+hppa*-*-bsd*) gdb_host=hppabsd ;;
+hppa*-*-hpux*) gdb_host=hppahpux ;;
+hppa*-*-hiux*) gdb_host=hppahpux ;;
i[34]86-ncr-*) gdb_host=ncr3000 ;;
-i[34]86-sequent-*) gdb_host=symmetry ;;
+i[34]86-sequent-bsd*) gdb_host=symmetry ;; #dynix
+i[34]86-sequent-sysv*) gdb_host=ptx ;;
+i[34]86-*-aix*) gdb_host=i386aix ;;
i[34]86-*-bsd*) gdb_host=i386bsd ;;
+i[34]86-*-netbsd*) gdb_host=i386bsd ;;
i[34]86-*-go32) gdb_host=go32 ;;
i[34]86-*-linux) gdb_host=linux ;;
+i[34]86-*-lynx*) gdb_host=i386lynx ;;
i[34]86-*-mach) gdb_host=i386mach ;;
-i[34]86-*-scosysv*) gdb_host=i386sco ;;
+i[34]86-*-sco3.2v4*) gdb_host=i386sco4 ;;
+i[34]86-*-sco*) gdb_host=i386sco ;;
i[34]86-*-solaris*) gdb_host=i386sol2 ;;
i[34]86-*-sunos*) gdb_host=sun386 ;;
-i[34]86-*-sysv32) gdb_host=i386v32 ;;
+i[34]86-*-sysv3.2) gdb_host=i386v32 ;;
i[34]86-*-sysv4*) gdb_host=i386v4 ;;
i[34]86-*-sysv*) gdb_host=i386v ;;
+i[34]86-*-isc*) gdb_host=i386v32 ;;
-i860-*-*) gdb_host=stratus ;;
-
-m68000-sun-sunos3*) gdb_host=sun2os3 ;;
-m68000-sun-sunos4*) gdb_host=sun2os4 ;;
-
+m680[01]0-sun-sunos3*) gdb_host=sun2os3 ;;
+m680[01]0-sun-sunos4*) gdb_host=sun2os4 ;;
m68030-sony-*) gdb_host=news1000 ;;
-m68k-altos-*) gdb_host=altos ;;
-
-m68k-apollo*-sysv*) gdb_host=apollo68v ;;
-
-m68k-apollo*-bsd*) gdb_host=apollo68b ;;
-
-m68k-att-*) gdb_host=3b1 ;;
-
-m68k-cbm-sysv4*) gdb_host=amix ;;
-
-m68k-hp-bsd) gdb_host=hp300bsd ;;
-m68k-hp-hpux) gdb_host=hp300hpux ;;
-
-m68k-isi-*) gdb_host=isi ;;
-
-m68k-sony-*) gdb_host=news ;;
-
-m68k-sun-sunos3*) gdb_host=sun3os3 ;;
-m68k-sun-sunos4*) gdb_host=sun3os4 ;;
-m68k-sun-*) gdb_host=sun3os4 ;;
-
-m88k-motorola-*) gdb_host=delta88 ;;
-m88k-*-*) gdb_host=m88k ;;
+m68*-altos-*) gdb_host=altos ;;
+m68*-apollo*-sysv*) gdb_host=apollo68v ;;
+m68*-apollo*-bsd*) gdb_host=apollo68b ;;
+m68*-att-*) gdb_host=3b1 ;;
+m68*-bull*-sysv*) gdb_host=dpx2 ;;
+m68*-cbm-sysv4*) gdb_host=amix ;;
+m68*-hp-bsd*) gdb_host=hp300bsd ;;
+m68*-hp-hpux*) gdb_host=hp300hpux ;;
+m68*-isi-*) gdb_host=isi ;;
+m68*-motorola-*) gdb_host=delta68 ;;
+m68*-sony-*) gdb_host=news ;;
+m68*-sun-sunos3*) gdb_host=sun3os3 ;;
+m68*-sun-sunos4*) gdb_host=sun3os4 ;;
+m68*-sun-*) gdb_host=sun3os4 ;;
+
+m88*-motorola-sysv4*) gdb_host=delta88v4 ;;
+m88*-motorola-sysv*) gdb_host=delta88 ;;
+# I suspect this is just used for DGUX
+m88*-*-*) gdb_host=m88k ;;
mips-dec-*) gdb_host=decstation ;;
mips-little-*) gdb_host=littlemips ;;
mips-sgi-irix3) gdb_host=irix3 ;;
-mips-sgi-irix4) gdb_host=irix4 ;;
-mips-sony-*) gdb_host=bigmips ;;
+mips-sgi-irix4*) gdb_host=irix4 ;;
+mips-sony-*) gdb_host=news-mips ;;
+mips-*-sysv*) gdb_host=riscos ;;
+mips-*-riscos*) gdb_host=riscos ;;
none-*-*) gdb_host=none ;;
tahoe-*-*) gdb_host=tahoe ;;
vax-*-bsd*) gdb_host=vaxbsd ;;
+vax-*-ultrix2*) gdb_host=vaxult2 ;;
vax-*-ultrix*) gdb_host=vaxult ;;
esac
-if [ ! -f ${srcdir}/config/${gdb_host}.mh ]; then
+if [ ! -f ${srcdir}/config/${gdb_host_cpu}/${gdb_host}.mh ]; then
echo '***' "Gdb does not support host ${host}" 1>&2
exit 1
fi
# We really shouldn't depend on there being a space after XM_FILE= ...
-hostfile=`awk '$1 == "XM_FILE=" { print $2 }' <${srcdir}/config/${gdb_host}.mh`
+hostfile=`awk '$1 == "XM_FILE=" { print $2 }' <${srcdir}/config/${gdb_host_cpu}/${gdb_host}.mh`
# per-target:
+# Map target cpu into the config cpu subdirectory name.
+# The default is $target_cpu.
+
+case "${target_cpu}" in
+
+alpha) gdb_target_cpu=alpha ;;
+c[12]) gdb_target_cpu=convex ;;
+hppa*) gdb_target_cpu=pa ;;
+i[34]86) gdb_target_cpu=i386 ;;
+m68*) gdb_target_cpu=m68k ;;
+m8*) gdb_target_cpu=m88k ;;
+np1) gdb_target_cpu=gould ;;
+pn) gdb_target_cpu=gould ;;
+pyramid) gdb_target_cpu=pyr ;;
+sparclite) gdb_target_cpu=sparc
+ configdirs="${configdirs} sparclite"
+ ;;
+sparc*) gdb_target_cpu=sparc ;;
+*) gdb_target_cpu=$target_cpu ;;
+
+esac
+
+# map target info into gdb names.
+
case "${target}" in
a29k-*-aout) gdb_target=a29k ;;
a29k-*-sym1) gdb_target=ultra3 ;;
a29k-*-udi) gdb_target=a29k-udi ;;
+alpha-*-osf*) gdb_target=alpha-osf1 ;;
+
arm-*-*) gdb_target=arm ;;
c1-*-*) gdb_target=convex ;;
c2-*-*) gdb_target=convex ;;
h8300-*-*) gdb_target=h8300hms ;;
+h8300h-*-*) gdb_target=h8300hms gdb_target_cpu=h8300 ;;
+h8500-*-*) gdb_target=h8500hms ;;
+
+sh-*-*) gdb_target=sh ;;
-hppa*-*-bsd) gdb_target=hppabsd ;;
-hppa*-*-hpux) gdb_target=hppahpux ;;
+hppa*-*-bsd*) gdb_target=hppabsd ;;
+hppa*-*-hpux*) gdb_target=hppahpux ;;
+hppa*-*-hiux*) gdb_target=hppahiux ;;
i[34]86-sequent-*) gdb_target=symmetry ;;
i[34]86-ncr-*) gdb_target=ncr3000 ;;
i[34]86-*-coff) gdb_target=i386v ;;
i[34]86-*-elf) gdb_target=i386v ;;
+i[34]86-*-aix*) gdb_target=i386aix ;;
i[34]86-*-bsd*) gdb_target=i386bsd ;;
+i[34]86-*-netbsd*) gdb_target=i386bsd ;;
+i[34]86-*-go32) gdb_target=i386aout ;;
+i[34]86-*-lynx*) gdb_target=i386lynx
+ configdirs="${configdirs} gdbserver"
+ ;;
i[34]86-*-solaris*) gdb_target=i386sol2 ;;
i[34]86-*-sunos*) gdb_target=sun386 ;;
i[34]86-*-sysv4*) gdb_target=i386v4 ;;
-i[34]86-*-scosysv3*) gdb_target=i386v ;;
+i[34]86-*-sco*) gdb_target=i386v ;;
i[34]86-*-sysv*) gdb_target=i386v ;;
-i[34]86-*-linux) gdb_target=linux ;;
-
-i860-*-*) gdb_target=stratus ;;
+i[34]86-*-linux*) gdb_target=linux ;;
+i[34]86-*-isc*) gdb_target=i386v ;;
+i[34]86-*-netware*) gdb_target=i386nw ;;
i960-*-bout) gdb_target=vxworks960 ;;
i960-*-coff) gdb_target=nindy960 ;;
i960-*-nindy) gdb_target=nindy960 ;;
i960-*-vxworks) gdb_target=vxworks960 ;;
-m68000-ericsson-*) gdb_target=es1800 ;;
-
m68000-*-sunos3*) gdb_target=sun2os3 ;;
m68000-*-sunos4*) gdb_target=sun2os4 ;;
-m680[01234]0-*-vxworks) gdb_target=vxworks68 ;;
-
-m68030-sony-*) gdb_target=news1000 ;;
-
-m68k-altos-*) gdb_target=altos ;;
-m68k-att-*) gdb_target=3b1 ;;
-
-m68k-cbm-sysv4*) gdb_target=amix ;;
-
-m68k-ericsson-*) gdb_target=es1800 ;;
-
-m68k-hp-bsd) gdb_target=hp300bsd ;;
-m68k-hp-hpux) gdb_target=hp300hpux ;;
-
-m68k-isi-*) gdb_target=isi ;;
-
-m68k-netx-*) gdb_target=vxworks68 ;;
-
-m68k-sony-*) gdb_target=news ;;
-
-m68k-*-aout) gdb_target=m68k-un ;;
-m68k-*-coff) gdb_target=m68k-noun ;;
-m68k-*-elf) gdb_target=m68k-noun ;;
-
-m68k-*-sunos3*) gdb_target=sun3os3 ;;
-m68k-*-sunos4*) gdb_target=sun3os4 ;;
-
-m68k-*-vxworks*) gdb_target=vxworks68 ;;
-
-m68k-*-os68k) gdb_target=os68k ;;
-
-m68kmote-tandem-*) gdb_target=st2000 ;;
-
-m88k-motorola-*) gdb_target=delta88 ;;
-m88k-*-*) gdb_target=m88k ;;
+m68*-cbm-sysv4*) gdb_target=amix ;;
+m68*-bull-sysv*) gdb_target=dpx2 ;;
+m68*-hp-bsd*) gdb_target=hp300bsd ;;
+m68*-hp-hpux*) gdb_target=hp300hpux ;;
+
+m68*-altos-*) gdb_target=altos ;;
+m68*-att-*) gdb_target=3b1 ;;
+m68*-ericsson-*) gdb_target=es1800 ;;
+m68*-isi-*) gdb_target=isi ;;
+m68*-motorola-*) gdb_target=delta68 ;;
+m68*-netx-*) gdb_target=vxworks68 ;;
+m68*-sony-*) gdb_target=news ;;
+m68*-tandem-*) gdb_target=st2000 ;;
+
+m68*-rom68k-*) gdb_target=monitor ;;
+m68*-*bug-*) gdb_target=monitor ;;
+m68*-monitor-*) gdb_target=monitor ;;
+
+m68*-*-aout) gdb_target=m68k-em ;;
+m68*-*-coff) gdb_target=m68k-em ;;
+m68*-*-elf) gdb_target=m68k-em ;;
+m68*-*-os68k) gdb_target=os68k ;;
+m68*-*-sunos3*) gdb_target=sun3os3 ;;
+m68*-*-sunos4*) gdb_target=sun3os4 ;;
+m68*-*-vxworks*) gdb_target=vxworks68 ;;
+
+m88*-motorola-sysv4*) gdb_target=delta88v4 ;;
+m88*-motorola-*) gdb_target=delta88 ;;
+m88*-*-*) gdb_target=m88k ;;
mips-big-*) gdb_target=bigmips ;;
mips-dec-*) gdb_target=decstation ;;
+mips-idt-ecoffl*) gdb_target=idtl ;;
+mips-idt-ecoff*) gdb_target=idt ;;
mips-little-*) gdb_target=littlemips ;;
mips-sgi-*) gdb_target=irix3 ;;
mips-sony-*) gdb_target=bigmips ;;
+mips-*-sysv*) gdb_target=bigmips ;;
+mips-*-riscos*) gdb_target=bigmips ;;
none-*-*) gdb_target=none ;;
rs6000-*-*) gdb_target=rs6000 ;;
-sparc-*-aout) gdb_target=sparc-un ;;
-sparc-*-coff) gdb_target=sparc-noun ;;
-sparc-*-elf) gdb_target=sparc-noun ;;
+sparc-*-aout) gdb_target=sparc-em ;;
+sparc-*-coff) gdb_target=sparc-em ;;
+sparc-*-elf) gdb_target=sparc-em ;;
sparc-*-solaris2*) gdb_target=sun4sol2 ;;
sparc-*-sunos4*) gdb_target=sun4os4 ;;
-sparc-*-vxworks*) gdb_target=sparc-un ;;
+sparc-*-vxworks*) gdb_target=vxsparc ;;
sparc-*-*) gdb_target=sun4os4 ;;
+sparclite*-*-*) gdb_target=sparclite ;;
+# start-sanitize-v9
+sparc64-*-*) gdb_target_cpu=sparc gdb_target=sp64 ;;
+# end-sanitize-v9
tahoe-*-*) gdb_target=tahoe ;;
vax-*-*) gdb_target=vax ;;
+z8k-*-sim | z8k-*-coff) gdb_target=z8ksim ;;
esac
-if [ ! -f ${srcdir}/config/${gdb_target}.mt ]; then
+if [ ! -f ${srcdir}/config/${gdb_target_cpu}/${gdb_target}.mt ]; then
echo '***' "Gdb does not support target ${target}" 1>&2
exit 1
fi
if [ -z "${removing}" ] ; then
- cat ${srcdir}/config/${gdb_host}.mh ${srcdir}/config/${gdb_target}.mt | awk '$1 == "#msg" {
+ cat ${srcdir}/config/${gdb_host_cpu}/${gdb_host}.mh ${srcdir}/config/${gdb_target_cpu}/${gdb_target}.mt | awk '$1 == "#msg" {
print substr($0,6)}'
fi
# We really shouldn't depend on there being a space after TM_FILE= ...
-targetfile=`awk '$1 == "TM_FILE=" { print $2 }' <${srcdir}/config/${gdb_target}.mt`
+targetfile=`awk '$1 == "TM_FILE=" { print $2 }' <${srcdir}/config/${gdb_target_cpu}/${gdb_target}.mt`
if [ "${target}" = "${host}" ] ; then
- nativefile=`awk '$1 == "NAT_FILE=" { print $2 }' <${srcdir}/config/${gdb_host}.mh`
+ nativefile=`awk '$1 == "NAT_FILE=" { print $2 }' <${srcdir}/config/${gdb_host_cpu}/${gdb_host}.mh`
fi
-host_makefile_frag=config/${gdb_host}.mh
-target_makefile_frag=config/${gdb_target}.mt
+host_makefile_frag=config/${gdb_host_cpu}/${gdb_host}.mh
+target_makefile_frag=config/${gdb_target_cpu}/${gdb_target}.mt
# If hostfile (XM_FILE) and/or targetfile (TM_FILE) and/or nativefile
# (NAT_FILE) is not set in the ?config/* file, we don't make the
links=
rm -f xm.h
if [ "${hostfile}" != "" ]; then
- files="${files} ${hostfile}"
+ if [ -f ${srcdir}/config/${hostfile} ]; then
+ files="${files} config/${hostfile}"
+ else
+ files="${files} config/${gdb_host_cpu}/${hostfile}"
+ fi
links="${links} xm.h"
fi
rm -f tm.h
if [ "${targetfile}" != "" ]; then
- files="${files} ${targetfile}"
+ if [ -f ${srcdir}/config/${targetfile} ]; then
+ files="${files} config/${targetfile}"
+ else
+ files="${files} config/${gdb_target_cpu}/${targetfile}"
+ fi
links="${links} tm.h"
fi
-rm -f nat.h
+rm -f nm.h
if [ "${nativefile}" != "" ]; then
- files="${files} ${nativefile}"
+ if [ -f ${srcdir}/config/${nativefile} ]; then
+ files="${files} config/${nativefile}"
+ else
+ files="${files} config/${gdb_host_cpu}/${nativefile}"
+ fi
links="${links} nm.h"
# temporary scaffolding until all hosts have the host/target/native
# split in place.
else
- files="${files} nm-trash.h"
+ files="${files} config/nm-trash.h"
links="${links} nm.h"
fi
.)
;;
*)
- grep -s "source ${srcdir}/.gdbinit" .gdbinit 2>/dev/null || \
+ grep "source ${srcdir}/.gdbinit" .gdbinit >/dev/null 2>/dev/null || \
echo "source ${srcdir}/.gdbinit" >> .gdbinit
esac
< Makefile > Makefile.tem
mv -f Makefile.tem Makefile
fi
-
-cat ${srcdir}/alldeps.mak ${srcdir}/depend >>Makefile