diff options
author | Edgar E. Iglesias <edgar.iglesias@gmail.com> | 2012-04-26 14:17:41 +0200 |
---|---|---|
committer | Edgar E. Iglesias <edgar.iglesias@gmail.com> | 2012-10-19 13:24:12 +0200 |
commit | a5b3bdcba8a105439ad3a44121526306c449e100 (patch) | |
tree | e39553b9c08439daf449c4cea769ffe75388d665 | |
parent | b6348f29d033d5a8a26f633d2ee94362595f32a4 (diff) | |
download | qemu-a5b3bdcba8a105439ad3a44121526306c449e100.zip qemu-a5b3bdcba8a105439ad3a44121526306c449e100.tar.gz qemu-a5b3bdcba8a105439ad3a44121526306c449e100.tar.bz2 |
microblaze: Support setting of TLS ptr
Signed-off-by: Edgar E. Iglesias <edgar.iglesias@gmail.com>
-rw-r--r-- | linux-user/syscall.c | 2 | ||||
-rw-r--r-- | target-microblaze/cpu.h | 1 |
2 files changed, 3 insertions, 0 deletions
diff --git a/linux-user/syscall.c b/linux-user/syscall.c index 471d060..c6a6337 100644 --- a/linux-user/syscall.c +++ b/linux-user/syscall.c @@ -6888,6 +6888,8 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1, ret = get_errno(do_fork(cpu_env, arg1, arg2, arg3, arg5, arg4)); #elif defined(TARGET_CRIS) ret = get_errno(do_fork(cpu_env, arg2, arg1, arg3, arg4, arg5)); +#elif defined(TARGET_MICROBLAZE) + ret = get_errno(do_fork(cpu_env, arg1, arg2, arg4, arg6, arg5)); #elif defined(TARGET_S390X) ret = get_errno(do_fork(cpu_env, arg2, arg1, arg3, arg5, arg4)); #else diff --git a/target-microblaze/cpu.h b/target-microblaze/cpu.h index 4968c24..88430b5 100644 --- a/target-microblaze/cpu.h +++ b/target-microblaze/cpu.h @@ -345,6 +345,7 @@ static inline void cpu_clone_regs(CPUMBState *env, target_ulong newsp) static inline void cpu_set_tls(CPUMBState *env, target_ulong newtls) { + env->regs[21] = newtls; } static inline int cpu_interrupts_enabled(CPUMBState *env) |