summaryrefslogtreecommitdiff
path: root/rust/helpers/bitops.c
diff options
context:
space:
mode:
authorMarc Zyngier <maz@kernel.org>2025-05-14 13:34:56 +0300
committerMarc Zyngier <maz@kernel.org>2025-05-19 10:01:19 +0300
commit4ffa72ad8f37e73bbb6c0baa88557bcb4fd39929 (patch)
tree7c0608041e2f3615359de433e81c347356e53ca3 /rust/helpers/bitops.c
parent73e1b621b25d7d45cebf9940cad3b377d3b94791 (diff)
downloadlinux-4ffa72ad8f37e73bbb6c0baa88557bcb4fd39929.tar.xz
KVM: arm64: nv: Add S1 TLB invalidation primitive for VNCR_EL2
A TLBI by VA for S1 must take effect on our pseudo-TLB for VNCR and potentially knock the fixmap mapping. Even worse, that TLBI must be able to work cross-vcpu. For that, we track on a per-VM basis if any VNCR is mapped, using an atomic counter. Whenever a TLBI S1E2 occurs and that this counter is non-zero, we take the long road all the way back to the core code. There, we iterate over all vcpus and check whether this particular invalidation has any damaging effect. If it does, we nuke the pseudo TLB and the corresponding fixmap. Yes, this is costly. Reviewed-by: Oliver Upton <oliver.upton@linux.dev> Link: https://lore.kernel.org/r/20250514103501.2225951-14-maz@kernel.org Signed-off-by: Marc Zyngier <maz@kernel.org>
Diffstat (limited to 'rust/helpers/bitops.c')
0 files changed, 0 insertions, 0 deletions