summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexander Graf <agraf@suse.de>2013-06-27 01:07:15 +0200
committerAlexander Graf <agraf@suse.de>2013-06-30 03:33:22 +0200
commita3ff5fbc94a829680d4aa005cd17add1c1a1fb5b (patch)
treec4e967bfba86a4d503734f20af73f0060279af17
parent681562cd56f5336cbdf6dab0c4b2f6ef16ea89ed (diff)
downloadlinux-stable-a3ff5fbc94a829680d4aa005cd17add1c1a1fb5b.tar.gz
linux-stable-a3ff5fbc94a829680d4aa005cd17add1c1a1fb5b.tar.bz2
linux-stable-a3ff5fbc94a829680d4aa005cd17add1c1a1fb5b.zip
KVM: PPC: Ignore PIR writes
While technically it's legal to write to PIR and have the identifier changed, we don't implement logic to do so because we simply expose vcpu_id to the guest. So instead, let's ignore writes to PIR. This ensures that we don't inject faults into the guest for something the guest is allowed to do. While at it, we cross our fingers hoping that it also doesn't mind that we broke its PIR read values. Signed-off-by: Alexander Graf <agraf@suse.de>
-rw-r--r--arch/powerpc/kvm/emulate.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/powerpc/kvm/emulate.c b/arch/powerpc/kvm/emulate.c
index 631a2650e4e4..2c52ada30775 100644
--- a/arch/powerpc/kvm/emulate.c
+++ b/arch/powerpc/kvm/emulate.c
@@ -169,6 +169,9 @@ static int kvmppc_emulate_mtspr(struct kvm_vcpu *vcpu, int sprn, int rs)
vcpu->arch.shared->sprg3 = spr_val;
break;
+ /* PIR can legally be written, but we ignore it */
+ case SPRN_PIR: break;
+
default:
emulated = kvmppc_core_emulate_mtspr(vcpu, sprn,
spr_val);