aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Kingdon <jkingdon@engr.sgi.com>1993-03-31 21:45:59 +0000
committerJim Kingdon <jkingdon@engr.sgi.com>1993-03-31 21:45:59 +0000
commitaff22f452f0c5688b6512c35d7e24d702e7e1631 (patch)
tree71e682aa811bdb3bc84ccf0e2342380d121d48dc
parent5d0734a7d74cf01b73303aeb884b719b4b220035 (diff)
downloadgdb-aff22f452f0c5688b6512c35d7e24d702e7e1631.zip
gdb-aff22f452f0c5688b6512c35d7e24d702e7e1631.tar.gz
gdb-aff22f452f0c5688b6512c35d7e24d702e7e1631.tar.bz2
New file dis-buf.c; part of read_memory_func changes just checked it
-rw-r--r--opcodes/dis-buf.c54
1 files changed, 54 insertions, 0 deletions
diff --git a/opcodes/dis-buf.c b/opcodes/dis-buf.c
new file mode 100644
index 0000000..279aa24
--- /dev/null
+++ b/opcodes/dis-buf.c
@@ -0,0 +1,54 @@
+/* Disassemble from a buffer, for GNU.
+ Copyright (C) 1993 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., 675 Mass Ave, Cambridge, MA 02139, USA. */
+
+#include "dis-asm.h"
+#include <errno.h>
+
+/* Get LENGTH bytes from info's buffer, at target address memaddr.
+ Transfer them to myaddr. */
+int
+buffer_read_memory (memaddr, myaddr, length, info)
+ bfd_vma memaddr;
+ bfd_byte *myaddr;
+ int length;
+ struct disassemble_info *info;
+{
+ if (memaddr < info->buffer_vma
+ || memaddr + length > info->buffer_vma + info->buffer_length)
+ /* Out of bounds. Use EIO because GDB uses it. */
+ return EIO;
+ memcpy (myaddr, info->buffer + (memaddr - info->buffer_vma), length);
+ return 0;
+}
+
+/* Print an error message. We can assume that this is in response to
+ an error return from buffer_read_memory. */
+void
+perror_memory (status, memaddr, info)
+ int status;
+ bfd_vma memaddr;
+ struct disassemble_info *info;
+{
+ if (status != EIO)
+ /* Can't happen. */
+ (*info->fprintf_func) (info->stream, "Unknown error %d\n", status);
+ else
+ /* Actually, address between memaddr and memaddr + len was
+ out of bounds. */
+ (*info->fprintf_func) (info->stream,
+ "Address 0x%x is out of bounds.\n", memaddr);
+}