KVM: ppc: e500: Add MMUCFG and PVR emulation
Latest kernel started to use these two registers. Signed-off-by: Liu Yu <yu.liu@freescale.com> Signed-off-by: Avi Kivity <avi@redhat.com>
This commit is contained in:
parent
5b7c1a2c17
commit
06579dd9c1
@ -180,6 +180,9 @@ int kvmppc_core_emulate_mfspr(struct kvm_vcpu *vcpu, int sprn, int rt)
|
|||||||
case SPRN_MMUCSR0:
|
case SPRN_MMUCSR0:
|
||||||
vcpu->arch.gpr[rt] = 0; break;
|
vcpu->arch.gpr[rt] = 0; break;
|
||||||
|
|
||||||
|
case SPRN_MMUCFG:
|
||||||
|
vcpu->arch.gpr[rt] = mfspr(SPRN_MMUCFG); break;
|
||||||
|
|
||||||
/* extra exceptions */
|
/* extra exceptions */
|
||||||
case SPRN_IVOR32:
|
case SPRN_IVOR32:
|
||||||
vcpu->arch.gpr[rt] = vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_UNAVAIL];
|
vcpu->arch.gpr[rt] = vcpu->arch.ivor[BOOKE_IRQPRIO_SPE_UNAVAIL];
|
||||||
|
@ -188,6 +188,8 @@ int kvmppc_emulate_instruction(struct kvm_run *run, struct kvm_vcpu *vcpu)
|
|||||||
vcpu->arch.gpr[rt] = vcpu->arch.srr1; break;
|
vcpu->arch.gpr[rt] = vcpu->arch.srr1; break;
|
||||||
case SPRN_PVR:
|
case SPRN_PVR:
|
||||||
vcpu->arch.gpr[rt] = mfspr(SPRN_PVR); break;
|
vcpu->arch.gpr[rt] = mfspr(SPRN_PVR); break;
|
||||||
|
case SPRN_PIR:
|
||||||
|
vcpu->arch.gpr[rt] = mfspr(SPRN_PIR); break;
|
||||||
|
|
||||||
/* Note: mftb and TBRL/TBWL are user-accessible, so
|
/* Note: mftb and TBRL/TBWL are user-accessible, so
|
||||||
* the guest can always access the real TB anyways.
|
* the guest can always access the real TB anyways.
|
||||||
|
Loading…
Reference in New Issue
Block a user