From: Andrew Cagney <ac131313@redhat.com>
To: "J. Johnston" <jjohnstn@redhat.com>
Cc: Andrew Cagney <ac131313@redhat.com>,
Daniel Jacobowitz <drow@mvista.com>,
Kevin Buettner <kevinb@redhat.com>,
Marcel Moolenaar <marcel@xcllnt.net>,
gdb-patches@sources.redhat.com
Subject: [patch/rfc] Add child_to_xfer_partial; Was: ia64 portion of libunwind patch
Date: Thu, 06 Nov 2003 22:32:00 -0000 [thread overview]
Message-ID: <3FAACBE3.3060104@redhat.com> (raw)
In-Reply-To: <3FA7F97B.4090909@redhat.com>
[-- Attachment #1: Type: text/plain, Size: 752 bytes --]
Jeff,
This adds a child_xfer_partial method to "inftarg.c". I've included a
hook vis:
> +#if 0
> + case TARGET_OBJECT_UNWIND_TABLE:
> +#ifndef NATIVE_XFER_UNWIND_TABLE
> +#define NATIVE_XFER_UNWIND_TABLE(OPS,OBJECT,ANNEX,WRITEBUF,READBUF,OFFSET,LEN)
> (-1)
> +#endif
> + return NATIVE_XFER_UNWIND_TABLE (ops, object, annex, writebuf,
> + readbuf, offset, len);
> +#endif
so that, in theory, all you need do is define that in the linux specific
nm-*.h file.
I think this will make plugging in additional xfer methods easier. How
does it look?
Anyone else?
Andrew
PS: You'll notice that it also contains lurking code to add support for
an auxv transfer.
PPS: Note that I need to better test it.
[-- Attachment #2: diffs --]
[-- Type: text/plain, Size: 1925 bytes --]
2003-11-06 Andrew Cagney <cagney@redhat.com>
* inftarg.c (child_xfer_partial): New function
(init_child_ops): Set "to_xfer_partial".
Index: inftarg.c
===================================================================
RCS file: /cvs/src/src/gdb/inftarg.c,v
retrieving revision 1.18
diff -u -r1.18 inftarg.c
--- inftarg.c 21 Sep 2003 01:26:45 -0000 1.18
+++ inftarg.c 6 Nov 2003 22:20:17 -0000
@@ -551,7 +551,45 @@
*/
return NULL;
}
-\f
+
+/* Perform a partial transfer to/from the specified object. */
+
+static LONGEST
+child_xfer_partial (struct target_ops *ops,
+ enum target_object object,
+ const char *annex, const void *writebuf,
+ void *readbuf, ULONGEST offset, LONGEST len)
+{
+ switch (object)
+ {
+ case TARGET_OBJECT_MEMORY:
+ if (readbuf)
+ return child_xfer_memory (offset, readbuf, len, 0/*write*/,
+ NULL, ops);
+ if (writebuf)
+ return child_xfer_memory (offset, readbuf, len, 1/*write*/,
+ NULL, ops);
+ return -1;
+
+#if 0
+ case TARGET_OBJECT_UNWIND_TABLE:
+#ifndef NATIVE_XFER_UNWIND_TABLE
+#define NATIVE_XFER_UNWIND_TABLE(OPS,OBJECT,ANNEX,WRITEBUF,READBUF,OFFSET,LEN) (-1)
+#endif
+ return NATIVE_XFER_UNWIND_TABLE (ops, object, annex, writebuf,
+ readbuf, offset, len);
+#endif
+
+#if 0
+ case TARGET_OBJECT_AUXV:
+ return native_xfer_auxv (PIDGET (inferior_ptid), writebuf, readbuf,
+ offset, len);
+#endif
+
+ default:
+ return -1;
+ }
+}
#if !defined(CHILD_PID_TO_STR)
char *
@@ -578,6 +616,7 @@
child_ops.to_store_registers = store_inferior_registers;
child_ops.to_prepare_to_store = child_prepare_to_store;
child_ops.to_xfer_memory = child_xfer_memory;
+ child_ops.to_xfer_partial = child_xfer_partial;
child_ops.to_files_info = child_files_info;
child_ops.to_insert_breakpoint = memory_insert_breakpoint;
child_ops.to_remove_breakpoint = memory_remove_breakpoint;
next prev parent reply other threads:[~2003-11-06 22:32 UTC|newest]
Thread overview: 32+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-10-24 0:11 RFA: " J. Johnston
2003-10-24 17:57 ` Kevin Buettner
2003-10-24 18:20 ` J. Johnston
2003-10-24 18:56 ` Kevin Buettner
2003-10-24 21:53 ` Marcel Moolenaar
2003-10-24 23:58 ` Kevin Buettner
2003-10-28 23:53 ` J. Johnston
2003-10-29 1:28 ` Daniel Jacobowitz
2003-10-29 4:48 ` Kevin Buettner
2003-10-29 18:43 ` J. Johnston
2003-10-29 22:48 ` Andrew Cagney
2003-11-04 19:09 ` J. Johnston
2003-11-04 20:48 ` Kevin Buettner
2003-11-06 17:21 ` RFA: ia64 portion of libunwind patch updated J. Johnston
2003-11-14 21:24 ` J. Johnston
2003-11-17 17:01 ` Kevin Buettner
2003-11-17 17:03 ` Kevin Buettner
2003-11-17 17:05 ` Kevin Buettner
2003-11-17 21:40 ` J. Johnston
2003-11-17 22:32 ` Marcel Moolenaar
2003-11-06 20:03 ` [commit] Fix two xfer partial bugs; Was; RFA: ia64 portion of libunwind patch Andrew Cagney
2003-11-06 20:12 ` J. Johnston
2003-11-06 22:32 ` Andrew Cagney [this message]
2003-11-06 22:47 ` [patch/rfc] Add child_to_xfer_partial; Was: " J. Johnston
2003-11-07 21:40 ` Andrew Cagney
2003-11-07 1:04 ` Kevin Buettner
2003-11-14 0:26 ` RFA: " J. Johnston
2003-11-14 1:17 ` Kevin Buettner
2003-11-14 20:49 ` J. Johnston
2003-10-29 23:28 ` Andrew Cagney
2003-11-02 20:39 ` Elena Zannoni
2003-10-29 15:18 ` Andrew Cagney
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3FAACBE3.3060104@redhat.com \
--to=ac131313@redhat.com \
--cc=drow@mvista.com \
--cc=gdb-patches@sources.redhat.com \
--cc=jjohnstn@redhat.com \
--cc=kevinb@redhat.com \
--cc=marcel@xcllnt.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox