mirror of https://github.com/xemu-project/xemu.git
target/i386: introduce insn_get_addr
The "O" operand type in the Intel SDM needs to load an 8- to 64-bit unsigned value, while insn_get is limited to 32 bits. Extract the code out of disas_insn and into a separate function. Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
5c2f60bd1b
commit
efcca7ef17
|
@ -2289,6 +2289,31 @@ static void gen_ldst_modrm(CPUX86State *env, DisasContext *s, int modrm,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static target_ulong insn_get_addr(CPUX86State *env, DisasContext *s, MemOp ot)
|
||||||
|
{
|
||||||
|
target_ulong ret;
|
||||||
|
|
||||||
|
switch (ot) {
|
||||||
|
case MO_8:
|
||||||
|
ret = x86_ldub_code(env, s);
|
||||||
|
break;
|
||||||
|
case MO_16:
|
||||||
|
ret = x86_lduw_code(env, s);
|
||||||
|
break;
|
||||||
|
case MO_32:
|
||||||
|
ret = x86_ldl_code(env, s);
|
||||||
|
break;
|
||||||
|
#ifdef TARGET_X86_64
|
||||||
|
case MO_64:
|
||||||
|
ret = x86_ldq_code(env, s);
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
g_assert_not_reached();
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static inline uint32_t insn_get(CPUX86State *env, DisasContext *s, MemOp ot)
|
static inline uint32_t insn_get(CPUX86State *env, DisasContext *s, MemOp ot)
|
||||||
{
|
{
|
||||||
uint32_t ret;
|
uint32_t ret;
|
||||||
|
@ -5851,16 +5876,7 @@ static target_ulong disas_insn(DisasContext *s, CPUState *cpu)
|
||||||
target_ulong offset_addr;
|
target_ulong offset_addr;
|
||||||
|
|
||||||
ot = mo_b_d(b, dflag);
|
ot = mo_b_d(b, dflag);
|
||||||
switch (s->aflag) {
|
offset_addr = insn_get_addr(env, s, s->aflag);
|
||||||
#ifdef TARGET_X86_64
|
|
||||||
case MO_64:
|
|
||||||
offset_addr = x86_ldq_code(env, s);
|
|
||||||
break;
|
|
||||||
#endif
|
|
||||||
default:
|
|
||||||
offset_addr = insn_get(env, s, s->aflag);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
tcg_gen_movi_tl(s->A0, offset_addr);
|
tcg_gen_movi_tl(s->A0, offset_addr);
|
||||||
gen_add_A0_ds_seg(s);
|
gen_add_A0_ds_seg(s);
|
||||||
if ((b & 2) == 0) {
|
if ((b & 2) == 0) {
|
||||||
|
|
Loading…
Reference in New Issue