target-arm: Get MMU index information correct for A64 code
Emit the correct MMU index information for loads and stores from A64 code, rather than hardwiring it to "always kernel mode", by storing the exception level in the TB flags, and make cpu_mmu_index() return the right answer when the CPU is in AArch64 mode. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com>
This commit is contained in:
parent
cd5c11b84b
commit
d9ea7d290b
@ -1057,7 +1057,7 @@ static inline CPUARMState *cpu_init(const char *cpu_model)
|
|||||||
#define MMU_USER_IDX 1
|
#define MMU_USER_IDX 1
|
||||||
static inline int cpu_mmu_index (CPUARMState *env)
|
static inline int cpu_mmu_index (CPUARMState *env)
|
||||||
{
|
{
|
||||||
return (env->uncached_cpsr & CPSR_M) == ARM_CPU_MODE_USR ? 1 : 0;
|
return arm_current_pl(env) ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "exec/cpu-all.h"
|
#include "exec/cpu-all.h"
|
||||||
@ -1084,7 +1084,9 @@ static inline int cpu_mmu_index (CPUARMState *env)
|
|||||||
#define ARM_TBFLAG_BSWAP_CODE_SHIFT 16
|
#define ARM_TBFLAG_BSWAP_CODE_SHIFT 16
|
||||||
#define ARM_TBFLAG_BSWAP_CODE_MASK (1 << ARM_TBFLAG_BSWAP_CODE_SHIFT)
|
#define ARM_TBFLAG_BSWAP_CODE_MASK (1 << ARM_TBFLAG_BSWAP_CODE_SHIFT)
|
||||||
|
|
||||||
/* Bit usage when in AArch64 state: currently no bits defined */
|
/* Bit usage when in AArch64 state */
|
||||||
|
#define ARM_TBFLAG_AA64_EL_SHIFT 0
|
||||||
|
#define ARM_TBFLAG_AA64_EL_MASK (0x3 << ARM_TBFLAG_AA64_EL_SHIFT)
|
||||||
|
|
||||||
/* some convenience accessor macros */
|
/* some convenience accessor macros */
|
||||||
#define ARM_TBFLAG_AARCH64_STATE(F) \
|
#define ARM_TBFLAG_AARCH64_STATE(F) \
|
||||||
@ -1103,13 +1105,16 @@ static inline int cpu_mmu_index (CPUARMState *env)
|
|||||||
(((F) & ARM_TBFLAG_CONDEXEC_MASK) >> ARM_TBFLAG_CONDEXEC_SHIFT)
|
(((F) & ARM_TBFLAG_CONDEXEC_MASK) >> ARM_TBFLAG_CONDEXEC_SHIFT)
|
||||||
#define ARM_TBFLAG_BSWAP_CODE(F) \
|
#define ARM_TBFLAG_BSWAP_CODE(F) \
|
||||||
(((F) & ARM_TBFLAG_BSWAP_CODE_MASK) >> ARM_TBFLAG_BSWAP_CODE_SHIFT)
|
(((F) & ARM_TBFLAG_BSWAP_CODE_MASK) >> ARM_TBFLAG_BSWAP_CODE_SHIFT)
|
||||||
|
#define ARM_TBFLAG_AA64_EL(F) \
|
||||||
|
(((F) & ARM_TBFLAG_AA64_EL_MASK) >> ARM_TBFLAG_AA64_EL_SHIFT)
|
||||||
|
|
||||||
static inline void cpu_get_tb_cpu_state(CPUARMState *env, target_ulong *pc,
|
static inline void cpu_get_tb_cpu_state(CPUARMState *env, target_ulong *pc,
|
||||||
target_ulong *cs_base, int *flags)
|
target_ulong *cs_base, int *flags)
|
||||||
{
|
{
|
||||||
if (is_a64(env)) {
|
if (is_a64(env)) {
|
||||||
*pc = env->pc;
|
*pc = env->pc;
|
||||||
*flags = ARM_TBFLAG_AARCH64_STATE_MASK;
|
*flags = ARM_TBFLAG_AARCH64_STATE_MASK
|
||||||
|
| (arm_current_pl(env) << ARM_TBFLAG_AA64_EL_SHIFT);
|
||||||
} else {
|
} else {
|
||||||
int privmode;
|
int privmode;
|
||||||
*pc = env->regs[15];
|
*pc = env->regs[15];
|
||||||
|
@ -9013,7 +9013,7 @@ void gen_intermediate_code_internal_a64(ARMCPU *cpu,
|
|||||||
dc->condexec_mask = 0;
|
dc->condexec_mask = 0;
|
||||||
dc->condexec_cond = 0;
|
dc->condexec_cond = 0;
|
||||||
#if !defined(CONFIG_USER_ONLY)
|
#if !defined(CONFIG_USER_ONLY)
|
||||||
dc->user = 0;
|
dc->user = (ARM_TBFLAG_AA64_EL(tb->flags) == 0);
|
||||||
#endif
|
#endif
|
||||||
dc->vfp_enabled = 0;
|
dc->vfp_enabled = 0;
|
||||||
dc->vec_len = 0;
|
dc->vec_len = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user