diff options
author | Alexander Graf <agraf@suse.de> | 2012-08-13 08:50:54 -0400 |
---|---|---|
committer | Alexander Graf <agraf@suse.de> | 2012-10-05 17:38:48 -0400 |
commit | 50c871edf59b4585fd2c17acfe4e7cd3752418b7 (patch) | |
tree | 756a74415eb506a6f8137730a4a9e23f0e257ab0 | |
parent | 491dd5b8a4926393308172da80c73faf242a4057 (diff) |
KVM: PPC: BookE: Add MCSR SPR support
Add support for the MCSR SPR. This only implements the SPR storage
bits, not actual machine checks.
Signed-off-by: Alexander Graf <agraf@suse.de>
-rw-r--r-- | arch/powerpc/kvm/booke_emulate.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/powerpc/kvm/booke_emulate.c b/arch/powerpc/kvm/booke_emulate.c index cc99a0b3d202..514790f41aba 100644 --- a/arch/powerpc/kvm/booke_emulate.c +++ b/arch/powerpc/kvm/booke_emulate.c | |||
@@ -237,6 +237,9 @@ int kvmppc_booke_emulate_mtspr(struct kvm_vcpu *vcpu, int sprn, ulong spr_val) | |||
237 | case SPRN_IVOR15: | 237 | case SPRN_IVOR15: |
238 | vcpu->arch.ivor[BOOKE_IRQPRIO_DEBUG] = spr_val; | 238 | vcpu->arch.ivor[BOOKE_IRQPRIO_DEBUG] = spr_val; |
239 | break; | 239 | break; |
240 | case SPRN_MCSR: | ||
241 | vcpu->arch.mcsr &= ~spr_val; | ||
242 | break; | ||
240 | 243 | ||
241 | default: | 244 | default: |
242 | emulated = EMULATE_FAIL; | 245 | emulated = EMULATE_FAIL; |
@@ -329,6 +332,9 @@ int kvmppc_booke_emulate_mfspr(struct kvm_vcpu *vcpu, int sprn, ulong *spr_val) | |||
329 | case SPRN_IVOR15: | 332 | case SPRN_IVOR15: |
330 | *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_DEBUG]; | 333 | *spr_val = vcpu->arch.ivor[BOOKE_IRQPRIO_DEBUG]; |
331 | break; | 334 | break; |
335 | case SPRN_MCSR: | ||
336 | *spr_val = vcpu->arch.mcsr; | ||
337 | break; | ||
332 | 338 | ||
333 | default: | 339 | default: |
334 | emulated = EMULATE_FAIL; | 340 | emulated = EMULATE_FAIL; |