diff options
| author | Jintack Lim <jintack.lim@linaro.org> | 2023-02-09 17:58:18 +0000 | 
|---|---|---|
| committer | Oliver Upton <oliver.upton@linux.dev> | 2023-02-11 10:13:30 +0000 | 
| commit | 280b748e871e5a9bd61fc13019b8cbda6e0242dd (patch) | |
| tree | 90a86749e67c6e97139e38cd537afe86fa0d6140 /lib/memory-notifier-error-inject.c | |
| parent | e6b367db0f9192692a3f3057878f1259fe966d33 (diff) | |
KVM: arm64: nv: Emulate EL12 register accesses from the virtual EL2
With HCR_EL2.NV bit set, accesses to EL12 registers in the virtual EL2
trap to EL2. Handle those traps just like we do for EL1 registers.
One exception is CNTKCTL_EL12. We don't trap on CNTKCTL_EL1 for non-VHE
virtual EL2 because we don't have to. However, accessing CNTKCTL_EL12
will trap since it's one of the EL12 registers controlled by HCR_EL2.NV
bit.  Therefore, add a handler for it and don't treat it as a
non-trap-registers when preparing a shadow context.
These registers, being only a view on their EL1 counterpart, are
permanently hidden from userspace.
Reviewed-by: Alexandru Elisei <alexandru.elisei@arm.com>
Signed-off-by: Jintack Lim <jintack.lim@linaro.org>
[maz: EL12_REG(), register visibility]
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20230209175820.1939006-17-maz@kernel.org
Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
Diffstat (limited to 'lib/memory-notifier-error-inject.c')
0 files changed, 0 insertions, 0 deletions
