Skip to content

Commit

Permalink
gdbstub: replace exit calls with proper shutdown for softmmu
Browse files Browse the repository at this point in the history
This replaces the exit calls by shutdown requests, ensuring a proper
cleanup of Qemu. Features like net/vhost-vdpa.c are expecting
qemu_cleanup to be called to remove their last residuals.

Signed-off-by: Clément Chigot <chigot@adacore.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Message-ID: <20231003071427.188697-6-chigot@adacore.com>
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
  • Loading branch information
Helflym authored and alistair23 committed Oct 12, 2023
1 parent 354c960 commit e216256
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 2 deletions.
5 changes: 3 additions & 2 deletions gdbstub/gdbstub.c
Original file line number Diff line number Diff line change
Expand Up @@ -1324,7 +1324,7 @@ static void handle_v_kill(GArray *params, void *user_ctx)
gdb_put_packet("OK");
error_report("QEMU: Terminated via GDBstub");
gdb_exit(0);
exit(0);
gdb_qemu_exit(0);
}

static const GdbCmdParseEntry gdb_v_commands_table[] = {
Expand Down Expand Up @@ -1843,7 +1843,8 @@ static int gdb_handle_packet(const char *line_buf)
/* Kill the target */
error_report("QEMU: Terminated via GDBstub");
gdb_exit(0);
exit(0);
gdb_qemu_exit(0);
break;
case 'D':
{
static const GdbCmdParseEntry detach_cmd_desc = {
Expand Down
6 changes: 6 additions & 0 deletions gdbstub/system.c
Original file line number Diff line number Diff line change
Expand Up @@ -435,6 +435,12 @@ void gdb_exit(int code)
qemu_chr_fe_deinit(&gdbserver_system_state.chr, true);
}

void gdb_qemu_exit(int code)
{
qemu_system_shutdown_request_with_code(SHUTDOWN_CAUSE_GUEST_SHUTDOWN,
code);
}

/*
* Memory access
*/
Expand Down
6 changes: 6 additions & 0 deletions gdbstub/user.c
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,12 @@ void gdb_exit(int code)
gdb_put_packet(buf);
gdbserver_state.allow_stop_reply = false;
}

}

void gdb_qemu_exit(int code)
{
exit(code);
}

int gdb_handlesig(CPUState *cpu, int sig)
Expand Down
9 changes: 9 additions & 0 deletions include/gdbstub/syscalls.h
Original file line number Diff line number Diff line change
Expand Up @@ -110,4 +110,13 @@ int use_gdb_syscalls(void);
*/
void gdb_exit(int code);

/**
* gdb_qemu_exit: ask qemu to exit
* @code: exit code reported
*
* This requests qemu to exit. This function is allowed to return as
* the exit request might be processed asynchronously by qemu backend.
*/
void gdb_qemu_exit(int code);

#endif /* _SYSCALLS_H_ */

0 comments on commit e216256

Please sign in to comment.