We will need a target-specific hook for adjusting registers in the parent during clone. Add an empty inline function for each target, and invoke it from the proper places. Reviewed-by: Laurent Vivier <laurent@vivier.eu> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Message-Id: <20191106113318.10226-11-richard.henderson@linaro.org> Signed-off-by: Laurent Vivier <laurent@vivier.eu>
		
			
				
	
	
		
			28 lines
		
	
	
		
			566 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			566 B
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef RISCV_TARGET_CPU_H
 | 
						|
#define RISCV_TARGET_CPU_H
 | 
						|
 | 
						|
static inline void cpu_clone_regs_child(CPURISCVState *env, target_ulong newsp,
 | 
						|
                                        unsigned flags)
 | 
						|
{
 | 
						|
    if (newsp) {
 | 
						|
        env->gpr[xSP] = newsp;
 | 
						|
    }
 | 
						|
 | 
						|
    env->gpr[xA0] = 0;
 | 
						|
}
 | 
						|
 | 
						|
static inline void cpu_clone_regs_parent(CPURISCVState *env, unsigned flags)
 | 
						|
{
 | 
						|
}
 | 
						|
 | 
						|
static inline void cpu_set_tls(CPURISCVState *env, target_ulong newtls)
 | 
						|
{
 | 
						|
    env->gpr[xTP] = newtls;
 | 
						|
}
 | 
						|
 | 
						|
static inline abi_ulong get_sp_from_cpustate(CPURISCVState *state)
 | 
						|
{
 | 
						|
   return state->gpr[xSP];
 | 
						|
}
 | 
						|
#endif
 |