target/arm: handle VMID change in secure state

The VTTBR write callback so far assumes that the underlying VM lies in
non-secure state. This handles the secure state scenario.

Signed-off-by: Rémi Denis-Courmont <remi.denis.courmont@huawei.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20210112104511.36576-10-remi.denis.courmont@huawei.com
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
Rémi Denis-Courmont 2021-01-12 12:45:02 +02:00 committed by Peter Maydell
parent e9152ee91c
commit c4f060e89e

View File

@ -4018,10 +4018,15 @@ static void vttbr_write(CPUARMState *env, const ARMCPRegInfo *ri,
* the combined stage 1&2 tlbs (EL10_1 and EL10_0). * the combined stage 1&2 tlbs (EL10_1 and EL10_0).
*/ */
if (raw_read(env, ri) != value) { if (raw_read(env, ri) != value) {
tlb_flush_by_mmuidx(cs, uint16_t mask = ARMMMUIdxBit_E10_1 |
ARMMMUIdxBit_E10_1 | ARMMMUIdxBit_E10_1_PAN |
ARMMMUIdxBit_E10_1_PAN | ARMMMUIdxBit_E10_0;
ARMMMUIdxBit_E10_0);
if (arm_is_secure_below_el3(env)) {
mask >>= ARM_MMU_IDX_A_NS;
}
tlb_flush_by_mmuidx(cs, mask);
raw_write(env, ri, value); raw_write(env, ri, value);
} }
} }