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.

backports c4f060e89effd70ebdb23d3315495d33af377a09
This commit is contained in:
Rémi Denis-Courmont 2021-03-04 14:20:45 -05:00 committed by Lioncash
parent a78c31e36a
commit ce50ba6d07

View file

@ -3710,10 +3710,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);
} }
} }