| /* |
| * gdbstub user-mode only APIs |
| * |
| * Copyright (c) 2022 Linaro Ltd |
| * |
| * SPDX-License-Identifier: LGPL-2.0+ |
| */ |
| |
| #ifndef GDBSTUB_USER_H |
| #define GDBSTUB_USER_H |
| |
| /** |
| * gdb_handlesig_reason() - yield control to gdb |
| * @cpu: CPU |
| * @sig: if non-zero, the signal number which caused us to stop |
| * @reason: stop reason for stop reply packet or NULL |
| * |
| * This function yields control to gdb, when a user-mode-only target |
| * needs to stop execution. If @sig is non-zero, then we will send a |
| * stop packet to tell gdb that we have stopped because of this signal. |
| * |
| * This function will block (handling protocol requests from gdb) |
| * until gdb tells us to continue target execution. When it does |
| * return, the return value is a signal to deliver to the target, |
| * or 0 if no signal should be delivered, ie the signal that caused |
| * us to stop should be ignored. |
| */ |
| int gdb_handlesig_reason(CPUState *, int, const char *); |
| |
| /** |
| * gdb_handlesig() - yield control to gdb |
| * @cpu CPU |
| * @sig: if non-zero, the signal number which caused us to stop |
| * @see gdb_handlesig_reason() |
| */ |
| static inline int gdb_handlesig(CPUState *cpu, int sig) |
| { |
| return gdb_handlesig_reason(cpu, sig, NULL); |
| } |
| |
| /** |
| * gdb_signalled() - inform remote gdb of sig exit |
| * @as: current CPUArchState |
| * @sig: signal number |
| */ |
| void gdb_signalled(CPUArchState *as, int sig); |
| |
| /** |
| * gdbserver_fork_start() - inform gdb of the upcoming fork() |
| */ |
| void gdbserver_fork_start(void); |
| |
| /** |
| * gdbserver_fork_end() - inform gdb of the completed fork() |
| * @cs: CPU |
| * @pid: 0 if in child process, -1 if fork failed, child process pid otherwise |
| */ |
| void gdbserver_fork_end(CPUState *cs, pid_t pid); |
| |
| /** |
| * gdb_syscall_entry() - inform gdb of syscall entry and yield control to it |
| * @cs: CPU |
| * @num: syscall number |
| */ |
| void gdb_syscall_entry(CPUState *cs, int num); |
| |
| /** |
| * gdb_syscall_entry() - inform gdb of syscall return and yield control to it |
| * @cs: CPU |
| * @num: syscall number |
| */ |
| void gdb_syscall_return(CPUState *cs, int num); |
| |
| #endif /* GDBSTUB_USER_H */ |