mirror of
https://github.com/xemu-project/xemu.git
synced 2024-11-27 05:20:50 +00:00
target/i386: Remove pc_start
The DisasContext member and the disas_insn local variable of the same name are identical to DisasContextBase.pc_next. Reviewed-by: Paolo Bonzini <pbonzini@redhat.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20221001140935.465607-2-richard.henderson@linaro.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
e2e69f6bb9
commit
ddf83b35bd
@ -76,7 +76,6 @@ typedef struct DisasContext {
|
||||
DisasContextBase base;
|
||||
|
||||
target_ulong pc; /* pc = eip + cs_base */
|
||||
target_ulong pc_start; /* pc at TB entry */
|
||||
target_ulong cs_base; /* base of CS segment */
|
||||
|
||||
MemOp aflag;
|
||||
@ -1345,13 +1344,13 @@ static void gen_exception(DisasContext *s, int trapno, target_ulong cur_eip)
|
||||
the instruction is known, but it isn't allowed in the current cpu mode. */
|
||||
static void gen_illegal_opcode(DisasContext *s)
|
||||
{
|
||||
gen_exception(s, EXCP06_ILLOP, s->pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP06_ILLOP, s->base.pc_next - s->cs_base);
|
||||
}
|
||||
|
||||
/* Generate #GP for the current instruction. */
|
||||
static void gen_exception_gpf(DisasContext *s)
|
||||
{
|
||||
gen_exception(s, EXCP0D_GPF, s->pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP0D_GPF, s->base.pc_next - s->cs_base);
|
||||
}
|
||||
|
||||
/* Check for cpl == 0; if not, raise #GP and return false. */
|
||||
@ -2016,7 +2015,7 @@ static uint64_t advance_pc(CPUX86State *env, DisasContext *s, int num_bytes)
|
||||
}
|
||||
|
||||
s->pc += num_bytes;
|
||||
if (unlikely(s->pc - s->pc_start > X86_MAX_INSN_LENGTH)) {
|
||||
if (unlikely(s->pc - s->base.pc_next > X86_MAX_INSN_LENGTH)) {
|
||||
/* If the instruction's 16th byte is on a different page than the 1st, a
|
||||
* page fault on the second page wins over the general protection fault
|
||||
* caused by the instruction being too long.
|
||||
@ -2614,7 +2613,7 @@ static void gen_unknown_opcode(CPUX86State *env, DisasContext *s)
|
||||
if (qemu_loglevel_mask(LOG_UNIMP)) {
|
||||
FILE *logfile = qemu_log_trylock();
|
||||
if (logfile) {
|
||||
target_ulong pc = s->pc_start, end = s->pc;
|
||||
target_ulong pc = s->base.pc_next, end = s->pc;
|
||||
|
||||
fprintf(logfile, "ILLOPC: " TARGET_FMT_lx ":", pc);
|
||||
for (; pc < end; ++pc) {
|
||||
@ -3226,8 +3225,7 @@ static const struct SSEOpHelper_table7 sse_op_table7[256] = {
|
||||
goto illegal_op; \
|
||||
} while (0)
|
||||
|
||||
static void gen_sse(CPUX86State *env, DisasContext *s, int b,
|
||||
target_ulong pc_start)
|
||||
static void gen_sse(CPUX86State *env, DisasContext *s, int b)
|
||||
{
|
||||
int b1, op1_offset, op2_offset, is_xmm, val;
|
||||
int modrm, mod, rm, reg;
|
||||
@ -3269,7 +3267,7 @@ static void gen_sse(CPUX86State *env, DisasContext *s, int b,
|
||||
}
|
||||
/* simple MMX/SSE operation */
|
||||
if (s->flags & HF_TS_MASK) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
return;
|
||||
}
|
||||
if (s->flags & HF_EM_MASK) {
|
||||
@ -4717,11 +4715,10 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
MemOp ot, aflag, dflag;
|
||||
int modrm, reg, rm, mod, op, opreg, val;
|
||||
target_ulong next_eip, tval;
|
||||
target_ulong pc_start = s->base.pc_next;
|
||||
bool orig_cc_op_dirty = s->cc_op_dirty;
|
||||
CCOp orig_cc_op = s->cc_op;
|
||||
|
||||
s->pc_start = s->pc = pc_start;
|
||||
s->pc = s->base.pc_next;
|
||||
s->override = -1;
|
||||
#ifdef TARGET_X86_64
|
||||
s->rex_w = false;
|
||||
@ -4745,7 +4742,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
s->base.num_insns--;
|
||||
tcg_remove_ops_after(s->prev_insn_end);
|
||||
s->base.is_jmp = DISAS_TOO_MANY;
|
||||
return pc_start;
|
||||
return s->base.pc_next;
|
||||
default:
|
||||
g_assert_not_reached();
|
||||
}
|
||||
@ -6079,7 +6076,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
if (s->flags & (HF_EM_MASK | HF_TS_MASK)) {
|
||||
/* if CR0.EM or CR0.TS are set, generate an FPU exception */
|
||||
/* XXX: what to do if illegal op ? */
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
break;
|
||||
}
|
||||
modrm = x86_ldub_code(env, s);
|
||||
@ -6620,7 +6617,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
offsetof(CPUX86State, segs[R_CS].selector));
|
||||
tcg_gen_st16_i32(s->tmp2_i32, cpu_env,
|
||||
offsetof(CPUX86State, fpcs));
|
||||
tcg_gen_st_tl(tcg_constant_tl(pc_start - s->cs_base),
|
||||
tcg_gen_st_tl(tcg_constant_tl(s->base.pc_next - s->cs_base),
|
||||
cpu_env, offsetof(CPUX86State, fpip));
|
||||
}
|
||||
}
|
||||
@ -6632,7 +6629,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0xa5:
|
||||
ot = mo_b_d(b, dflag);
|
||||
if (prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) {
|
||||
gen_repz_movs(s, ot, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_repz_movs(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base);
|
||||
} else {
|
||||
gen_movs(s, ot);
|
||||
}
|
||||
@ -6642,7 +6640,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0xab:
|
||||
ot = mo_b_d(b, dflag);
|
||||
if (prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) {
|
||||
gen_repz_stos(s, ot, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_repz_stos(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base);
|
||||
} else {
|
||||
gen_stos(s, ot);
|
||||
}
|
||||
@ -6651,7 +6650,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0xad:
|
||||
ot = mo_b_d(b, dflag);
|
||||
if (prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) {
|
||||
gen_repz_lods(s, ot, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_repz_lods(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base);
|
||||
} else {
|
||||
gen_lods(s, ot);
|
||||
}
|
||||
@ -6660,9 +6660,11 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0xaf:
|
||||
ot = mo_b_d(b, dflag);
|
||||
if (prefixes & PREFIX_REPNZ) {
|
||||
gen_repz_scas(s, ot, pc_start - s->cs_base, s->pc - s->cs_base, 1);
|
||||
gen_repz_scas(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base, 1);
|
||||
} else if (prefixes & PREFIX_REPZ) {
|
||||
gen_repz_scas(s, ot, pc_start - s->cs_base, s->pc - s->cs_base, 0);
|
||||
gen_repz_scas(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base, 0);
|
||||
} else {
|
||||
gen_scas(s, ot);
|
||||
}
|
||||
@ -6672,9 +6674,11 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0xa7:
|
||||
ot = mo_b_d(b, dflag);
|
||||
if (prefixes & PREFIX_REPNZ) {
|
||||
gen_repz_cmps(s, ot, pc_start - s->cs_base, s->pc - s->cs_base, 1);
|
||||
gen_repz_cmps(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base, 1);
|
||||
} else if (prefixes & PREFIX_REPZ) {
|
||||
gen_repz_cmps(s, ot, pc_start - s->cs_base, s->pc - s->cs_base, 0);
|
||||
gen_repz_cmps(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base, 0);
|
||||
} else {
|
||||
gen_cmps(s, ot);
|
||||
}
|
||||
@ -6692,7 +6696,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
gen_io_start();
|
||||
}
|
||||
if (prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) {
|
||||
gen_repz_ins(s, ot, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_repz_ins(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base);
|
||||
/* jump generated by gen_repz_ins */
|
||||
} else {
|
||||
gen_ins(s, ot);
|
||||
@ -6713,7 +6718,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
gen_io_start();
|
||||
}
|
||||
if (prefixes & (PREFIX_REPZ | PREFIX_REPNZ)) {
|
||||
gen_repz_outs(s, ot, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_repz_outs(s, ot, s->base.pc_next - s->cs_base,
|
||||
s->pc - s->cs_base);
|
||||
/* jump generated by gen_repz_outs */
|
||||
} else {
|
||||
gen_outs(s, ot);
|
||||
@ -6825,7 +6831,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
do_lret:
|
||||
if (PE(s) && !VM86(s)) {
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_lret_protected(cpu_env, tcg_const_i32(dflag - 1),
|
||||
tcg_const_i32(val));
|
||||
} else {
|
||||
@ -7295,7 +7301,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
val = x86_ldub_code(env, s);
|
||||
if (val == 0) {
|
||||
gen_exception(s, EXCP00_DIVZ, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP00_DIVZ, s->base.pc_next - s->cs_base);
|
||||
} else {
|
||||
gen_helper_aam(cpu_env, tcg_const_i32(val));
|
||||
set_cc_op(s, CC_OP_LOGICB);
|
||||
@ -7321,34 +7327,34 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
}
|
||||
if (prefixes & PREFIX_REPZ) {
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_helper_pause(cpu_env, tcg_const_i32(s->pc - pc_start));
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_pause(cpu_env, tcg_const_i32(s->pc - s->base.pc_next));
|
||||
s->base.is_jmp = DISAS_NORETURN;
|
||||
}
|
||||
break;
|
||||
case 0x9b: /* fwait */
|
||||
if ((s->flags & (HF_MP_MASK | HF_TS_MASK)) ==
|
||||
(HF_MP_MASK | HF_TS_MASK)) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
} else {
|
||||
gen_helper_fwait(cpu_env);
|
||||
}
|
||||
break;
|
||||
case 0xcc: /* int3 */
|
||||
gen_interrupt(s, EXCP03_INT3, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_interrupt(s, EXCP03_INT3, s->base.pc_next - s->cs_base, s->pc - s->cs_base);
|
||||
break;
|
||||
case 0xcd: /* int N */
|
||||
val = x86_ldub_code(env, s);
|
||||
if (check_vm86_iopl(s)) {
|
||||
gen_interrupt(s, val, pc_start - s->cs_base, s->pc - s->cs_base);
|
||||
gen_interrupt(s, val, s->base.pc_next - s->cs_base, s->pc - s->cs_base);
|
||||
}
|
||||
break;
|
||||
case 0xce: /* into */
|
||||
if (CODE64(s))
|
||||
goto illegal_op;
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_helper_into(cpu_env, tcg_const_i32(s->pc - pc_start));
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_into(cpu_env, tcg_const_i32(s->pc - s->base.pc_next));
|
||||
break;
|
||||
#ifdef WANT_ICEBP
|
||||
case 0xf1: /* icebp (undocumented, exits to external debugger) */
|
||||
@ -7454,7 +7460,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0x132: /* rdmsr */
|
||||
if (check_cpl0(s)) {
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
if (b & 2) {
|
||||
gen_helper_rdmsr(cpu_env);
|
||||
} else {
|
||||
@ -7466,7 +7472,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
case 0x131: /* rdtsc */
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
if (tb_cflags(s->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
}
|
||||
@ -7477,7 +7483,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
case 0x133: /* rdpmc */
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_rdpmc(cpu_env);
|
||||
s->base.is_jmp = DISAS_NORETURN;
|
||||
break;
|
||||
@ -7507,8 +7513,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0x105: /* syscall */
|
||||
/* XXX: is it usable in real mode ? */
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_helper_syscall(cpu_env, tcg_const_i32(s->pc - pc_start));
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_syscall(cpu_env, tcg_const_i32(s->pc - s->base.pc_next));
|
||||
/* TF handling for the syscall insn is different. The TF bit is checked
|
||||
after the syscall insn completes. This allows #DB to not be
|
||||
generated after one has entered CPL0 if TF is set in FMASK. */
|
||||
@ -7533,14 +7539,14 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
#endif
|
||||
case 0x1a2: /* cpuid */
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_cpuid(cpu_env);
|
||||
break;
|
||||
case 0xf4: /* hlt */
|
||||
if (check_cpl0(s)) {
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_helper_hlt(cpu_env, tcg_const_i32(s->pc - pc_start));
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_hlt(cpu_env, tcg_const_i32(s->pc - s->base.pc_next));
|
||||
s->base.is_jmp = DISAS_NORETURN;
|
||||
}
|
||||
break;
|
||||
@ -7636,7 +7642,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
tcg_gen_mov_tl(s->A0, cpu_regs[R_EAX]);
|
||||
gen_extu(s->aflag, s->A0);
|
||||
gen_add_A0_ds_seg(s);
|
||||
@ -7648,8 +7654,8 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_helper_mwait(cpu_env, tcg_const_i32(s->pc - pc_start));
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_mwait(cpu_env, tcg_const_i32(s->pc - s->base.pc_next));
|
||||
s->base.is_jmp = DISAS_NORETURN;
|
||||
break;
|
||||
|
||||
@ -7726,9 +7732,9 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_vmrun(cpu_env, tcg_const_i32(s->aflag - 1),
|
||||
tcg_const_i32(s->pc - pc_start));
|
||||
tcg_const_i32(s->pc - s->base.pc_next));
|
||||
tcg_gen_exit_tb(NULL, 0);
|
||||
s->base.is_jmp = DISAS_NORETURN;
|
||||
break;
|
||||
@ -7738,7 +7744,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_vmmcall(cpu_env);
|
||||
break;
|
||||
|
||||
@ -7750,7 +7756,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_vmload(cpu_env, tcg_const_i32(s->aflag - 1));
|
||||
break;
|
||||
|
||||
@ -7762,7 +7768,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_vmsave(cpu_env, tcg_const_i32(s->aflag - 1));
|
||||
break;
|
||||
|
||||
@ -7788,7 +7794,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
break;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
gen_helper_clgi(cpu_env);
|
||||
break;
|
||||
|
||||
@ -7934,7 +7940,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
gen_update_cc_op(s);
|
||||
gen_jmp_im(s, pc_start - s->cs_base);
|
||||
gen_jmp_im(s, s->base.pc_next - s->cs_base);
|
||||
if (tb_cflags(s->base.tb) & CF_USE_ICOUNT) {
|
||||
gen_io_start();
|
||||
}
|
||||
@ -8386,7 +8392,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
if ((s->flags & HF_EM_MASK) || (s->flags & HF_TS_MASK)) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
break;
|
||||
}
|
||||
gen_lea_modrm(env, s, modrm);
|
||||
@ -8399,7 +8405,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
if ((s->flags & HF_EM_MASK) || (s->flags & HF_TS_MASK)) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
break;
|
||||
}
|
||||
gen_lea_modrm(env, s, modrm);
|
||||
@ -8411,7 +8417,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
if (s->flags & HF_TS_MASK) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
break;
|
||||
}
|
||||
gen_lea_modrm(env, s, modrm);
|
||||
@ -8424,7 +8430,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
goto illegal_op;
|
||||
}
|
||||
if (s->flags & HF_TS_MASK) {
|
||||
gen_exception(s, EXCP07_PREX, pc_start - s->cs_base);
|
||||
gen_exception(s, EXCP07_PREX, s->base.pc_next - s->cs_base);
|
||||
break;
|
||||
}
|
||||
gen_helper_update_mxcsr(cpu_env);
|
||||
@ -8633,7 +8639,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||
case 0x1c2:
|
||||
case 0x1c4 ... 0x1c6:
|
||||
case 0x1d0 ... 0x1fe:
|
||||
gen_sse(env, s, b, pc_start);
|
||||
gen_sse(env, s, b);
|
||||
break;
|
||||
default:
|
||||
goto unknown_op;
|
||||
|
Loading…
Reference in New Issue
Block a user