mirror of
https://github.com/qemu/qemu.git
synced 2024-11-25 11:53:39 +08:00
target/i386: Clear RF on SYSCALL instruction
Fix the SYSCALL instruction in 64-bit (long mode). The RF flag should be cleared in R11 as well as in the RFLAGS. Intel and AMD CPUs behave same. AMD has this documented in the APM vol 3. Signed-off-by: Roman Kapl <rka@sysgo.com> Signed-off-by: Rudolf Marek <rudolf.marek@sysgo.com> Message-Id: <20181019122449.26387-1-rka@sysgo.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
2185fd67d2
commit
1a1435dd61
@ -991,11 +991,11 @@ void helper_syscall(CPUX86State *env, int next_eip_addend)
|
||||
int code64;
|
||||
|
||||
env->regs[R_ECX] = env->eip + next_eip_addend;
|
||||
env->regs[11] = cpu_compute_eflags(env);
|
||||
env->regs[11] = cpu_compute_eflags(env) & ~RF_MASK;
|
||||
|
||||
code64 = env->hflags & HF_CS64_MASK;
|
||||
|
||||
env->eflags &= ~env->fmask;
|
||||
env->eflags &= ~(env->fmask | RF_MASK);
|
||||
cpu_load_eflags(env, env->eflags, 0);
|
||||
cpu_x86_load_seg_cache(env, R_CS, selector & 0xfffc,
|
||||
0, 0xffffffff,
|
||||
|
Loading…
Reference in New Issue
Block a user