diff options
author | Michael Snyder <msnyder@vmware.com> | 2009-07-31 21:33:39 +0000 |
---|---|---|
committer | Michael Snyder <msnyder@vmware.com> | 2009-07-31 21:33:39 +0000 |
commit | 1f4437a49e91afb4c417b09867db5620bf0e0e0a (patch) | |
tree | dad8629003b22c54115ba53b12d30bd82c6529e8 /gdb/remote.c | |
parent | cd000bffb245795be23f4a024481dc192d30cae7 (diff) | |
download | gdb-1f4437a49e91afb4c417b09867db5620bf0e0e0a.zip gdb-1f4437a49e91afb4c417b09867db5620bf0e0e0a.tar.gz gdb-1f4437a49e91afb4c417b09867db5620bf0e0e0a.tar.bz2 |
2009-07-29 Michael Snyder <msnyder@vmware.com>
* remote.c (store_register_using_P): Call putpkt and getpkt
directly instead of calling remote_send.
(store_register_using_G): Ditto.
(fetch_register_using_p): Ditto.
Diffstat (limited to 'gdb/remote.c')
-rw-r--r-- | gdb/remote.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/gdb/remote.c b/gdb/remote.c index ba5c346..d120f8c 100644 --- a/gdb/remote.c +++ b/gdb/remote.c @@ -4873,7 +4873,8 @@ fetch_register_using_p (struct regcache *regcache, struct packet_reg *reg) *p++ = 'p'; p += hexnumstr (p, reg->pnum); *p++ = '\0'; - remote_send (&rs->buf, &rs->buf_size); + putpkt (rs->buf); + getpkt (&rs->buf, &rs->buf_size, 0); buf = rs->buf; @@ -5121,7 +5122,8 @@ remote_prepare_to_store (struct regcache *regcache) packet was not recognized. */ static int -store_register_using_P (const struct regcache *regcache, struct packet_reg *reg) +store_register_using_P (const struct regcache *regcache, + struct packet_reg *reg) { struct gdbarch *gdbarch = get_regcache_arch (regcache); struct remote_state *rs = get_remote_state (); @@ -5141,7 +5143,8 @@ store_register_using_P (const struct regcache *regcache, struct packet_reg *reg) p = buf + strlen (buf); regcache_raw_collect (regcache, reg->regnum, regp); bin2hex (regp, p, register_size (gdbarch, reg->regnum)); - remote_send (&rs->buf, &rs->buf_size); + putpkt (rs->buf); + getpkt (&rs->buf, &rs->buf_size, 0); switch (packet_ok (rs->buf, &remote_protocol_packets[PACKET_P])) { @@ -5189,7 +5192,10 @@ store_registers_using_G (const struct regcache *regcache) /* remote_prepare_to_store insures that rsa->sizeof_g_packet gets updated. */ bin2hex (regs, p, rsa->sizeof_g_packet); - remote_send (&rs->buf, &rs->buf_size); + putpkt (rs->buf); + getpkt (&rs->buf, &rs->buf_size, 0); + if (packet_check_result (rs->buf) == PACKET_ERROR) + error (_("Could not write registers")); } /* Store register REGNUM, or all registers if REGNUM == -1, from the contents |