diff options
author | oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60> | 2008-04-13 13:29:33 +0000 |
---|---|---|
committer | oharboe <oharboe@b42882b7-edfa-0310-969c-e2dbd0fdcd60> | 2008-04-13 13:29:33 +0000 |
commit | f62ba3550762cded4a857e2c2763b3c2f6436e5d (patch) | |
tree | f890713f20a1fa4583dc3faf0d37053b9647620d /src/server | |
parent | 7280d4a2c74f444e81d5a2df8b77a2f184f5e6d1 (diff) | |
download | openocd_libswd-f62ba3550762cded4a857e2c2763b3c2f6436e5d.tar.gz openocd_libswd-f62ba3550762cded4a857e2c2763b3c2f6436e5d.tar.bz2 openocd_libswd-f62ba3550762cded4a857e2c2763b3c2f6436e5d.tar.xz openocd_libswd-f62ba3550762cded4a857e2c2763b3c2f6436e5d.zip |
More robust handling of unknown target state for step/continue packet.
git-svn-id: svn://svn.berlios.de/openocd/trunk@573 b42882b7-edfa-0310-969c-e2dbd0fdcd60
Diffstat (limited to 'src/server')
-rw-r--r-- | src/server/gdb_server.c | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/src/server/gdb_server.c b/src/server/gdb_server.c index 3e4ba824..bd247b01 100644 --- a/src/server/gdb_server.c +++ b/src/server/gdb_server.c @@ -1855,12 +1855,24 @@ int gdb_input_inner(connection_t *connection) case 'c': case 's': { - /* We're running/stepping, in which case we can - * forward log output until the target is halted */ - gdb_connection_t *gdb_con = connection->priv; - gdb_con->frontend_state = TARGET_RUNNING; - log_add_callback(gdb_log_callback, connection); - gdb_step_continue_packet(connection, target, packet, packet_size); + if (target->state != TARGET_HALTED) + { + /* If the target isn't in the halted state, then we can't + * step/continue. This might be early setup, etc. + */ + char sig_reply[4]; + snprintf(sig_reply, 4, "T%2.2x", 2); + gdb_put_packet(connection, sig_reply, 3); + } else + { + /* We're running/stepping, in which case we can + * forward log output until the target is halted + */ + gdb_connection_t *gdb_con = connection->priv; + gdb_con->frontend_state = TARGET_RUNNING; + log_add_callback(gdb_log_callback, connection); + gdb_step_continue_packet(connection, target, packet, packet_size); + } } break; case 'v': |