 c0bea68f9e
			
		
	
	
		c0bea68f9e
		
	
	
	
	
		
			
			Update the SPARC main loop and sigreturn code: * on TARGET_ERESTARTSYS, wind guest PC backwards to repeat syscall insn * set all guest CPU state within signal.c code on sigreturn * handle TARGET_QEMU_ESIGRETURN in the main loop as the indication that the main loop should not touch any guest CPU state Signed-off-by: Timothy Edward Baldwin <T.E.Baldwin99@members.leeds.ac.uk> Message-id: 1441497448-32489-9-git-send-email-T.E.Baldwin99@members.leeds.ac.uk [PMM: Commit message tweaks; drop TARGET_USE_ERESTARTSYS define] Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
		
			
				
	
	
		
			38 lines
		
	
	
		
			638 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			638 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef TARGET_SIGNAL_H
 | |
| #define TARGET_SIGNAL_H
 | |
| 
 | |
| #include "cpu.h"
 | |
| 
 | |
| /* this struct defines a stack used during syscall handling */
 | |
| 
 | |
| typedef struct target_sigaltstack {
 | |
| 	abi_ulong ss_sp;
 | |
| 	abi_long ss_flags;
 | |
| 	abi_ulong ss_size;
 | |
| } target_stack_t;
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * sigaltstack controls
 | |
|  */
 | |
| #define TARGET_SS_ONSTACK	1
 | |
| #define TARGET_SS_DISABLE	2
 | |
| 
 | |
| #define TARGET_MINSIGSTKSZ	4096
 | |
| #define TARGET_SIGSTKSZ		16384
 | |
| 
 | |
| #ifndef UREG_I6
 | |
| #define UREG_I6        6
 | |
| #endif
 | |
| #ifndef UREG_FP
 | |
| #define UREG_FP        UREG_I6
 | |
| #endif
 | |
| 
 | |
| static inline abi_ulong get_sp_from_cpustate(CPUSPARCState *state)
 | |
| {
 | |
|     return state->regwptr[UREG_FP];
 | |
| }
 | |
| 
 | |
| 
 | |
| #endif /* TARGET_SIGNAL_H */
 |