mirror of
https://gitlab.com/qemu-project/qemu
synced 2024-11-05 20:35:44 +00:00
target/arm: NSTable is RES0 for the RME EL3 regime
Test in_space instead of in_secure so that we don't switch out of Root space. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20230620124418.805717-12-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
90c6629393
commit
26d1994594
1 changed files with 14 additions and 14 deletions
|
@ -1275,7 +1275,6 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
|
|||
{
|
||||
ARMCPU *cpu = env_archcpu(env);
|
||||
ARMMMUIdx mmu_idx = ptw->in_mmu_idx;
|
||||
bool is_secure = ptw->in_secure;
|
||||
int32_t level;
|
||||
ARMVAParameters param;
|
||||
uint64_t ttbr;
|
||||
|
@ -1291,7 +1290,6 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
|
|||
uint64_t descaddrmask;
|
||||
bool aarch64 = arm_el_is_aa64(env, el);
|
||||
uint64_t descriptor, new_descriptor;
|
||||
bool nstable;
|
||||
|
||||
/* TODO: This code does not support shareability levels. */
|
||||
if (aarch64) {
|
||||
|
@ -1453,21 +1451,21 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
|
|||
descaddrmask = MAKE_64BIT_MASK(0, 40);
|
||||
}
|
||||
descaddrmask &= ~indexmask_grainsize;
|
||||
|
||||
/*
|
||||
* Secure stage 1 accesses start with the page table in secure memory and
|
||||
* can be downgraded to non-secure at any step. Non-secure accesses
|
||||
* remain non-secure. We implement this by just ORing in the NSTable/NS
|
||||
* bits at each step.
|
||||
* Stage 2 never gets this kind of downgrade.
|
||||
*/
|
||||
tableattrs = is_secure ? 0 : (1 << 4);
|
||||
tableattrs = 0;
|
||||
|
||||
next_level:
|
||||
descaddr |= (address >> (stride * (4 - level))) & indexmask;
|
||||
descaddr &= ~7ULL;
|
||||
nstable = !regime_is_stage2(mmu_idx) && extract32(tableattrs, 4, 1);
|
||||
if (nstable && ptw->in_secure) {
|
||||
|
||||
/*
|
||||
* Process the NSTable bit from the previous level. This changes
|
||||
* the table address space and the output space from Secure to
|
||||
* NonSecure. With RME, the EL3 translation regime does not change
|
||||
* from Root to NonSecure.
|
||||
*/
|
||||
if (ptw->in_space == ARMSS_Secure
|
||||
&& !regime_is_stage2(mmu_idx)
|
||||
&& extract32(tableattrs, 4, 1)) {
|
||||
/*
|
||||
* Stage2_S -> Stage2 or Phys_S -> Phys_NS
|
||||
* Assert the relative order of the secure/non-secure indexes.
|
||||
|
@ -1476,7 +1474,9 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
|
|||
QEMU_BUILD_BUG_ON(ARMMMUIdx_Stage2_S + 1 != ARMMMUIdx_Stage2);
|
||||
ptw->in_ptw_idx += 1;
|
||||
ptw->in_secure = false;
|
||||
ptw->in_space = ARMSS_NonSecure;
|
||||
}
|
||||
|
||||
if (!S1_ptw_translate(env, ptw, descaddr, fi)) {
|
||||
goto do_fault;
|
||||
}
|
||||
|
@ -1579,7 +1579,7 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw,
|
|||
*/
|
||||
attrs = new_descriptor & (MAKE_64BIT_MASK(2, 10) | MAKE_64BIT_MASK(50, 14));
|
||||
if (!regime_is_stage2(mmu_idx)) {
|
||||
attrs |= nstable << 5; /* NS */
|
||||
attrs |= !ptw->in_secure << 5; /* NS */
|
||||
if (!param.hpd) {
|
||||
attrs |= extract64(tableattrs, 0, 2) << 53; /* XN, PXN */
|
||||
/*
|
||||
|
|
Loading…
Reference in a new issue