12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- /*
- * gdbstub user-mode only APIs
- *
- * Copyright (c) 2022 Linaro Ltd
- *
- * SPDX-License-Identifier: LGPL-2.0-or-later
- */
- #ifndef GDBSTUB_USER_H
- #define GDBSTUB_USER_H
- #define MAX_SIGINFO_LENGTH 128
- /**
- * gdb_handlesig() - 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
- * @siginfo: target-specific siginfo struct
- * @siginfo_len: target-specific siginfo struct length
- *
- * 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(CPUState *, int, const char *, void *, int);
- /**
- * 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 */
|