mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-17 07:02:03 -06:00
target/arm: Move regime_el to internals.h
We will shortly need this in mte_helper.c as well. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20200626033144.790098-22-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
5463df160e
commit
9c7ab8fc8c
2 changed files with 36 additions and 36 deletions
|
@ -9793,42 +9793,6 @@ void arm_cpu_do_interrupt(CPUState *cs)
|
||||||
}
|
}
|
||||||
#endif /* !CONFIG_USER_ONLY */
|
#endif /* !CONFIG_USER_ONLY */
|
||||||
|
|
||||||
/* Return the exception level which controls this address translation regime */
|
|
||||||
static uint32_t regime_el(CPUARMState *env, ARMMMUIdx mmu_idx)
|
|
||||||
{
|
|
||||||
switch (mmu_idx) {
|
|
||||||
case ARMMMUIdx_E20_0:
|
|
||||||
case ARMMMUIdx_E20_2:
|
|
||||||
case ARMMMUIdx_E20_2_PAN:
|
|
||||||
case ARMMMUIdx_Stage2:
|
|
||||||
case ARMMMUIdx_E2:
|
|
||||||
return 2;
|
|
||||||
case ARMMMUIdx_SE3:
|
|
||||||
return 3;
|
|
||||||
case ARMMMUIdx_SE10_0:
|
|
||||||
return arm_el_is_aa64(env, 3) ? 1 : 3;
|
|
||||||
case ARMMMUIdx_SE10_1:
|
|
||||||
case ARMMMUIdx_SE10_1_PAN:
|
|
||||||
case ARMMMUIdx_Stage1_E0:
|
|
||||||
case ARMMMUIdx_Stage1_E1:
|
|
||||||
case ARMMMUIdx_Stage1_E1_PAN:
|
|
||||||
case ARMMMUIdx_E10_0:
|
|
||||||
case ARMMMUIdx_E10_1:
|
|
||||||
case ARMMMUIdx_E10_1_PAN:
|
|
||||||
case ARMMMUIdx_MPrivNegPri:
|
|
||||||
case ARMMMUIdx_MUserNegPri:
|
|
||||||
case ARMMMUIdx_MPriv:
|
|
||||||
case ARMMMUIdx_MUser:
|
|
||||||
case ARMMMUIdx_MSPrivNegPri:
|
|
||||||
case ARMMMUIdx_MSUserNegPri:
|
|
||||||
case ARMMMUIdx_MSPriv:
|
|
||||||
case ARMMMUIdx_MSUser:
|
|
||||||
return 1;
|
|
||||||
default:
|
|
||||||
g_assert_not_reached();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
uint64_t arm_sctlr(CPUARMState *env, int el)
|
uint64_t arm_sctlr(CPUARMState *env, int el)
|
||||||
{
|
{
|
||||||
/* Only EL0 needs to be adjusted for EL1&0 or EL2&0. */
|
/* Only EL0 needs to be adjusted for EL1&0 or EL2&0. */
|
||||||
|
|
|
@ -913,6 +913,42 @@ static inline bool regime_is_pan(CPUARMState *env, ARMMMUIdx mmu_idx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return the exception level which controls this address translation regime */
|
||||||
|
static inline uint32_t regime_el(CPUARMState *env, ARMMMUIdx mmu_idx)
|
||||||
|
{
|
||||||
|
switch (mmu_idx) {
|
||||||
|
case ARMMMUIdx_E20_0:
|
||||||
|
case ARMMMUIdx_E20_2:
|
||||||
|
case ARMMMUIdx_E20_2_PAN:
|
||||||
|
case ARMMMUIdx_Stage2:
|
||||||
|
case ARMMMUIdx_E2:
|
||||||
|
return 2;
|
||||||
|
case ARMMMUIdx_SE3:
|
||||||
|
return 3;
|
||||||
|
case ARMMMUIdx_SE10_0:
|
||||||
|
return arm_el_is_aa64(env, 3) ? 1 : 3;
|
||||||
|
case ARMMMUIdx_SE10_1:
|
||||||
|
case ARMMMUIdx_SE10_1_PAN:
|
||||||
|
case ARMMMUIdx_Stage1_E0:
|
||||||
|
case ARMMMUIdx_Stage1_E1:
|
||||||
|
case ARMMMUIdx_Stage1_E1_PAN:
|
||||||
|
case ARMMMUIdx_E10_0:
|
||||||
|
case ARMMMUIdx_E10_1:
|
||||||
|
case ARMMMUIdx_E10_1_PAN:
|
||||||
|
case ARMMMUIdx_MPrivNegPri:
|
||||||
|
case ARMMMUIdx_MUserNegPri:
|
||||||
|
case ARMMMUIdx_MPriv:
|
||||||
|
case ARMMMUIdx_MUser:
|
||||||
|
case ARMMMUIdx_MSPrivNegPri:
|
||||||
|
case ARMMMUIdx_MSUserNegPri:
|
||||||
|
case ARMMMUIdx_MSPriv:
|
||||||
|
case ARMMMUIdx_MSUser:
|
||||||
|
return 1;
|
||||||
|
default:
|
||||||
|
g_assert_not_reached();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Return the FSR value for a debug exception (watchpoint, hardware
|
/* Return the FSR value for a debug exception (watchpoint, hardware
|
||||||
* breakpoint or BKPT insn) targeting the specified exception level.
|
* breakpoint or BKPT insn) targeting the specified exception level.
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue