diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2005-04-26 20:42:36 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2005-04-26 20:42:36 +0000 |
commit | e90096763d74b1126cf502c2d710d64df5ecbb63 (patch) | |
tree | 8ddd7ea84a000d60f3b17a73cce36b9562f2fd3c | |
parent | 43fb823b5f89c6d716e2cbce603c6fb1ca6c0b2f (diff) |
report user mode gdb exit codes (Paul Brook)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1401 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | gdbstub.c | 16 | ||||
-rw-r--r-- | gdbstub.h | 1 | ||||
-rw-r--r-- | linux-user/syscall.c | 2 |
3 files changed, 19 insertions, 0 deletions
@@ -656,6 +656,22 @@ gdb_handlesig (CPUState *env, int sig) } return sig; } + +/* Tell the remote gdb that the process has exited. */ +void gdb_exit(CPUState *env, int code) +{ + GDBState *s; + char buf[4]; + + if (gdbserver_fd < 0) + return; + + s = &gdbserver_state; + + snprintf(buf, sizeof(buf), "W%02x", code); + put_packet(s, buf); +} + #else static int gdb_can_read(void *opaque) { @@ -5,6 +5,7 @@ #ifdef CONFIG_USER_ONLY int gdb_handlesig (CPUState *, int); +void gdb_exit(CPUState *, int); #endif int gdbserver_start(int); diff --git a/linux-user/syscall.c b/linux-user/syscall.c index b00ce90cbf..0a4f07e31d 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -1603,6 +1603,7 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3, #ifdef HAVE_GPROF _mcleanup(); #endif + gdb_exit(cpu_env, arg1); /* XXX: should free thread stack and CPU env */ _exit(arg1); ret = 0; /* avoid warning */ @@ -2409,6 +2410,7 @@ long do_syscall(void *cpu_env, int num, long arg1, long arg2, long arg3, #ifdef __NR_exit_group /* new thread calls */ case TARGET_NR_exit_group: + gdb_exit(cpu_env, arg1); ret = get_errno(exit_group(arg1)); break; #endif |