diff options
author | nobody <> | 1998-12-21 20:06:34 +0000 |
---|---|---|
committer | nobody <> | 1998-12-21 20:06:34 +0000 |
commit | 94228bd3ca403b6bad17f96e32db7b8cf2e870c6 (patch) | |
tree | c5c2deb54b366a5a36d119a4132689b3a939fd51 /gdb/remote-adapt.c | |
parent | be9485d5f52e873f1a66f55f34a70fda754fce1f (diff) | |
download | binutils-94228bd3ca403b6bad17f96e32db7b8cf2e870c6.zip binutils-94228bd3ca403b6bad17f96e32db7b8cf2e870c6.tar.gz binutils-94228bd3ca403b6bad17f96e32db7b8cf2e870c6.tar.bz2 |
This commit was manufactured by cvs2svn to create branch 'FSF'.
Sprout from master 1991-11-19 05:16:47 UTC Stu Grossman <grossman@cygnus> 'Initial revision'
Cherrypick from master 1998-12-21 20:06:33 UTC Elena Zannoni <ezannoni@kwikemart.cygnus.com> 'Initial revision':
readline/INSTALL
readline/bind.c
readline/config.h.in
readline/doc/Makefile.in
readline/examples/histexamp.c
readline/isearch.c
readline/parens.c
readline/search.c
readline/shell.c
readline/support/install.sh
readline/support/mkdirs
readline/tilde.c
readline/tilde.h
readline/xmalloc.c
Cherrypick from master 1991-05-21 19:55:06 UTC K. Richard Pixley <rich@cygnus> 'Initial revision':
readline/Makefile.in
readline/configure
readline/readline.c
Cherrypick from master 1994-01-16 03:39:57 UTC Per Bothner <per@bothner.com> ' Merge in changes from bash-1.13. The most obvious one is':
readline/complete.c
readline/display.c
readline/rldefs.h
Delete:
.Sanitize
DOC.Sanitize
DOC.configure
INSTALL
Makefile.in
README.configure
SUPPORTED
bfd/.Sanitize
bfd/COPYING
bfd/ChangeLog
bfd/Makefile
bfd/Makefile.in
bfd/TODO
bfd/VERSION
bfd/aout-encap.c
bfd/aout.c
bfd/aout32.c
bfd/aout64.c
bfd/aoutf1.h
bfd/aoutx.c
bfd/aoutx.h
bfd/archive.c
bfd/archures.c
bfd/archures.h
bfd/awkscan
bfd/awkscan-ip
bfd/awkscan-p
bfd/bfd-in.h
bfd/bfd.c
bfd/bfd.doc
bfd/bfd.doc.ps
bfd/bfd.texinfo
bfd/blins-p
bfd/bout.c
bfd/cache.c
bfd/coff-a29k.c
bfd/coff-code.h
bfd/coff-i386.c
bfd/coff-i960.c
bfd/coff-m68k.c
bfd/coff-m88k.c
bfd/coff-mips.c
bfd/coff-rs6000.c
bfd/coffcode.h
bfd/coffish.h
bfd/coffswap.c
bfd/config.sub
bfd/configure
bfd/configure.in
bfd/core.c
bfd/cplus-dem.c
bfd/cpu-a29k.c
bfd/cpu-h8300.c
bfd/cpu-i386.c
bfd/cpu-i960.c
bfd/cpu-m88k.c
bfd/cpu-rs6000.c
bfd/cpu-vax.c
bfd/ctor.c
bfd/demo64.c
bfd/doc/.Sanitize
bfd/doc/Makefile
bfd/doc/Makefile.in
bfd/doc/awkscan
bfd/doc/awkscan-ip
bfd/doc/awkscan-p
bfd/doc/bfd.info
bfd/doc/bfd.texinfo
bfd/doc/bfdinfo
bfd/doc/blins-p
bfd/doc/configure.in
bfd/doc/exfil1-p
bfd/doc/exfil3-p
bfd/doc/exfilter
bfd/doc/exfilter-p
bfd/doc/exfiltst
bfd/doc/exmerge
bfd/doc/intobfd
bfd/doc/mergecom-p
bfd/doc/movecom-p
bfd/doc/scanit
bfd/doc/scanph
bfd/doc/sedscript
bfd/doc/sedscript-p
bfd/doc/startcom-p
bfd/doc/tolibbfd
bfd/doc/tolibcoff
bfd/doc/unPROTO
bfd/elf.c
bfd/exfilter
bfd/exmerge
bfd/filemode.c
bfd/format.c
bfd/host-aout.c
bfd/hosts/.Sanitize
bfd/hosts/amix.h
bfd/hosts/decstation.h
bfd/hosts/delta88.h
bfd/hosts/dgux.h
bfd/hosts/dose.h
bfd/hosts/h-m68kv.h
bfd/hosts/harris.h
bfd/hosts/hp9000.h
bfd/hosts/i386mach.h
bfd/hosts/i386v.h
bfd/hosts/irix3.h
bfd/hosts/rs6000.h
bfd/hosts/rtbsd.h
bfd/hosts/sparc-ll.h
bfd/hosts/sparc.h
bfd/hosts/sun3.h
bfd/hosts/tahoe.h
bfd/hosts/ultra3.h
bfd/hosts/vaxbsd.h
bfd/hosts/vaxult.h
bfd/howto.c
bfd/i386aout.c
bfd/ieee.c
bfd/init.c
bfd/intobfd
bfd/libaout.h
bfd/libbfd-in.h
bfd/libbfd.c
bfd/libbfd.h
bfd/libcoff.h
bfd/libieee.h
bfd/liboasys.h
bfd/mergecom-p
bfd/misc.c
bfd/misc.h
bfd/movecom-p
bfd/newsos3.c
bfd/oasys.c
bfd/obstack.c
bfd/obstack.h
bfd/opncls.c
bfd/reloc.c
bfd/scanit
bfd/scanph
bfd/section.c
bfd/sedscript
bfd/sedscript-p
bfd/srec.c
bfd/startcom-p
bfd/sunos.c
bfd/syms.c
bfd/targets.c
bfd/tolibbfd
bfd/tolibcoff
bfd/trad-core.c
bfd/trad-core.h
bfd/unPROTO
binutils/.Sanitize
binutils/ChangeLog
binutils/Makefile.in
binutils/README
binutils/TODO
binutils/alloca.c
binutils/am29k-pinsn.c
binutils/ar.1
binutils/ar.c
binutils/binutils.texi
binutils/binutils.texinfo
binutils/bucomm.c
binutils/config.sub
binutils/configure
binutils/configure.in
binutils/copy.c
binutils/cplus-dem.c
binutils/filemode.c
binutils/gmalloc.c
binutils/i960-pinsn.c
binutils/is-ranlib.c
binutils/is-strip.c
binutils/m68k-pinsn.c
binutils/maybe-ranlib.c
binutils/maybe-strip.c
binutils/nm.1
binutils/nm.c
binutils/not-ranlib.c
binutils/not-strip.c
binutils/objdump.1
binutils/objdump.c
binutils/ostrip.c
binutils/ranlib.1
binutils/ranlib.sh
binutils/size.1
binutils/size.c
binutils/sparc-pinsn.c
binutils/strip.1
binutils/strip.c
binutils/version.c
config.sub
config/.Sanitize
config/mh-delta88
config/mh-dgux
config/mh-sco
config/mh-svr4
config/mh-sysv
config/mt-a29k
config/mt-ebmon29k
configure
configure.in
gas/.Sanitize
gas/.gdbinit
gas/COPYING
gas/ChangeLog
gas/GNUmakefile-host
gas/Makefile-intel
gas/Makefile.generic
gas/Makefile.in
gas/Makefile.loic
gas/Makefile.old
gas/NOTES
gas/NOTES.config
gas/README
gas/README-vms-dbg
gas/README.coff
gas/README.rich
gas/VERSION
gas/a.out.gnu.h
gas/app.c
gas/as.c
gas/as.h
gas/atof-generic.c
gas/bignum-copy.c
gas/bignum.h
gas/cond.c
gas/config.sub
gas/config/.Sanitize
gas/config/a.out.h
gas/config/atof-ieee.c
gas/config/atof-vax.c
gas/config/coff.gnu.h
gas/config/cplus-dem.c
gas/config/ebmon29k.mt
gas/config/h8300.mt
gas/config/h8300hds.mt
gas/config/ho-a29k.h
gas/config/ho-ansi.h
gas/config/ho-cygnus.h
gas/config/ho-decstation.h
gas/config/ho-generic.h
gas/config/ho-hpux.h
gas/config/ho-i386.h
gas/config/ho-rs6000.h
gas/config/ho-sun3.h
gas/config/ho-sun386.h
gas/config/ho-sun4.h
gas/config/ho-sunos.h
gas/config/ho-sysv.h
gas/config/ho-vax.h
gas/config/m68k.mt
gas/config/mh-a29k
gas/config/mh-cygnus
gas/config/mh-i386
gas/config/mips.mt
gas/config/obj-aout.c
gas/config/obj-aout.h
gas/config/obj-bfd-sunos.c
gas/config/obj-bfd-sunos.h
gas/config/obj-bout.c
gas/config/obj-bout.h
gas/config/obj-coff.c
gas/config/obj-coff.h
gas/config/obj-generic.c
gas/config/obj-generic.h
gas/config/obj-ieee.c
gas/config/obj-ieee.h
gas/config/ranlib.h
gas/config/rs6000.mt
gas/config/signame.h
gas/config/stab.h
gas/config/tc-a29k.c
gas/config/tc-a29k.h
gas/config/tc-generic.c
gas/config/tc-generic.h
gas/config/tc-h8300.c
gas/config/tc-i386.c
gas/config/tc-i386.h
gas/config/tc-i860.c
gas/config/tc-i860.h
gas/config/tc-i960.c
gas/config/tc-i960.h
gas/config/tc-m68851.h
gas/config/tc-m68k.c
gas/config/tc-m68k.h
gas/config/tc-ns32k.c
gas/config/tc-ns32k.h
gas/config/tc-rs6000.c
gas/config/tc-rs6000.h
gas/config/tc-sparc.c
gas/config/tc-sparc.h
gas/config/tc-vax.c
gas/config/tc-vax.h
gas/config/te-dpx2.h
gas/config/te-generic.h
gas/config/te-ic960.h
gas/config/te-motor.h
gas/config/te-sco386.h
gas/config/te-sparc.h
gas/config/te-sun3.h
gas/config/te-sysv32.h
gas/config/te-unisoft.h
gas/config/tmake-sun3
gas/config/vax-inst.h
gas/config/vms/.Sanitize
gas/config/vms/objrecdef.h
gas/config/vms/vms-dbg.c
gas/config/vms/vms.c
gas/configure
gas/configure.in
gas/configure.was
gas/debug.c
gas/doc/Makefile
gas/doc/a29k-coff.m4
gas/doc/a29k.m4
gas/doc/all.m4
gas/doc/as.texinfo
gas/doc/gen.m4
gas/doc/i80386.m4
gas/doc/i960.m4
gas/doc/m680x0.m4
gas/doc/none.m4
gas/doc/pretex.m4
gas/doc/sparc.m4
gas/doc/vax.m4
gas/doc/vintage.m4
gas/expr.c
gas/expr.h
gas/flonum-const.c
gas/flonum-copy.c
gas/flonum-mult.c
gas/flonum.h
gas/frags.c
gas/frags.h
gas/hash.c
gas/hash.h
gas/hex-value.c
gas/input-file.c
gas/input-file.h
gas/input-scrub.c
gas/link.cmd
gas/make-gas.com
gas/messages.c
gas/obj.h
gas/objdump.c
gas/obsolete/gdb-blocks.c
gas/obsolete/gdb-file.c
gas/obsolete/gdb-lines.c
gas/obsolete/gdb-symbols.c
gas/obsolete/gdb.c
gas/output-file.c
gas/output-file.h
gas/read.c
gas/read.h
gas/strstr.c
gas/struc-symbol.h
gas/subsegs.c
gas/subsegs.h
gas/symbols.c
gas/symbols.h
gas/tc.h
gas/testscripts/doboth
gas/testscripts/doobjcmp
gas/testscripts/dostriptest
gas/testscripts/dotest
gas/testscripts/dounsortreloc
gas/testscripts/dounsortsymbols
gas/ver960.c
gas/version.c
gas/write.c
gas/write.h
gas/xmalloc.c
gas/xrealloc.c
gdb/.Sanitize
gdb/.gdbinit
gdb/Attic/Makefile.in
gdb/COPYING
gdb/ChangeLog
gdb/ChangeLog-3.x
gdb/Convex.notes
gdb/Makefile
gdb/Makefile.dist
gdb/Makefile.in
gdb/Makefile.sdir
gdb/Makefile.srcdir
gdb/Projects
gdb/README
gdb/TODO
gdb/WHATS.NEW
gdb/alldeps.mak
gdb/alloca.c
gdb/altos-xdep.c
gdb/am29k-opcode.h
gdb/am29k-pinsn.c
gdb/am29k-tdep.c
gdb/ansidecl.h
gdb/arm-convert.s
gdb/arm-opcode.h
gdb/arm-pinsn.c
gdb/arm-tdep.c
gdb/arm-xdep.c
gdb/blockframe.c
gdb/breakpoint.c
gdb/breakpoint.h
gdb/buildsym.c
gdb/buildsym.h
gdb/c-exp.y
gdb/coffread.c
gdb/command.c
gdb/command.h
gdb/config.gdb
gdb/config.status
gdb/config.sub
gdb/config/.Sanitize
gdb/config/3b1.mh
gdb/config/3b1.mt
gdb/config/a29k-kern.mt
gdb/config/a29k.mt
gdb/config/altos.mh
gdb/config/altos.mt
gdb/config/altosgas.mh
gdb/config/altosgas.mt
gdb/config/am29k
gdb/config/amix.mh
gdb/config/amix.mt
gdb/config/arm.mh
gdb/config/arm.mt
gdb/config/bigmips.mh
gdb/config/bigmips.mt
gdb/config/convex.mh
gdb/config/convex.mt
gdb/config/decstation.mh
gdb/config/decstation.mt
gdb/config/delta88.mh
gdb/config/delta88.mt
gdb/config/hp300bsd.mh
gdb/config/hp300bsd.mt
gdb/config/hp300hpux.mh
gdb/config/hp300hpux.mt
gdb/config/i386aout.mt
gdb/config/i386mach.mh
gdb/config/i386sco.mh
gdb/config/i386sco.mt
gdb/config/i386v-g.mh
gdb/config/i386v-g.mt
gdb/config/i386v.mh
gdb/config/i386v.mt
gdb/config/i386v32-g.mh
gdb/config/i386v32-g.mt
gdb/config/i386v32.mh
gdb/config/i386v32.mt
gdb/config/i960.mt
gdb/config/irix3.mh
gdb/config/irix3.mt
gdb/config/isi.mh
gdb/config/isi.mt
gdb/config/littlemips.mh
gdb/config/littlemips.mt
gdb/config/m88k.mh
gdb/config/m88k.mt
gdb/config/merlin.mh
gdb/config/merlin.mt
gdb/config/mh-vax
gdb/config/news.mh
gdb/config/news.mt
gdb/config/news1000.mh
gdb/config/news1000.mt
gdb/config/nindy960.mt
gdb/config/none.mh
gdb/config/none.mt
gdb/config/np1.mh
gdb/config/np1.mt
gdb/config/pn.mh
gdb/config/pn.mt
gdb/config/pyramid.mh
gdb/config/pyramid.mt
gdb/config/rs6000.mh
gdb/config/rs6000.mt
gdb/config/rtbsd.mh
gdb/config/sun2os3.mh
gdb/config/sun2os3.mt
gdb/config/sun2os4.mh
gdb/config/sun2os4.mt
gdb/config/sun3.mh
gdb/config/sun3.mt
gdb/config/sun386.mh
gdb/config/sun386.mt
gdb/config/sun3os3.mh
gdb/config/sun3os3.mt
gdb/config/sun3os4.mh
gdb/config/sun3os4.mt
gdb/config/sun4.mh
gdb/config/sun4.mt
gdb/config/sun4os3.mh
gdb/config/sun4os3.mt
gdb/config/sun4os4.mh
gdb/config/sun4os4.mt
gdb/config/symmetry.mh
gdb/config/symmetry.mt
gdb/config/tahoe.mh
gdb/config/tahoe.mt
gdb/config/ultra3.mh
gdb/config/ultra3.mt
gdb/config/umax.mh
gdb/config/umax.mt
gdb/config/vax.mt
gdb/config/vxworks68.mt
gdb/config/vxworks960.mt
gdb/configure
gdb/configure.in
gdb/convex-opcode.h
gdb/convex-pinsn.c
gdb/convex-tdep.c
gdb/convex-xdep.c
gdb/convx-opcode.h
gdb/copying.awk
gdb/copying.c
gdb/core.c
gdb/coredep.c
gdb/cplus-dem.c
gdb/createtags
gdb/dbxread.c
gdb/defs.h
gdb/depend
gdb/doc/.Sanitize
gdb/doc/Makefile
gdb/doc/Makefile.in
gdb/doc/all.m4
gdb/doc/amd29k.m4
gdb/doc/configure.in
gdb/doc/gdb.alter-m4
gdb/doc/gdb.bugs-m4
gdb/doc/gdb.canned-m4
gdb/doc/gdb.cmds-m4
gdb/doc/gdb.ctl-m4
gdb/doc/gdb.data-m4
gdb/doc/gdb.emacs-m4
gdb/doc/gdb.files-m4
gdb/doc/gdb.gpl-m4
gdb/doc/gdb.install-m4
gdb/doc/gdb.invoc-m4
gdb/doc/gdb.rdln-m4
gdb/doc/gdb.rename-m4
gdb/doc/gdb.run-m4
gdb/doc/gdb.sample-m4
gdb/doc/gdb.src-m4
gdb/doc/gdb.stack-m4
gdb/doc/gdb.stop-m4
gdb/doc/gdb.symb-m4
gdb/doc/gdb.texinfo
gdb/doc/gdb.tgts-m4
gdb/doc/gdb.top-m4
gdb/doc/gdbint.texinfo
gdb/doc/gdbinv-m.m4
gdb/doc/gdbinv-m.m4.in
gdb/doc/gdbinv-s.m4
gdb/doc/gdbinv-s.m4.in
gdb/doc/gen.m4
gdb/doc/i80386.m4
gdb/doc/i960.m4
gdb/doc/interim-gdb.texinfo
gdb/doc/interim-gdbinv-m.m4
gdb/doc/interim-gdbinv-s.m4
gdb/doc/m680x0.m4
gdb/doc/none.m4
gdb/doc/pretex.m4
gdb/doc/rc-cm.tex
gdb/doc/rc-ps.tex
gdb/doc/rc-pslong.tex
gdb/doc/rdl-apps.texi
gdb/doc/refcard.tex
gdb/doc/sparc.m4
gdb/doc/threecol.tex
gdb/doc/vax.m4
gdb/dwarfread.c
gdb/elfread.c
gdb/environ.c
gdb/environ.h
gdb/eval.c
gdb/exec.c
gdb/expprint.c
gdb/expread.tab.c
gdb/expread.y
gdb/expression.h
gdb/findvar.c
gdb/frame.h
gdb/gdb-int.texinfo
gdb/gdbcmd.h
gdb/gdbcore.h
gdb/getpagesize.h
gdb/gmalloc.c
gdb/gmalloc.h
gdb/gould-pinsn.c
gdb/gould-xdep.c
gdb/hp300hpux-xdep.c
gdb/hp300ux-xdep.c
gdb/i386-pinsn.c
gdb/i386-tdep.c
gdb/i386-xdep.c
gdb/i387-tdep.c
gdb/i960-pinsn.c
gdb/i960-tdep.c
gdb/ieee-float.c
gdb/ieee-float.h
gdb/infcmd.c
gdb/inferior.h
gdb/inflow.c
gdb/infptrace.c
gdb/infrun.c
gdb/infrun.hacked.c
gdb/inftarg.c
gdb/kdb-start.c
gdb/language.c
gdb/language.h
gdb/m2-exp.y
gdb/m68k-opcode.h
gdb/m68k-pinsn.c
gdb/m68k-stub.c
gdb/m68k-tdep.c
gdb/m88k-opcode.h
gdb/m88k-pinsn.c
gdb/m88k-tdep.c
gdb/m88k-xdep.c
gdb/mach386-xdep.c
gdb/main.c
gdb/mcheck.c
gdb/mem-break.c
gdb/minimon.h
gdb/mips-opcode.h
gdb/mips-pinsn.c
gdb/mips-tdep.c
gdb/mips-xdep.c
gdb/mipsread.c
gdb/mtrace.awk
gdb/mtrace.c
gdb/munch
gdb/news-xdep.c
gdb/nindy-tdep.c
gdb/np1-opcode.h
gdb/ns32k-opcode.h
gdb/ns32k-pinsn.c
gdb/obstack.c
gdb/obstack.h
gdb/param-no-tm.h
gdb/param.h
gdb/parse.c
gdb/parser-defs.h
gdb/pn-opcode.h
gdb/printcmd.c
gdb/procfs.c
gdb/putenv.c
gdb/pyr-opcode.h
gdb/pyr-pinsn.c
gdb/pyr-tdep.c
gdb/pyr-xdep.c
gdb/regex.c
gdb/regex.h
gdb/rem-m68k.shar
gdb/rem-multi.shar
gdb/remote-adapt.c
gdb/remote-eb.c
gdb/remote-mm.c
gdb/remote-multi.shar
gdb/remote-nindy.c
gdb/remote-sa.m68k.shar
gdb/remote-sa.sparc.c
gdb/remote-vx.68.c
gdb/remote-vx.c
gdb/remote.c
gdb/rs6000-pinsn.c
gdb/rs6000-tdep.c
gdb/rs6000-xdep.c
gdb/rs6k-opcode.def
gdb/rs6k-opcode.h
gdb/saber.suppress
gdb/signals.h
gdb/signame.c
gdb/signame.h
gdb/solib.c
gdb/source.c
gdb/sparc-opcode.h
gdb/sparc-pinsn.c
gdb/sparc-tdep.c
gdb/sparc-xdep.c
gdb/stab.def
gdb/stack.c
gdb/standalone.c
gdb/stddef.h
gdb/stdlib.h
gdb/stuff.c
gdb/sun3-xdep.c
gdb/sun386-xdep.c
gdb/symfile.c
gdb/symfile.h
gdb/symm-tdep.c
gdb/symm-xdep.c
gdb/symmetry-tdep.c
gdb/symmetry-xdep.c
gdb/symmisc.c
gdb/symtab.c
gdb/symtab.h
gdb/tahoe-opcode.h
gdb/tahoe-pinsn.c
gdb/target.c
gdb/target.h
gdb/tdesc.c
gdb/tdesc.h
gdb/terminal.h
gdb/tm-29k.h
gdb/tm-3b1.h
gdb/tm-68k.h
gdb/tm-altos.h
gdb/tm-altosgas.h
gdb/tm-amix.h
gdb/tm-arm.h
gdb/tm-bigmips.h
gdb/tm-convex.h
gdb/tm-delta88.h
gdb/tm-hp300bsd.h
gdb/tm-hp300hpux.h
gdb/tm-i386v-g.h
gdb/tm-i386v.h
gdb/tm-i960.h
gdb/tm-irix3.h
gdb/tm-isi.h
gdb/tm-m88k.h
gdb/tm-merlin.h
gdb/tm-mips.h
gdb/tm-news.h
gdb/tm-nindy960.h
gdb/tm-np1.h
gdb/tm-pn.h
gdb/tm-pyr.h
gdb/tm-rs6000.h
gdb/tm-sparc.h
gdb/tm-sun2.h
gdb/tm-sun2os4.h
gdb/tm-sun3.h
gdb/tm-sun386.h
gdb/tm-sun3os4.h
gdb/tm-sun4os4.h
gdb/tm-sunos.h
gdb/tm-svr4.h
gdb/tm-symmetry.h
gdb/tm-tahoe.h
gdb/tm-ultra3.h
gdb/tm-umax.h
gdb/tm-vax.h
gdb/tm-vx68.h
gdb/tm-vx960.h
gdb/tm-vxworks68.h
gdb/tm-vxworks960.h
gdb/ultra3-xdep.c
gdb/umax-xdep.c
gdb/utils.c
gdb/valarith.c
gdb/valops.c
gdb/valprint.c
gdb/value.h
gdb/values.c
gdb/vax-opcode.h
gdb/vax-pinsn.c
gdb/vx-share/.Sanitize
gdb/vx-share/dbgRpcLib.h
gdb/vx-share/ptrace.h
gdb/vx-share/reg.h
gdb/vx-share/vxTypes.h
gdb/vx-share/vxWorks.h
gdb/vx-share/wait.h
gdb/vx-share/xdr_ld.c
gdb/vx-share/xdr_ld.h
gdb/vx-share/xdr_ptrace.c
gdb/vx-share/xdr_ptrace.h
gdb/vx-share/xdr_rdb.c
gdb/vx-share/xdr_rdb.h
gdb/vx-share/xdr_regs.c
gdb/vx-share/xdr_regs.h
gdb/xcoffexec.c
gdb/xcoffread.c
gdb/xm-3b1.h
gdb/xm-altos.h
gdb/xm-amix.h
gdb/xm-arm.h
gdb/xm-bigmips.h
gdb/xm-convex.h
gdb/xm-delta88.h
gdb/xm-hp300bsd.h
gdb/xm-hp300hpux.h
gdb/xm-i386mach.h
gdb/xm-i386sco.h
gdb/xm-i386v.h
gdb/xm-i386v32.h
gdb/xm-irix3.h
gdb/xm-isi.h
gdb/xm-m68k.h
gdb/xm-m88k.h
gdb/xm-merlin.h
gdb/xm-mips.h
gdb/xm-news.h
gdb/xm-news1000.h
gdb/xm-np1.h
gdb/xm-pn.h
gdb/xm-pyr.h
gdb/xm-rs6000.h
gdb/xm-rtbsd.h
gdb/xm-sparc.h
gdb/xm-sun2.h
gdb/xm-sun3.h
gdb/xm-sun386.h
gdb/xm-sun3os4.h
gdb/xm-sun4os4.h
gdb/xm-svr4.h
gdb/xm-symmetry.h
gdb/xm-tahoe.h
gdb/xm-ultra3.h
gdb/xm-umax.h
gdb/xm-vax.h
gprof/Makefile
gprof/Makefile.in
gprof/arcs.c
gprof/config/mt-i386
gprof/config/mt-sparc
gprof/config/tmake-i386
gprof/config/tmake-sparc
gprof/configure
gprof/configure.in
gprof/dfn.c
gprof/gmon.h
gprof/gprof.1
gprof/gprof.c
gprof/gprof.callg
gprof/gprof.flat
gprof/gprof.h
gprof/hertz.c
gprof/i386.c
gprof/i386.h
gprof/lookup.c
gprof/pathnames.h
gprof/printgprof.c
gprof/printlist.c
gprof/sparc.c
gprof/sparc.h
gprof/t.c
gprof/tahoe.c
gprof/tahoe.h
gprof/vax.c
gprof/vax.h
include/.Sanitize
include/COPYING
include/ChangeLog
include/a.out.encap.h
include/a.out.host.h
include/a.out.hp.h
include/a.out.sun4.h
include/a.out.vax.h
include/a29k-opcode.h
include/aout64.h
include/ar.h
include/arm-opcode.h
include/bcs88kcoff.h
include/bfd.h
include/bout.h
include/coff-a29k.h
include/coff-i386.h
include/coff-i960.h
include/coff-m68k.h
include/coff-m88k.h
include/coff-mips.h
include/coff-rs6000.h
include/convx-opcode.h
include/dwarf.h
include/elf-common.h
include/elf-external.h
include/elf-internal.h
include/gdbm.h
include/getopt.h
include/h8300-opcode.h
include/i386-opcode.h
include/i860-opcode.h
include/i960-opcode.h
include/ieee.h
include/internalcoff.h
include/m68k-opcode.h
include/m88k-opcode.h
include/mips-opcode.h
include/np1-opcode.h
include/ns32k-opcode.h
include/oasys.h
include/obstack.h
include/pn-opcode.h
include/pyr-opcode.h
include/ranlib.h
include/reloc.h
include/sparc-opcode.h
include/stab.def
include/stab.gnu.h
include/sysdep.h
include/tahoe-opcode.h
include/vax-opcode.h
include/wait.h
install.texinfo
ld/.Sanitize
ld/ChangeLog
ld/Makefile
ld/Makefile.in
ld/README
ld/config.h
ld/config.sub
ld/config/.Sanitize
ld/config/coff-a29k.mt
ld/config/decstation.mh
ld/config/delta88.mh
ld/config/dgux.mh
ld/config/ebmon29k.mt
ld/config/h-i386v
ld/config/h-m68kv
ld/config/hmake-dec3100
ld/config/hmake-dgux
ld/config/hmake-rtbsd
ld/config/hmake-sun3
ld/config/hmake-sun4
ld/config/hmake-sun4-64
ld/config/i386-aout.mt
ld/config/i386v.mt
ld/config/m68k.mt
ld/config/m68kv.mt
ld/config/m88k-bcs.mt
ld/config/news.mh
ld/config/news.mt
ld/config/rtbsd.mh
ld/config/sparc-ll.mh
ld/config/sparc.mh
ld/config/sun3.mh
ld/config/sun4.mt
ld/config/tmake-coff-a29k
ld/config/tmake-m88k-bcs
ld/config/tmake-sun4
ld/configure
ld/configure.in
ld/ebmon29k.sc
ld/gld.1
ld/h8300hds.c
ld/h8300hds.sc
ld/i386aout.c
ld/i386aout.sc
ld/ld-emul.c
ld/ld-gld-Ur.script
ld/ld-gld-r.script
ld/ld-gld.c
ld/ld-gld.script
ld/ld-gld68k-Ur.script
ld/ld-gld68k-r.script
ld/ld-gld68k.c
ld/ld-gld68k.script
ld/ld-gld960.c
ld/ld-gld960.script
ld/ld-gldm88kbcs-Ur.script
ld/ld-gldm88kbcs-r.script
ld/ld-gldm88kbcs.c
ld/ld-gldm88kbcs.script
ld/ld-lnk960-r.script
ld/ld-lnk960.c
ld/ld-lnk960.script
ld/ld-vanilla.c
ld/ld.h
ld/ld.tex
ld/ld.texinfo
ld/ldemul.c
ld/ldexp.c
ld/ldexp.h
ld/ldfile.c
ld/ldfile.h
ld/ldgld.c
ld/ldgld.sc
ld/ldgld.script
ld/ldgld68k.c
ld/ldgld68k.sc
ld/ldgld68k.script
ld/ldgld68kUr.sc
ld/ldgld68kUr.script
ld/ldgld68kr.sc
ld/ldgld68kr.script
ld/ldgld960.c
ld/ldgld960.sc
ld/ldgld960.script
ld/ldgldUr.sc
ld/ldgldUr.script
ld/ldglda29k.c
ld/ldglda29k.sc
ld/ldglda29k.script
ld/ldglda29kUr.sc
ld/ldglda29kUr.script
ld/ldglda29kr.sc
ld/ldglda29kr.script
ld/ldgldi386v.c
ld/ldgldi386v.sc
ld/ldgldi386vUr.sc
ld/ldgldi386vr.sc
ld/ldgldm68kv.c
ld/ldgldm68kv.sc
ld/ldgldm68kvUr.sc
ld/ldgldm68kvr.sc
ld/ldgldm88kbcs.c
ld/ldgldm88kbcs.sc
ld/ldgldm88kbcs.script
ld/ldgldm88kbcsUr.sc
ld/ldgldm88kbcsUr.script
ld/ldgldm88kbcsr.sc
ld/ldgldm88kbcsr.script
ld/ldgldr.sc
ld/ldgldr.script
ld/ldgram.y
ld/ldindr.c
ld/ldindr.h
ld/ldlang.c
ld/ldlang.h
ld/ldlex.h
ld/ldlex.l
ld/ldlnk960.c
ld/ldlnk960.sc
ld/ldlnk960.script
ld/ldlnk960r.sc
ld/ldlnk960r.script
ld/ldm88k.c
ld/ldm88k.sc
ld/ldm88kUr.sc
ld/ldm88kr.sc
ld/ldmain.c
ld/ldmain.h
ld/ldmisc.c
ld/ldmisc.h
ld/ldsym.c
ld/ldsym.h
ld/ldtemplate
ld/ldvanilla.c
ld/ldver.c
ld/ldver.h
ld/ldwarn.c
ld/ldwarn.h
ld/ldwrite.c
ld/ldwrite.h
ld/mkscript.c
ld/news.sc
readline/.Sanitize
readline/ChangeLog
readline/config.sub
readline/configure.in
readline/doc/Makefile
readline/doc/texindex.c
readline/examples/Makefile
readline/history.texi
readline/history.texinfo
readline/inc-hist.texi
readline/inc-history.texinfo
readline/inc-read.texi
readline/inc-readline.texinfo
readline/readline.texi
readline/readline.texinfo
readline/sysdep-aix.h
readline/sysdep-norm.h
Diffstat (limited to 'gdb/remote-adapt.c')
-rw-r--r-- | gdb/remote-adapt.c | 1448 |
1 files changed, 0 insertions, 1448 deletions
diff --git a/gdb/remote-adapt.c b/gdb/remote-adapt.c deleted file mode 100644 index 6c22422..0000000 --- a/gdb/remote-adapt.c +++ /dev/null @@ -1,1448 +0,0 @@ -/* Remote debugging interface for AMD 290*0 Adapt Monitor Version 2.1d18. - Copyright 1990, 1991 Free Software Foundation, Inc. - Contributed by David Wood at New York University (wood@lab.ultra.nyu.edu). - Adapted from work done at Cygnus Support in remote-eb.c. - -This file is part of GDB. - -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., 675 Mass Ave, Cambridge, MA 02139, USA. */ - -/* This is like remote.c but is for an esoteric situation-- - having a 29k board attached to an Adapt inline monitor. - The monitor is connected via serial line to a unix machine - running gdb. - - 3/91 - developed on Sun3 OS 4.1, by David Wood - o - I can't get binary coff to load. - o - I can't get 19200 baud rate to work. - 7/91 o - Freeze mode tracing can be done on a 29050. */ - -#include <stdio.h> -#include <string.h> -#include "defs.h" -#include "tm.h" -#include "param-no-tm.h" -#include "inferior.h" -#include "wait.h" -#include "value.h" -#include <ctype.h> -#include <fcntl.h> -#include <signal.h> -#include <errno.h> -#include "terminal.h" -#include "target.h" -#include "gdbcore.h" - -/* External data declarations */ -extern int stop_soon_quietly; /* for wait_for_inferior */ - -/* External function declarations */ -extern struct value *call_function_by_hand(); - -/* Forward data declarations */ -extern struct target_ops adapt_ops; /* Forward declaration */ - -/* Forward function declarations */ -static void adapt_fetch_registers (); -static int adapt_store_registers (); -static void adapt_close (); -static int adapt_clear_breakpoints(); - -/* - * Processor types. It is assumed that the adapt has the correct - * ROM for the given processor. - */ -#define TYPE_UNKNOWN 0 -#define TYPE_A29000 1 -#define TYPE_A29030 2 -#define TYPE_A29050 3 -static char *processor_name[] = { "Unknown", "A29000", "A29030", "A29050" }; -static int processor_type=TYPE_UNKNOWN; - -#define FREEZE_MODE (read_register(CPS_REGNUM) && 0x400) -#define USE_SHADOW_PC ((processor_type == TYPE_A29050) && FREEZE_MODE) - - -/* #define DEBUG /* */ -#ifdef DEBUG -# define DENTER(NAME) (printf_filtered("Entering %s\n",NAME), fflush(stdout)) -# define DEXIT(NAME) (printf_filtered("Exiting %s\n",NAME), fflush(stdout)) -#else -# define DENTER(NAME) -# define DEXIT(NAME) -#endif - -/* Can't seem to get binary coff working */ -#define ASCII_COFF /* Adapt will be downloaded with ascii coff */ - -#define LOG_FILE "adapt.log" -#if defined (LOG_FILE) -FILE *log_file=NULL; -#endif - -static int timeout = 5; -static char *dev_name; - -/* Descriptor for I/O to remote machine. Initialize it to -1 so that - adapt_open knows that we don't have a file open when the program - starts. */ -int adapt_desc = -1; - -/* stream which is fdopen'd from adapt_desc. Only valid when - adapt_desc != -1. */ -FILE *adapt_stream; - -#define ON 1 -#define OFF 0 -static void -rawmode(desc, turnon) -int desc; -int turnon; -{ - TERMINAL sg; - - if (desc < 0) - return; - - ioctl (desc, TIOCGETP, &sg); - - if (turnon) { -#ifdef HAVE_TERMIO - sg.c_lflag &= ~(ICANON); -#else - sg.sg_flags |= RAW; -#endif - } else { -#ifdef HAVE_TERMIO - sg.c_lflag |= ICANON; -#else - sg.sg_flags &= ~(RAW); -#endif - } - ioctl (desc, TIOCSETP, &sg); -} - -/* Suck up all the input from the adapt */ -slurp_input() -{ - char buf[8]; - -#ifdef HAVE_TERMIO - /* termio does the timeout for us. */ - while (read (adapt_desc, buf, 8) > 0); -#else - alarm (timeout); - while (read (adapt_desc, buf, 8) > 0); - alarm (0); -#endif -} - -/* Read a character from the remote system, doing all the fancy - timeout stuff. */ -static int -readchar () -{ - char buf; - - buf = '\0'; -#ifdef HAVE_TERMIO - /* termio does the timeout for us. */ - read (adapt_desc, &buf, 1); -#else - alarm (timeout); - if (read (adapt_desc, &buf, 1) < 0) - { - if (errno == EINTR) - error ("Timeout reading from remote system."); - else - perror_with_name ("remote"); - } - alarm (0); -#endif - - if (buf == '\0') - error ("Timeout reading from remote system."); -#if defined (LOG_FILE) - putc (buf & 0x7f, log_file); -#endif - return buf & 0x7f; -} - -/* Keep discarding input from the remote system, until STRING is found. - Let the user break out immediately. */ -static void -expect (string) - char *string; -{ - char *p = string; - - fflush(adapt_stream); - immediate_quit = 1; - while (1) - { - if (readchar() == *p) - { - p++; - if (*p == '\0') - { - immediate_quit = 0; - return; - } - } - else - p = string; - } -} - -/* Keep discarding input until we see the adapt prompt. - - The convention for dealing with the prompt is that you - o give your command - o *then* wait for the prompt. - - Thus the last thing that a procedure does with the serial line - will be an expect_prompt(). Exception: adapt_resume does not - wait for the prompt, because the terminal is being handed over - to the inferior. However, the next thing which happens after that - is a adapt_wait which does wait for the prompt. - Note that this includes abnormal exit, e.g. error(). This is - necessary to prevent getting into states from which we can't - recover. */ -static void -expect_prompt () -{ -#if defined (LOG_FILE) - /* This is a convenient place to do this. The idea is to do it often - enough that we never lose much data if we terminate abnormally. */ - fflush (log_file); -#endif - fflush(adapt_stream); - expect ("\n# "); -} - -/* Get a hex digit from the remote system & return its value. - If ignore_space is nonzero, ignore spaces (not newline, tab, etc). */ -static int -get_hex_digit (ignore_space) - int ignore_space; -{ - int ch; - while (1) - { - ch = readchar (); - if (ch >= '0' && ch <= '9') - return ch - '0'; - else if (ch >= 'A' && ch <= 'F') - return ch - 'A' + 10; - else if (ch >= 'a' && ch <= 'f') - return ch - 'a' + 10; - else if (ch == ' ' && ignore_space) - ; - else - { - expect_prompt (); - error ("Invalid hex digit from remote system."); - } - } -} - -/* Get a byte from adapt_desc and put it in *BYT. Accept any number - leading spaces. */ -static void -get_hex_byte (byt) - char *byt; -{ - int val; - - val = get_hex_digit (1) << 4; - val |= get_hex_digit (0); - *byt = val; -} - -/* Read a 32-bit hex word from the adapt, preceded by a space */ -static long -get_hex_word() -{ - long val; - int j; - - val = 0; - for (j = 0; j < 8; j++) - val = (val << 4) + get_hex_digit (j == 0); - return val; -} -/* Get N 32-bit hex words from remote, each preceded by a space - and put them in registers starting at REGNO. */ -static void -get_hex_regs (n, regno) - int n; - int regno; -{ - long val; - while (n--) { - val = get_hex_word(); - supply_register(regno++,&val); - } -} -/* Called when SIGALRM signal sent due to alarm() timeout. */ -#ifndef HAVE_TERMIO - -#ifndef __STDC__ -# ifndef volatile -# define volatile /**/ -# endif -#endif -volatile int n_alarms; - -void -adapt_timer () -{ -#if 0 - if (kiodebug) - printf ("adapt_timer called\n"); -#endif - n_alarms++; -} -#endif - -/* malloc'd name of the program on the remote system. */ -static char *prog_name = NULL; - -/* Number of SIGTRAPs we need to simulate. That is, the next - NEED_ARTIFICIAL_TRAP calls to adapt_wait should just return - SIGTRAP without actually waiting for anything. */ - -static int need_artificial_trap = 0; - -void -adapt_kill(arg,from_tty) -char *arg; -int from_tty; -{ - DENTER("adapt_kill()"); - fprintf (adapt_stream, "K"); - fprintf (adapt_stream, "\r"); - expect_prompt (); - DEXIT("adapt_kill()"); -} -/* - * Download a file specified in 'args', to the adapt. - * FIXME: Assumes the file to download is a binary coff file. - */ -static void -adapt_load(args,fromtty) -char *args; -int fromtty; -{ - FILE *fp; - int n; - char buffer[1024]; - - DENTER("adapt_load()"); - if (!adapt_stream) { - printf_filtered("Adapt not open. Use 'target' command to open adapt\n"); - return; - } - - /* OK, now read in the file. Y=read, C=COFF, T=dTe port - 0=start address. */ - -#ifdef ASCII_COFF /* Ascii coff */ - fprintf (adapt_stream, "YA T,0\r"); - fflush(adapt_stream); /* Just in case */ - /* FIXME: should check args for only 1 argument */ - sprintf(buffer,"cat %s | btoa > /tmp/#adapt-btoa",args); - system(buffer); - fp = fopen("/tmp/#adapt-btoa","r"); - rawmode(adapt_desc,OFF); - while (n=fread(buffer,1,1024,fp)) { - do { n -= write(adapt_desc,buffer,n); } while (n>0); - if (n<0) { perror("writing ascii coff"); break; } - } - fclose(fp); - rawmode(adapt_desc,ON); - system("rm /tmp/#adapt-btoa"); -#else /* Binary coff - can't get it to work .*/ - fprintf (adapt_stream, "YC T,0\r"); - fflush(adapt_stream); /* Just in case */ - if (!(fp = fopen(args,"r"))) { - printf_filtered("Can't open %s\n",args); - return; - } - while (n=fread(buffer,1,512,fp)) { - do { n -= write(adapt_desc,buffer,n); } while (n>0); - if (n<0) { perror("writing ascii coff"); break; } - } - fclose(fp); -#endif - expect_prompt (); /* Skip garbage that comes out */ - fprintf (adapt_stream, "\r"); - expect_prompt (); - DEXIT("adapt_load()"); -} - -/* This is called not only when we first attach, but also when the - user types "run" after having attached. */ -void -adapt_create_inferior (execfile, args, env) - char *execfile; - char *args; - char **env; -{ - int entry_pt; - - DENTER("adapt_create_inferior()"); - - if (args && *args) - error ("Can't pass arguments to remote adapt process."); - - if (execfile == 0 || exec_bfd == 0) - error ("No exec file specified"); - - entry_pt = (int) bfd_get_start_address (exec_bfd); - - if (adapt_stream) { - adapt_kill(NULL,NULL); - adapt_clear_breakpoints(); - init_wait_for_inferior (); - /* Clear the input because what the adapt sends back is different - * depending on whether it was running or not. - */ - slurp_input(); /* After this there should be a prompt */ - fprintf(adapt_stream,"\r"); - expect_prompt(); - printf_filtered("Do you want to download '%s' (y/n)? [y] : ",prog_name); - { - char buffer[10]; - gets(buffer); - if (*buffer != 'n') { - adapt_load(prog_name,0); - } - } - -#ifdef NOTDEF - /* Set the PC and wait for a go/cont */ - fprintf (adapt_stream, "G %x,N\r",entry_pt); - printf_filtered("Now use the 'continue' command to start.\n"); - expect_prompt (); -#else - insert_breakpoints (); /* Needed to get correct instruction in cache */ - proceed(entry_pt, -1, 0); -#endif - - } else { - printf_filtered("Adapt not open yet.\n"); - } - DEXIT("adapt_create_inferior()"); -} - -/* Translate baud rates from integers to damn B_codes. Unix should - have outgrown this crap years ago, but even POSIX wouldn't buck it. */ - -#ifndef B19200 -#define B19200 EXTA -#endif -#ifndef B38400 -#define B38400 EXTB -#endif - -static struct {int rate, damn_b;} baudtab[] = { - {0, B0}, - {50, B50}, - {75, B75}, - {110, B110}, - {134, B134}, - {150, B150}, - {200, B200}, - {300, B300}, - {600, B600}, - {1200, B1200}, - {1800, B1800}, - {2400, B2400}, - {4800, B4800}, - {9600, B9600}, - {19200, B19200}, - {38400, B38400}, - {-1, -1}, -}; - -static int damn_b (rate) - int rate; -{ - int i; - - for (i = 0; baudtab[i].rate != -1; i++) - if (rate == baudtab[i].rate) return baudtab[i].damn_b; - return B38400; /* Random */ -} - - -/* Open a connection to a remote debugger. - NAME is the filename used for communication, then a space, - then the baud rate. - */ - -static int baudrate = 9600; -static void -adapt_open (name, from_tty) - char *name; - int from_tty; -{ - TERMINAL sg; - unsigned int prl; - char *p; - - DENTER("adapt_open()"); - /* Find the first whitespace character, it separates dev_name from - prog_name. */ - if (name == 0) - goto erroid; - - for (p = name; - *p != '\0' && !isspace (*p); p++) - ; - if (*p == '\0') -erroid: - error ("\ -Please include the name of the device for the serial port,\n\ -the baud rate, and the name of the program to run on the remote system."); - dev_name = (char*)malloc(p - name + 1); - strncpy (dev_name, name, p - name); - dev_name[p - name] = '\0'; - - /* Skip over the whitespace after dev_name */ - for (; isspace (*p); p++) - /*EMPTY*/; - - if (1 != sscanf (p, "%d ", &baudrate)) - goto erroid; - - /* Skip the number and then the spaces */ - for (; isdigit (*p); p++) - /*EMPTY*/; - for (; isspace (*p); p++) - /*EMPTY*/; - - if (prog_name != NULL) - free (prog_name); - prog_name = savestring (p, strlen (p)); - - adapt_close (0); - - adapt_desc = open (dev_name, O_RDWR); - if (adapt_desc < 0) - perror_with_name (dev_name); - ioctl (adapt_desc, TIOCGETP, &sg); -#ifdef HAVE_TERMIO - sg.c_cc[VMIN] = 0; /* read with timeout. */ - sg.c_cc[VTIME] = timeout * 10; - sg.c_lflag &= ~(ICANON | ECHO); - sg.c_cflag = (sg.c_cflag & ~CBAUD) | damn_b (baudrate); -#else - sg.sg_ispeed = damn_b (baudrate); - sg.sg_ospeed = damn_b (baudrate); - sg.sg_flags |= RAW | ANYP; - sg.sg_flags &= ~ECHO; -#endif - - ioctl (adapt_desc, TIOCSETP, &sg); - adapt_stream = fdopen (adapt_desc, "r+"); - - push_target (&adapt_ops); - /* start_remote (); /* Initialize gdb process mechanisms */ - - -#ifndef HAVE_TERMIO -#ifndef NO_SIGINTERRUPT - /* Cause SIGALRM's to make reads fail with EINTR instead of resuming - the read. */ - if (siginterrupt (SIGALRM, 1) != 0) - perror ("adapt_open: error in siginterrupt"); -#endif - - /* Set up read timeout timer. */ - if ((void (*)) signal (SIGALRM, adapt_timer) == (void (*)) -1) - perror ("adapt_open: error in signal"); -#endif - -#if defined (LOG_FILE) - log_file = fopen (LOG_FILE, "w"); - if (log_file == NULL) - perror_with_name (LOG_FILE); -#endif - - /* Put this port into NORMAL mode, send the 'normal' character */ - write(adapt_desc, "", 1); /* Control A */ - write(adapt_desc, "\r", 1); - expect_prompt (); - - /* Hello? Are you there? */ - write (adapt_desc, "\r", 1); - - expect_prompt (); - - /* Clear any break points */ - adapt_clear_breakpoints(); - - /* Determine the processor revision level */ - prl = (unsigned int)read_register(CFG_REGNUM) >> 24; - if (prl == 0x03) { - processor_type = TYPE_A29000; - } else if ((prl&0xf0) == 0x40) { /* 29030 = 0x4* */ - processor_type = TYPE_A29030; - fprintf_filtered(stderr,"WARNING: debugging of A29030 not tested.\n"); - } else if ((prl&0xf0) == 0x20) { /* 29050 = 0x2* */ - processor_type = TYPE_A29050; - fprintf_filtered(stderr,"WARNING: debugging of A29050 not tested.\n"); - } else { - processor_type = TYPE_UNKNOWN; - fprintf_filtered(stderr,"WARNING: processor type unknown.\n"); - } - - /* Print out some stuff, letting the user now what's going on */ - printf_filtered("Remote debugging on an %s connect to an Adapt via %s.\n", - processor_name[processor_type],dev_name); - /* FIXME: can this restriction be removed? */ - printf_filtered("Remote debugging using virtual addresses works only\n"); - printf_filtered("\twhen virtual addresses map 1:1 to physical addresses.\n"); - if (processor_type != TYPE_A29050) { - fprintf_filtered(stderr, - "Freeze-mode debugging not available, and can only be done on an A29050.\n"); - } - DEXIT("adapt_open()"); -} - -/* Close out all files and local state before this target loses control. */ - -static void -adapt_close (quitting) - int quitting; -{ - - DENTER("adapt_close()"); - - /* Clear any break points */ - adapt_clear_breakpoints(); - - /* Put this port back into REMOTE mode */ - if (adapt_stream) { - fflush(adapt_stream); - sleep(1); /* Let any output make it all the way back */ - write(adapt_desc, "R\r", 2); - } - - /* Due to a bug in Unix, fclose closes not only the stdio stream, - but also the file descriptor. So we don't actually close - adapt_desc. */ - if (adapt_stream) - fclose (adapt_stream); /* This also closes adapt_desc */ - if (adapt_desc >= 0) - /* close (adapt_desc); */ - - /* Do not try to close adapt_desc again, later in the program. */ - adapt_stream = NULL; - adapt_desc = -1; - -#if defined (LOG_FILE) - if (log_file) { - if (ferror (log_file)) - printf_filtered ("Error writing log file.\n"); - if (fclose (log_file) != 0) - printf_filtered ("Error closing log file.\n"); - log_file = NULL; - } -#endif - DEXIT("adapt_close()"); -} - -/* Attach to the target that is already loaded and possibly running */ -static void -adapt_attach (args, from_tty) - char *args; - int from_tty; -{ - - DENTER("adapt_attach()"); - if (from_tty) - printf_filtered ("Attaching to remote program %s.\n", prog_name); - - /* push_target(&adapt_ops); /* This done in adapt_open() */ - - mark_breakpoints_out (); - - /* Send the adapt a kill. It is ok if it is not already running */ - fprintf(adapt_stream, "K\r"); fflush(adapt_stream); - expect_prompt(); /* Slurp the echo */ - - /* We will get a task spawn event immediately. */ - init_wait_for_inferior (); - clear_proceed_status (); - stop_soon_quietly = 1; - wait_for_inferior (); - stop_soon_quietly = 0; - normal_stop (); - DEXIT("adapt_attach()"); -} - - -/* Terminate the open connection to the remote debugger. - Use this when you want to detach and do something else - with your gdb. */ -void -adapt_detach (args,from_tty) - char *args; - int from_tty; -{ - DENTER("adapt_detach()"); - if (adapt_stream) { /* Send it on its way (tell it to continue) */ - adapt_clear_breakpoints(); - fprintf(adapt_stream,"G\r"); - } - - pop_target(); /* calls adapt_close to do the real work */ - if (from_tty) - printf_filtered ("Ending remote %s debugging\n", target_shortname); - DEXIT("adapt_detach()"); -} - -/* Tell the remote machine to resume. */ - -void -adapt_resume (step, sig) - int step, sig; -{ - DENTER("adapt_resume()"); - if (step) - { - write (adapt_desc, "t 1,s\r", 6); - /* Wait for the echo. */ - expect ("t 1,s\r\n"); - /* Then comes a line containing the instruction we stepped to. */ - expect ("@"); - /* Then we get the prompt. */ - expect_prompt (); - - /* Force the next adapt_wait to return a trap. Not doing anything - about I/O from the target means that the user has to type - "continue" to see any. FIXME, this should be fixed. */ - need_artificial_trap = 1; - } - else - { - write (adapt_desc, "G\r", 2); - /* Swallow the echo. */ - expect_prompt(); - } - DEXIT("adapt_resume()"); -} - -/* Wait until the remote machine stops, then return, - storing status in STATUS just as `wait' would. */ - -int -adapt_wait (status) - WAITTYPE *status; -{ - /* Strings to look for. '?' means match any single character. - Note that with the algorithm we use, the initial character - of the string cannot recur in the string, or we will not - find some cases of the string in the input. */ - - static char bpt[] = "@"; - /* It would be tempting to look for "\n[__exit + 0x8]\n" - but that requires loading symbols with "yc i" and even if - we did do that we don't know that the file has symbols. */ - static char exitmsg[] = "@????????I JMPTI GR121,LR0"; - char *bp = bpt; - char *ep = exitmsg; - - /* Large enough for either sizeof (bpt) or sizeof (exitmsg) chars. */ - char swallowed[50]; - /* Current position in swallowed. */ - char *swallowed_p = swallowed; - - int ch; - int ch_handled; - int old_timeout = timeout; - int old_immediate_quit = immediate_quit; - - DENTER("adapt_wait()"); - - WSETEXIT ((*status), 0); - - if (need_artificial_trap != 0) - { - WSETSTOP ((*status), SIGTRAP); - need_artificial_trap--; - return 0; - } - - timeout = 0; /* Don't time out -- user program is running. */ - immediate_quit = 1; /* Helps ability to QUIT */ - while (1) { - QUIT; /* Let user quit and leave process running */ - ch_handled = 0; - ch = readchar (); - if (ch == *bp) { - bp++; - if (*bp == '\0') - break; - ch_handled = 1; - - *swallowed_p++ = ch; - } else - bp = bpt; - if (ch == *ep || *ep == '?') { - ep++; - if (*ep == '\0') - break; - - if (!ch_handled) - *swallowed_p++ = ch; - ch_handled = 1; - } else - ep = exitmsg; - if (!ch_handled) { - char *p; - /* Print out any characters which have been swallowed. */ - for (p = swallowed; p < swallowed_p; ++p) - putc (*p, stdout); - swallowed_p = swallowed; - putc (ch, stdout); - } - } - expect_prompt (); - if (*bp== '\0') - WSETSTOP ((*status), SIGTRAP); - else - WSETEXIT ((*status), 0); - timeout = old_timeout; - immediate_quit = old_immediate_quit; - DEXIT("adapt_wait()"); - return 0; -} - -/* Return the name of register number REGNO - in the form input and output by adapt. - - Returns a pointer to a static buffer containing the answer. */ -static char * -get_reg_name (regno) - int regno; -{ - static char buf[80]; - if (regno >= GR96_REGNUM && regno < GR96_REGNUM + 32 ) - sprintf (buf, "GR%03d", regno - GR96_REGNUM + 96); -#if defined(GR64_REGNUM) - else if (regno >= GR64_REGNUM && regno < GR64_REGNUM + 32 ) - sprintf (buf, "GR%03d", regno - GR64_REGNUM + 64); -#endif - else if (regno >= LR0_REGNUM && regno < LR0_REGNUM + 128) - sprintf (buf, "LR%03d", regno - LR0_REGNUM); - else if (regno == Q_REGNUM) - strcpy (buf, "SR131"); - else if (regno >= BP_REGNUM && regno <= CR_REGNUM) - sprintf (buf, "SR%03d", regno - BP_REGNUM + 133); - else if (regno == ALU_REGNUM) - strcpy (buf, "SR132"); - else if (regno >= IPC_REGNUM && regno <= IPB_REGNUM) - sprintf (buf, "SR%03d", regno - IPC_REGNUM + 128); - else if (regno >= VAB_REGNUM && regno <= LRU_REGNUM) { - /* When a 29050 is in freeze-mode, read shadow pcs instead */ - if ((regno >= NPC_REGNUM && regno <= PC2_REGNUM) && USE_SHADOW_PC) - sprintf (buf, "SR%03d", regno - NPC_REGNUM + 20); - else - sprintf (buf, "SR%03d", regno - VAB_REGNUM); - } - else if (regno == GR1_REGNUM) - strcpy (buf, "GR001"); - return buf; -} - -/* Read the remote registers. */ - -static void -adapt_fetch_registers () -{ - int reg_index; - int regnum_index; - char tempbuf[10]; - int sreg_buf[16]; - int i,j; - - DENTER("adapt_fetch_registers()"); - -/* - * Global registers - */ -#if defined(GR64_REGNUM) - write (adapt_desc, "dw gr64,gr95\r", 13); - for (reg_index = 64, regnum_index = GR64_REGNUM; - reg_index < 96; - reg_index += 4, regnum_index += 4) - { - sprintf (tempbuf, "GR%03d ", reg_index); - expect (tempbuf); - get_hex_regs (4, regnum_index); - expect ("\n"); - } -#endif - write (adapt_desc, "dw gr96,gr127\r", 14); - for (reg_index = 96, regnum_index = GR96_REGNUM; - reg_index < 128; - reg_index += 4, regnum_index += 4) - { - sprintf (tempbuf, "GR%03d ", reg_index); - expect (tempbuf); - get_hex_regs (4, regnum_index); - expect ("\n"); - } - -/* - * Local registers - */ - for (i = 0; i < 128; i += 32) - { - /* The PC has a tendency to hang if we get these - all in one fell swoop ("dw lr0,lr127"). */ - sprintf (tempbuf, "dw lr%d\r", i); - write (adapt_desc, tempbuf, strlen (tempbuf)); - for (reg_index = i, regnum_index = LR0_REGNUM + i; - reg_index < i + 32; - reg_index += 4, regnum_index += 4) - { - sprintf (tempbuf, "LR%03d ", reg_index); - expect (tempbuf); - get_hex_regs (4, regnum_index); - expect ("\n"); - } - } - -/* - * Special registers - */ - sprintf (tempbuf, "dw sr0\r"); - write (adapt_desc, tempbuf, strlen (tempbuf)); - for (i=0 ; i<4 ; i++) { /* SR0 - SR14 */ - sprintf (tempbuf, "SR%3d",i*4); - expect(tempbuf); - for (j=0 ; j < (i==3 ? 3 : 4) ; j++) - sreg_buf[i*4 + j] = get_hex_word(); - } - expect_prompt(); - /* - * Read the pcs individually if we are in freeze mode. - * See get_reg_name(), it translates the register names for the pcs to - * the names of the shadow pcs. - */ - if (USE_SHADOW_PC) { - sreg_buf[10] = read_register(NPC_REGNUM); /* pc0 */ - sreg_buf[11] = read_register(PC_REGNUM); /* pc1 */ - sreg_buf[12] = read_register(PC2_REGNUM); /* pc2 */ - } - for (i=0 ; i<14 ; i++) /* Supply vab -> lru */ - supply_register(VAB_REGNUM+i,&sreg_buf[i]); - sprintf (tempbuf, "dw sr128\r"); - write (adapt_desc, tempbuf, strlen (tempbuf)); - for (i=0 ; i<2 ; i++) { /* SR128 - SR135 */ - sprintf (tempbuf, "SR%3d",128 + i*4); - expect(tempbuf); - for (j=0 ; j<4 ; j++) - sreg_buf[i*4 + j] = get_hex_word(); - } - expect_prompt(); - supply_register(IPC_REGNUM,&sreg_buf[0]); - supply_register(IPA_REGNUM,&sreg_buf[1]); - supply_register(IPB_REGNUM,&sreg_buf[2]); - supply_register(Q_REGNUM, &sreg_buf[3]); - /* Skip ALU */ - supply_register(BP_REGNUM, &sreg_buf[5]); - supply_register(FC_REGNUM, &sreg_buf[6]); - supply_register(CR_REGNUM, &sreg_buf[7]); - - /* There doesn't seem to be any way to get these. */ - { - int val = -1; - supply_register (FPE_REGNUM, &val); - supply_register (INT_REGNUM, &val); - supply_register (FPS_REGNUM, &val); - supply_register (EXO_REGNUM, &val); - } - - write (adapt_desc, "dw gr1,gr1\r", 11); - expect ("GR001 "); - get_hex_regs (1, GR1_REGNUM); - expect_prompt (); - - DEXIT("adapt_fetch_registers()"); -} - -/* Fetch register REGNO, or all registers if REGNO is -1. - */ -static void -adapt_fetch_register (regno) - int regno; -{ - DENTER("adapt_fetch_register()"); - if (regno == -1) - adapt_fetch_registers (); - else - { - char *name = get_reg_name (regno); - fprintf (adapt_stream, "dw %s,%s\r", name, name); - expect (name); - expect (" "); - get_hex_regs (1, regno); - expect_prompt (); - } - DEXIT("adapt_fetch_register()"); -} - -/* Store the remote registers from the contents of the block REGS. */ - -static int -adapt_store_registers () -{ - int i, j; - - DENTER("adapt_store_registers()"); - fprintf (adapt_stream, "s gr1,%x\r", read_register (GR1_REGNUM)); - expect_prompt (); - -#if defined(GR64_REGNUM) - for (j = 0; j < 32; j += 16) - { - fprintf (adapt_stream, "s gr%d,", j + 64); - for (i = 0; i < 15; ++i) - fprintf (adapt_stream, "%x,", read_register (GR64_REGNUM + j + i)); - fprintf (adapt_stream, "%x\r", read_register (GR64_REGNUM + j + 15)); - expect_prompt (); - } -#endif - for (j = 0; j < 32; j += 16) - { - fprintf (adapt_stream, "s gr%d,", j + 96); - for (i = 0; i < 15; ++i) - fprintf (adapt_stream, "%x,", read_register (GR96_REGNUM + j + i)); - fprintf (adapt_stream, "%x\r", read_register (GR96_REGNUM + j + 15)); - expect_prompt (); - } - - for (j = 0; j < 128; j += 16) - { - fprintf (adapt_stream, "s lr%d,", j); - for (i = 0; i < 15; ++i) - fprintf (adapt_stream, "%x,", read_register (LR0_REGNUM + j + i)); - fprintf (adapt_stream, "%x\r", read_register (LR0_REGNUM + j + 15)); - expect_prompt (); - } - - fprintf (adapt_stream, "s sr128,%x,%x,%x\r", read_register (IPC_REGNUM), - read_register (IPA_REGNUM), read_register (IPB_REGNUM)); - expect_prompt (); - fprintf (adapt_stream, "s sr133,%x,%x,%x\r", read_register (BP_REGNUM), - read_register (FC_REGNUM), read_register (CR_REGNUM)); - expect_prompt (); - fprintf (adapt_stream, "s sr131,%x\r", read_register (Q_REGNUM)); - expect_prompt (); - fprintf (adapt_stream, "s sr0,"); - for (i=0 ; i<7 ; ++i) - fprintf (adapt_stream, "%x,", read_register (VAB_REGNUM + i)); - expect_prompt (); - fprintf (adapt_stream, "s sr7,"); - for (i=7; i<14 ; ++i) - fprintf (adapt_stream, "%x,", read_register (VAB_REGNUM + i)); - expect_prompt (); -} - -/* Store register REGNO, or all if REGNO == -1. - Return errno value. */ -int -adapt_store_register (regno) - int regno; -{ - /* printf("adapt_store_register() called.\n"); fflush(stdout); /* */ - if (regno == -1) - adapt_store_registers (); - else - { - char *name = get_reg_name (regno); - fprintf (adapt_stream, "s %s,%x\r", name, read_register (regno)); - /* Setting GR1 changes the numbers of all the locals, so - invalidate the register cache. Do this *after* calling - read_register, because we want read_register to return the - value that write_register has just stuffed into the registers - array, not the value of the register fetched from the - inferior. */ - if (regno == GR1_REGNUM) - registers_changed (); - expect_prompt (); - } - DEXIT("adapt_store_registers()"); - return 0; -} - -/* Get ready to modify the registers array. On machines which store - individual registers, this doesn't need to do anything. On machines - which store all the registers in one fell swoop, this makes sure - that registers contains all the registers from the program being - debugged. */ - -void -adapt_prepare_to_store () -{ - /* Do nothing, since we can store individual regs */ -} - -static CORE_ADDR -translate_addr(addr) -CORE_ADDR addr; -{ -#if defined(KERNEL_DEBUGGING) - /* Check for a virtual address in the kernel */ - /* Assume physical address of ublock is in paddr_u register */ - if (addr >= UVADDR) { - /* PADDR_U register holds the physical address of the ublock */ - CORE_ADDR i = (CORE_ADDR)read_register(PADDR_U_REGNUM); - return(i + addr - (CORE_ADDR)UVADDR); - } else { - return(addr); - } -#else - return(addr); -#endif -} - - -/* FIXME! Merge these two. */ -int -adapt_xfer_inferior_memory (memaddr, myaddr, len, write) - CORE_ADDR memaddr; - char *myaddr; - int len; - int write; -{ - - memaddr = translate_addr(memaddr); - - if (write) - return adapt_write_inferior_memory (memaddr, myaddr, len); - else - return adapt_read_inferior_memory (memaddr, myaddr, len); -} - -void -adapt_files_info () -{ - printf_filtered("\tAttached to %s at %d baud and running program %s\n", - dev_name, baudrate, prog_name); - printf_filtered("\ton an %s processor.\n", processor_name[processor_type]); -} - -/* Copy LEN bytes of data from debugger memory at MYADDR - to inferior's memory at MEMADDR. Returns errno value. - * sb/sh instructions don't work on unaligned addresses, when TU=1. - */ -int -adapt_write_inferior_memory (memaddr, myaddr, len) - CORE_ADDR memaddr; - char *myaddr; - int len; -{ - int i; - unsigned int cps; - - /* DENTER("adapt_write_inferior_memory()"); */ - -/* Turn TU bit off so we can do 'sb' commands */ - cps = read_register(CPS_REGNUM); - if (cps & 0x00000800) - write_register(CPS_REGNUM,cps&~(0x00000800)); - - for (i = 0; i < len; i++) - { - if ((i % 16) == 0) - fprintf (adapt_stream, "sb %x,", memaddr + i); - if ((i % 16) == 15 || i == len - 1) - { - fprintf (adapt_stream, "%x\r", ((unsigned char *)myaddr)[i]); - expect_prompt (); - } - else - fprintf (adapt_stream, "%x,", ((unsigned char *)myaddr)[i]); - } - /* Restore the old value of cps if the TU bit was on */ - if (cps & 0x00000800) - write_register(CPS_REGNUM,cps); - /* DEXIT("adapt_write_inferior_memory()"); */ - return len; -} - -/* Read LEN bytes from inferior memory at MEMADDR. Put the result - at debugger address MYADDR. Returns errno value. */ -int -adapt_read_inferior_memory(memaddr, myaddr, len) - CORE_ADDR memaddr; - char *myaddr; - int len; -{ - int i; - - /* Number of bytes read so far. */ - int count; - - /* Starting address of this pass. */ - unsigned long startaddr; - - /* Number of bytes to read in this pass. */ - int len_this_pass; - - /* Note that this code works correctly if startaddr is just less - than UINT_MAX (well, really CORE_ADDR_MAX if there was such a - thing). That is, something like - adapt_read_bytes (CORE_ADDR_MAX - 4, foo, 4) - works--it never adds len to memaddr and gets 0. */ - /* However, something like - adapt_read_bytes (CORE_ADDR_MAX - 3, foo, 4) - doesn't need to work. Detect it and give up if there's an attempt - to do that. */ - /* DENTER("adapt_read_inferior_memory()"); */ - - if (((memaddr - 1) + len) < memaddr) - return EIO; - - startaddr = memaddr; - count = 0; - while (count < len) - { - len_this_pass = 16; - if ((startaddr % 16) != 0) - len_this_pass -= startaddr % 16; - if (len_this_pass > (len - count)) - len_this_pass = (len - count); - - fprintf (adapt_stream, "db %x,%x\r", startaddr, - (startaddr - 1) + len_this_pass); - -#ifdef NOTDEF /* Why do this */ - expect ("\n"); - /* Look for 8 hex digits. */ - i = 0; - while (1) - { - if (isxdigit (readchar ())) - ++i; - else - { - expect_prompt (); - error ("Hex digit expected from remote system."); - } - if (i >= 8) - break; - } -#endif /* NOTDEF */ - - expect (" "); - - for (i = 0; i < len_this_pass; i++) - get_hex_byte (&myaddr[count++]); - - expect_prompt (); - - startaddr += len_this_pass; - } - - /* DEXIT("adapt_read_inferior_memory()"); */ - return count; -} - -#define MAX_BREAKS 8 -static int num_brkpts=0; -static int -adapt_insert_breakpoint(addr, save) -CORE_ADDR addr; -char *save; /* Throw away, let adapt save instructions */ -{ - DENTER("adapt_insert_breakpoint()"); - if (num_brkpts < MAX_BREAKS) { - num_brkpts++; - fprintf (adapt_stream, "B %x", addr); - fprintf (adapt_stream, "\r"); - expect_prompt (); - DEXIT("adapt_insert_breakpoint() success"); - return(0); /* Success */ - } else { - fprintf_filtered(stderr, - "Too many break points, break point not installed\n"); - DEXIT("adapt_insert_breakpoint() failure"); - return(1); /* Failure */ - } - -} -static int -adapt_remove_breakpoint(addr, save) -CORE_ADDR addr; -char *save; /* Throw away, let adapt save instructions */ -{ - DENTER("adapt_remove_breakpoint()"); - if (num_brkpts > 0) { - num_brkpts--; - fprintf (adapt_stream, "BR %x", addr); - fprintf (adapt_stream, "\r"); - fflush (adapt_stream); - expect_prompt (); - } - DEXIT("adapt_remove_breakpoint()"); - return(0); -} - -/* Clear the adapts notion of what the break points are */ -static int -adapt_clear_breakpoints() -{ - DENTER("adapt_clear_breakpoint()"); - if (adapt_stream) { - fprintf (adapt_stream, "BR"); /* Clear all break points */ - fprintf (adapt_stream, "\r"); - fflush(adapt_stream); - expect_prompt (); - } - num_brkpts = 0; - DEXIT("adapt_clear_breakpoint()"); -} -static void -adapt_mourn() -{ - DENTER("adapt_mourn()"); - adapt_clear_breakpoints(); - pop_target (); /* Pop back to no-child state */ - generic_mourn_inferior (); - DEXIT("adapt_mourn()"); -} - -/* Display everthing we read in from the adapt until we match/see the - * specified string - */ -static int -display_until(str) -char *str; -{ - int i=0,j,c; - - while (c=readchar()) { - if (c==str[i]) { - i++; - if (i == strlen(str)) return; - } else { - if (i) { - for (j=0 ; j<i ; j++) /* Put everthing we matched */ - putchar(str[j]); - i=0; - } - putchar(c); - } - } - -} - - -/* Put a command string, in args, out to the adapt. The adapt is assumed to - be in raw mode, all writing/reading done through adapt_desc. - Ouput from the adapt is placed on the users terminal until the - prompt from the adapt is seen. - FIXME: Can't handle commands that take input. */ - -void -adapt_com (args, fromtty) - char *args; - int fromtty; -{ - if (!adapt_stream) { - printf_filtered("Adapt not open. Use the 'target' command to open.\n"); - return; - } - - /* Clear all input so only command relative output is displayed */ - slurp_input(); - - switch(islower(args[0]) ? toupper(args[0]) : args[0]) { - default: - printf_filtered("Unknown/Unimplemented adapt command '%s'\n",args); - break; - case 'G': /* Go, begin execution */ - write(adapt_desc,args,strlen(args)); - write(adapt_desc,"\r",1); - expect_prompt(); - break; - case 'B': /* Break points, B or BR */ - case 'C': /* Check current 29k status (running/halted) */ - case 'D': /* Display data/registers */ - case 'I': /* Input from i/o space */ - case 'J': /* Jam an instruction */ - case 'K': /* Kill, stop execution */ - case 'L': /* Disassemble */ - case 'O': /* Output to i/o space */ - case 'T': /* Trace */ - case 'P': /* Pulse an input line */ - case 'X': /* Examine special purpose registers */ - case 'Z': /* Display trace buffer */ - write(adapt_desc,args,strlen(args)); - write(adapt_desc,"\r",1); - expect(args); /* Don't display the command */ - display_until("# "); - break; - /* Begin commands that take input in the form 'c x,y[,z...]' */ - case 'S': /* Set memory or register */ - if (index(args,',')) { /* Assume it is properly formatted */ - write(adapt_desc,args,strlen(args)); - write(adapt_desc,"\r",1); - expect_prompt(); - } - break; - } -} - -/* Define the target subroutine names */ - -struct target_ops adapt_ops = { - "adapt", "Remote AMD `Adapt' target", - "Remote debug an AMD 290*0 using an `Adapt' monitor via RS232", - adapt_open, adapt_close, - adapt_attach, adapt_detach, adapt_resume, adapt_wait, - adapt_fetch_register, adapt_store_register, - adapt_prepare_to_store, 0, 0, /* conv_to, conv_from */ - adapt_xfer_inferior_memory, - adapt_files_info, - adapt_insert_breakpoint, adapt_remove_breakpoint, /* Breakpoints */ - 0, 0, 0, 0, 0, /* Terminal handling */ - adapt_kill, /* FIXME, kill */ - adapt_load, - call_function_by_hand, - 0, /* lookup_symbol */ - adapt_create_inferior, /* create_inferior */ - adapt_mourn, /* mourn_inferior FIXME */ - process_stratum, 0, /* next */ - 1, 1, 1, 1, 1, /* all mem, mem, stack, regs, exec */ - 0,0, /* Section pointers */ - OPS_MAGIC, /* Always the last thing */ -}; - -void -_initialize_remote_adapt () -{ - add_target (&adapt_ops); - add_com ("adapt <command>", class_obscure, adapt_com, - "Send a command to the AMD Adapt remote monitor."); -} |