diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2023-08-22 17:31:10 +0100 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2023-08-22 17:31:10 +0100 |
commit | a729d63642b01f2b7a3c1db468811a7b40b88f70 (patch) | |
tree | d342566ae91c9ce9f37a3f4f27b74e0837967306 /target | |
parent | d53e25075bd9c89c81ab2bfc45ccbcdc92842b24 (diff) |
target/arm/ptw: Report stage 2 fault level for stage 2 faults on stage 1 ptw
When we report faults due to stage 2 faults during a stage 1
page table walk, the 'level' parameter should be the level
of the walk in stage 2 that faulted, not the level of the
walk in stage 1. Correct the reporting of these faults.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20230807141514.19075-15-peter.maydell@linaro.org
Diffstat (limited to 'target')
-rw-r--r-- | target/arm/ptw.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/target/arm/ptw.c b/target/arm/ptw.c index fbb0f8a0bf..07832eb8f7 100644 --- a/target/arm/ptw.c +++ b/target/arm/ptw.c @@ -2048,9 +2048,13 @@ static bool get_phys_addr_lpae(CPUARMState *env, S1Translate *ptw, do_translation_fault: fi->type = ARMFault_Translation; do_fault: - fi->level = level; - /* Tag the error as S2 for failed S1 PTW at S2 or ordinary S2. */ - fi->stage2 = fi->s1ptw || regime_is_stage2(mmu_idx); + if (fi->s1ptw) { + /* Retain the existing stage 2 fi->level */ + assert(fi->stage2); + } else { + fi->level = level; + fi->stage2 = regime_is_stage2(mmu_idx); + } fi->s1ns = fault_s1ns(ptw->in_space, mmu_idx); return true; } |