 6604b05763
			
		
	
	
		6604b05763
		
	
	
	
	
		
			
			The upcoming follow-fork-mode child support requires post-fork message exchange between the parent and the child. Prepare gdbserver_fork() for this purpose. Rename it to gdbserver_fork_end() to better reflect its purpose. Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com> Message-Id: <20240219141628.246823-8-iii@linux.ibm.com> Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Message-Id: <20240305121005.3528075-9-alex.bennee@linaro.org>
		
			
				
	
	
		
			75 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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 */
 |