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
 |