mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-25 03:03:32 +00:00 
			
		
		
		
	 ba0e733362
			
		
	
	
		ba0e733362
		
	
	
	
	
		
			
			The existing code for safe-syscall.inc.S will compile without change for riscv32 and riscv64. We may also drop the meson.build stanza that merges them for tcg/. Reviewed-by: Warner Losh <imp@bsdimp.com> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
		
			
				
	
	
		
			35 lines
		
	
	
		
			876 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			876 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * hostdep.h : things which are dependent on the host architecture
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2 or later.
 | |
|  * See the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #ifndef RISCV_HOSTDEP_H
 | |
| #define RISCV_HOSTDEP_H
 | |
| 
 | |
| /* We have a safe-syscall.inc.S */
 | |
| #define HAVE_SAFE_SYSCALL
 | |
| 
 | |
| #ifndef __ASSEMBLER__
 | |
| 
 | |
| /* These are defined by the safe-syscall.inc.S file */
 | |
| extern char safe_syscall_start[];
 | |
| extern char safe_syscall_end[];
 | |
| 
 | |
| /* Adjust the signal context to rewind out of safe-syscall if we're in it */
 | |
| static inline void rewind_if_in_safe_syscall(void *puc)
 | |
| {
 | |
|     ucontext_t *uc = puc;
 | |
|     unsigned long *pcreg = &uc->uc_mcontext.__gregs[REG_PC];
 | |
| 
 | |
|     if (*pcreg > (uintptr_t)safe_syscall_start
 | |
|         && *pcreg < (uintptr_t)safe_syscall_end) {
 | |
|         *pcreg = (uintptr_t)safe_syscall_start;
 | |
|     }
 | |
| }
 | |
| 
 | |
| #endif /* __ASSEMBLER__ */
 | |
| 
 | |
| #endif
 |