Update the tilegx main loop and sigreturn code: * on TARGET_ERESTARTSYS, wind guest PC backwards to repeat syscall insn * return -TARGET_QEMU_ESIGRETURN from sigreturn rather than current R_RE * handle TARGET_QEMU_ESIGRETURN in the main loop as the indication that the main loop should not touch any guest CPU state Note that this fixes a bug where a sigreturn which happened to have an errno value in TILEGX_R_RE would incorrectly cause TILEGX_R_ERR to get set. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
		
			
				
	
	
		
			30 lines
		
	
	
		
			556 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			30 lines
		
	
	
		
			556 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_int ss_flags;
 | 
						|
    abi_ulong ss_size;
 | 
						|
} target_stack_t;
 | 
						|
 | 
						|
/*
 | 
						|
 * sigaltstack controls
 | 
						|
 */
 | 
						|
#define TARGET_SS_ONSTACK     1
 | 
						|
#define TARGET_SS_DISABLE     2
 | 
						|
 | 
						|
#define TARGET_MINSIGSTKSZ    2048
 | 
						|
#define TARGET_SIGSTKSZ       8192
 | 
						|
 | 
						|
static inline abi_ulong get_sp_from_cpustate(CPUTLGState *state)
 | 
						|
{
 | 
						|
    return state->regs[TILEGX_R_SP];
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
#endif /* TARGET_SIGNAL_H */
 |