mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-11 07:25:33 +00:00
target-arm: Fix default_exception_el() function for the case when EL3 is not supported
If EL3 is not supported in current configuration, we should not try to get EL3 bitness. Backports commit cef9ee706792b1e205fe472b67053a0e82cd058e from qemu
This commit is contained in:
parent
a249923d4d
commit
a883d349fe
|
@ -11232,7 +11232,11 @@ void gen_intermediate_code_internal_a64(ARMCPU *cpu,
|
|||
dc->condjmp = 0;
|
||||
|
||||
dc->aarch64 = 1;
|
||||
dc->el3_is_aa64 = arm_el_is_aa64(env, 3);
|
||||
/* If we are coming from secure EL0 in a system with a 32-bit EL3, then
|
||||
* there is no secure EL1, so we route exceptions to EL3.
|
||||
*/
|
||||
dc->secure_routed_to_el3 = arm_feature(env, ARM_FEATURE_EL3) &&
|
||||
!arm_el_is_aa64(env, 3);
|
||||
dc->thumb = 0;
|
||||
#if defined(TARGET_WORDS_BIGENDIAN)
|
||||
dc->bswap_code = 1;
|
||||
|
|
|
@ -11378,7 +11378,11 @@ static inline void gen_intermediate_code_internal(ARMCPU *cpu,
|
|||
dc->condjmp = 0;
|
||||
|
||||
dc->aarch64 = 0;
|
||||
dc->el3_is_aa64 = arm_el_is_aa64(env, 3);
|
||||
/* If we are coming from secure EL0 in a system with a 32-bit EL3, then
|
||||
* there is no secure EL1, so we route exceptions to EL3.
|
||||
*/
|
||||
dc->secure_routed_to_el3 = arm_feature(env, ARM_FEATURE_EL3) &&
|
||||
!arm_el_is_aa64(env, 3);
|
||||
dc->thumb = ARM_TBFLAG_THUMB(tb->flags); // qq
|
||||
dc->bswap_code = ARM_TBFLAG_BSWAP_CODE(tb->flags);
|
||||
dc->condexec_mask = (ARM_TBFLAG_CONDEXEC(tb->flags) & 0xf) << 1;
|
||||
|
|
|
@ -23,7 +23,8 @@ typedef struct DisasContext {
|
|||
ARMMMUIdx mmu_idx; /* MMU index to use for normal loads/stores */
|
||||
bool ns; /* Use non-secure CPREG bank on access */
|
||||
int fp_excp_el; /* FP exception EL or 0 if enabled */
|
||||
bool el3_is_aa64; /* Flag indicating whether EL3 is AArch64 or not */
|
||||
/* Flag indicating that exceptions from secure mode are routed to EL3. */
|
||||
bool secure_routed_to_el3;
|
||||
bool vfp_enabled; /* FP enabled via FPSCR.EN */
|
||||
int vec_len;
|
||||
int vec_stride;
|
||||
|
@ -91,7 +92,7 @@ static inline int default_exception_el(DisasContext *s)
|
|||
* exceptions can only be routed to ELs above 1, so we target the higher of
|
||||
* 1 or the current EL.
|
||||
*/
|
||||
return (s->mmu_idx == ARMMMUIdx_S1SE0 && !s->el3_is_aa64)
|
||||
return (s->mmu_idx == ARMMMUIdx_S1SE0 && s->secure_routed_to_el3)
|
||||
? 3 : MAX(1, s->current_el);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue