aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/kvm
diff options
context:
space:
mode:
authorScott Wood <scottwood@freescale.com>2011-04-27 18:24:10 -0400
committerAvi Kivity <avi@redhat.com>2011-05-22 08:47:50 -0400
commiteab176722f4628b2d9cf76221a43dd3a0e37e632 (patch)
tree4b1e9e9ecb6adc4fb97c47ad5a3c174d3ad942ef /arch/powerpc/kvm
parent1a040b26c5c915b317103b87ae7006d40443f197 (diff)
KVM: PPC: booke: save/restore VRSAVE (a.k.a. USPRG0)
Linux doesn't use USPRG0 (now renamed VRSAVE in the architecture, even when Altivec isn't involved), but a guest might. Signed-off-by: Scott Wood <scottwood@freescale.com> Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/kvm')
-rw-r--r--arch/powerpc/kvm/booke_interrupts.S1
-rw-r--r--arch/powerpc/kvm/powerpc.c13
2 files changed, 13 insertions, 1 deletions
diff --git a/arch/powerpc/kvm/booke_interrupts.S b/arch/powerpc/kvm/booke_interrupts.S
index 1cc471faac2d..b58ccae95904 100644
--- a/arch/powerpc/kvm/booke_interrupts.S
+++ b/arch/powerpc/kvm/booke_interrupts.S
@@ -380,7 +380,6 @@ lightweight_exit:
380 * because host interrupt handlers would get confused. */ 380 * because host interrupt handlers would get confused. */
381 lwz r1, VCPU_GPR(r1)(r4) 381 lwz r1, VCPU_GPR(r1)(r4)
382 382
383 /* XXX handle USPRG0 */
384 /* Host interrupt handlers may have clobbered these guest-readable 383 /* Host interrupt handlers may have clobbered these guest-readable
385 * SPRGs, so we need to reload them here with the guest's values. */ 384 * SPRGs, so we need to reload them here with the guest's values. */
386 lwz r3, VCPU_SPRG4(r4) 385 lwz r3, VCPU_SPRG4(r4)
diff --git a/arch/powerpc/kvm/powerpc.c b/arch/powerpc/kvm/powerpc.c
index ec3d2e75c0a8..9e6aa8bfd160 100644
--- a/arch/powerpc/kvm/powerpc.c
+++ b/arch/powerpc/kvm/powerpc.c
@@ -298,12 +298,25 @@ void kvm_arch_vcpu_uninit(struct kvm_vcpu *vcpu)
298 298
299void kvm_arch_vcpu_load(struct kvm_vcpu *vcpu, int cpu) 299void kvm_arch_vcpu_load(struct kvm_vcpu *vcpu, int cpu)
300{ 300{
301#ifdef CONFIG_BOOKE
302 /*
303 * vrsave (formerly usprg0) isn't used by Linux, but may
304 * be used by the guest.
305 *
306 * On non-booke this is associated with Altivec and
307 * is handled by code in book3s.c.
308 */
309 mtspr(SPRN_VRSAVE, vcpu->arch.vrsave);
310#endif
301 kvmppc_core_vcpu_load(vcpu, cpu); 311 kvmppc_core_vcpu_load(vcpu, cpu);
302} 312}
303 313
304void kvm_arch_vcpu_put(struct kvm_vcpu *vcpu) 314void kvm_arch_vcpu_put(struct kvm_vcpu *vcpu)
305{ 315{
306 kvmppc_core_vcpu_put(vcpu); 316 kvmppc_core_vcpu_put(vcpu);
317#ifdef CONFIG_BOOKE
318 vcpu->arch.vrsave = mfspr(SPRN_VRSAVE);
319#endif
307} 320}
308 321
309int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu, 322int kvm_arch_vcpu_ioctl_set_guest_debug(struct kvm_vcpu *vcpu,