mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-25 19:21:01 +00:00
target/arm: Factor out unallocated_encoding for aarch32
Make this a static function private to translate.c. Thus we can use the same idiom between aarch64 and aarch32 without actually sharing function implementations. Backports commit 1ce21ba1eaf08b22da5925f3e37fc0b4322da858 from qemu
This commit is contained in:
parent
1f59a43544
commit
87c06b7fae
|
@ -110,8 +110,7 @@ static bool full_vfp_access_check(DisasContext *s, bool ignore_vfp_enabled)
|
||||||
|
|
||||||
if (!s->vfp_enabled && !ignore_vfp_enabled) {
|
if (!s->vfp_enabled && !ignore_vfp_enabled) {
|
||||||
assert(!arm_dc_feature(s, ARM_FEATURE_M));
|
assert(!arm_dc_feature(s, ARM_FEATURE_M));
|
||||||
gen_exception_insn(s, 4, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1304,6 +1304,13 @@ static void gen_exception_bkpt_insn(DisasContext *s, uint32_t syn)
|
||||||
s->base.is_jmp = DISAS_NORETURN;
|
s->base.is_jmp = DISAS_NORETURN;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void unallocated_encoding(DisasContext *s)
|
||||||
|
{
|
||||||
|
/* Unallocated and reserved encodings are uncategorized */
|
||||||
|
gen_exception_insn(s, s->pc_curr, EXCP_UDEF, syn_uncategorized(),
|
||||||
|
default_exception_el(s));
|
||||||
|
}
|
||||||
|
|
||||||
/* Force a TB lookup after an instruction that changes the CPU state. */
|
/* Force a TB lookup after an instruction that changes the CPU state. */
|
||||||
static inline void gen_lookup_tb(DisasContext *s)
|
static inline void gen_lookup_tb(DisasContext *s)
|
||||||
{
|
{
|
||||||
|
@ -1335,8 +1342,7 @@ static inline void gen_hlt(DisasContext *s, int imm)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
gen_exception_insn(s, s->thumb ? 2 : 4, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void gen_add_data_offset(DisasContext *s, unsigned int insn,
|
static inline void gen_add_data_offset(DisasContext *s, unsigned int insn,
|
||||||
|
@ -7748,8 +7754,7 @@ static void gen_srs(DisasContext *s,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (undef) {
|
if (undef) {
|
||||||
gen_exception_insn(s, 4, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9378,8 +9383,7 @@ static void disas_arm_insn(DisasContext *s, unsigned int insn)
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
illegal_op:
|
illegal_op:
|
||||||
gen_exception_insn(s, 4, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11066,8 +11070,7 @@ static void disas_thumb2_insn(DisasContext *s, uint32_t insn)
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
illegal_op:
|
illegal_op:
|
||||||
gen_exception_insn(s, 4, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void disas_thumb_insn(DisasContext *s, uint32_t insn)
|
static void disas_thumb_insn(DisasContext *s, uint32_t insn)
|
||||||
|
@ -11891,8 +11894,7 @@ static void disas_thumb_insn(DisasContext *s, uint32_t insn)
|
||||||
return;
|
return;
|
||||||
illegal_op:
|
illegal_op:
|
||||||
undef:
|
undef:
|
||||||
gen_exception_insn(s, 2, EXCP_UDEF, syn_uncategorized(),
|
unallocated_encoding(s);
|
||||||
default_exception_el(s));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool insn_crosses_page(CPUARMState *env, DisasContext *s)
|
static bool insn_crosses_page(CPUARMState *env, DisasContext *s)
|
||||||
|
|
Loading…
Reference in a new issue