diff --git a/qemu/target/i386/translate.c b/qemu/target/i386/translate.c index 7b54be3e..7bdc6da6 100644 --- a/qemu/target/i386/translate.c +++ b/qemu/target/i386/translate.c @@ -4644,10 +4644,11 @@ static void gen_sse(CPUX86State *env, DisasContext *s, int b, if (!(s->cpuid_ext_features & sse_op_table7[b].ext_mask)) goto illegal_op; + s->rip_offset = 1; + if (sse_fn_eppi == SSE_SPECIAL) { ot = mo_64_32(s->dflag); rm = (modrm & 7) | REX_B(s); - s->rip_offset = 1; if (mod != 3) gen_lea_modrm(env, s, modrm); reg = ((modrm >> 3) & 7) | rex_r;