aboutsummaryrefslogtreecommitdiff
path: root/linux-user/openrisc
diff options
context:
space:
mode:
authorRichard Henderson <rth@twiddle.net>2017-02-10 06:56:34 +1000
committerRichard Henderson <rth@twiddle.net>2017-02-14 08:14:59 +1100
commitc40413a65eeb98d6f9eeb92544ab782c812ccc51 (patch)
treeec6a689918e2a69582b6121ac3eabe2746773858 /linux-user/openrisc
parenta0adc417a0b22e9b33a529133e04822753067f33 (diff)
downloadqemu-c40413a65eeb98d6f9eeb92544ab782c812ccc51.zip
qemu-c40413a65eeb98d6f9eeb92544ab782c812ccc51.tar.gz
qemu-c40413a65eeb98d6f9eeb92544ab782c812ccc51.tar.bz2
linux-user: Honor CLONE_SETTLS for openrisc
Threads work much better when you set the TLS register. This was fixed in the upstream kernel for Linux 4.9. Signed-off-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'linux-user/openrisc')
-rw-r--r--linux-user/openrisc/target_cpu.h4
1 files changed, 1 insertions, 3 deletions
diff --git a/linux-user/openrisc/target_cpu.h b/linux-user/openrisc/target_cpu.h
index a21ed1a..f283d96 100644
--- a/linux-user/openrisc/target_cpu.h
+++ b/linux-user/openrisc/target_cpu.h
@@ -30,9 +30,7 @@ static inline void cpu_clone_regs(CPUOpenRISCState *env, target_ulong newsp)
static inline void cpu_set_tls(CPUOpenRISCState *env, target_ulong newtls)
{
- /* Linux kernel 3.10 does not pay any attention to CLONE_SETTLS
- * in copy_thread(), so QEMU need not do so either.
- */
+ env->gpr[10] = newtls;
}
#endif