summaryrefslogtreecommitdiffstats
path: root/virt
diff options
context:
space:
mode:
authorChristoffer Dall <christoffer.dall@arm.com>2018-12-20 12:44:05 +0100
committerMarc Zyngier <marc.zyngier@arm.com>2019-02-07 12:43:59 +0100
commite761a927bc9a7ee6ceb7c4f63d5922dbced87f0d (patch)
treea77628056f5717fc8461665a7524f1bf94619726 /virt
parentarm64: KVM: Don't generate UNDEF when LORegion feature is present (diff)
downloadlinux-e761a927bc9a7ee6ceb7c4f63d5922dbced87f0d.tar.xz
linux-e761a927bc9a7ee6ceb7c4f63d5922dbced87f0d.zip
KVM: arm/arm64: Reset the VCPU without preemption and vcpu state loaded
We have two ways to reset a vcpu: - either through VCPU_INIT - or through a PSCI_ON call The first one is easy to reason about. The second one is implemented in a more bizarre way, as it is the vcpu that handles PSCI_ON that resets the vcpu that is being powered-on. As we need to turn the logic around and have the target vcpu to reset itself, we must take some preliminary steps. Resetting the VCPU state modifies the system register state in memory, but this may interact with vcpu_load/vcpu_put if running with preemption disabled, which in turn may lead to corrupted system register state. Address this by disabling preemption and doing put/load if required around the reset logic. Reviewed-by: Andrew Jones <drjones@redhat.com> Signed-off-by: Christoffer Dall <christoffer.dall@arm.com> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Diffstat (limited to 'virt')
0 files changed, 0 insertions, 0 deletions