2017-01-25 10:54:11 -08:00
|
|
|
/*
|
|
|
|
* Xtensa-specific CPU ABI and functions for linux-user
|
|
|
|
*/
|
|
|
|
#ifndef XTENSA_TARGET_CPU_H
|
|
|
|
#define XTENSA_TARGET_CPU_H
|
|
|
|
|
2019-11-06 12:33:15 +01:00
|
|
|
static inline void cpu_clone_regs_child(CPUXtensaState *env,
|
|
|
|
target_ulong newsp,
|
|
|
|
unsigned flags)
|
2017-01-25 10:54:11 -08:00
|
|
|
{
|
|
|
|
if (newsp) {
|
|
|
|
env->regs[1] = newsp;
|
|
|
|
env->sregs[WINDOW_BASE] = 0;
|
|
|
|
env->sregs[WINDOW_START] = 0x1;
|
|
|
|
}
|
|
|
|
env->regs[2] = 0;
|
|
|
|
}
|
|
|
|
|
2019-11-06 12:33:16 +01:00
|
|
|
static inline void cpu_clone_regs_parent(CPUXtensaState *env, unsigned flags)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2017-01-25 10:54:11 -08:00
|
|
|
static inline void cpu_set_tls(CPUXtensaState *env, target_ulong newtls)
|
|
|
|
{
|
|
|
|
env->uregs[THREADPTR] = newtls;
|
|
|
|
}
|
|
|
|
|
2018-05-29 21:42:00 +02:00
|
|
|
static inline abi_ulong get_sp_from_cpustate(CPUXtensaState *state)
|
|
|
|
{
|
|
|
|
return state->regs[1];
|
|
|
|
}
|
2017-01-25 10:54:11 -08:00
|
|
|
#endif
|