提交 1a1435dd 编写于 作者: R Rudolf Marek 提交者: Paolo Bonzini

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: NRoman Kapl <rka@sysgo.com>
Signed-off-by: NRudolf Marek <rudolf.marek@sysgo.com>
Message-Id: <20181019122449.26387-1-rka@sysgo.com>
Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
上级 2185fd67
...@@ -991,11 +991,11 @@ void helper_syscall(CPUX86State *env, int next_eip_addend) ...@@ -991,11 +991,11 @@ void helper_syscall(CPUX86State *env, int next_eip_addend)
int code64; int code64;
env->regs[R_ECX] = env->eip + next_eip_addend; 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; code64 = env->hflags & HF_CS64_MASK;
env->eflags &= ~env->fmask; env->eflags &= ~(env->fmask | RF_MASK);
cpu_load_eflags(env, env->eflags, 0); cpu_load_eflags(env, env->eflags, 0);
cpu_x86_load_seg_cache(env, R_CS, selector & 0xfffc, cpu_x86_load_seg_cache(env, R_CS, selector & 0xfffc,
0, 0xffffffff, 0, 0xffffffff,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册