Lines Matching refs:sprn
653 static struct kvmppc_bat *kvmppc_find_bat(struct kvm_vcpu *vcpu, int sprn) in kvmppc_find_bat() argument
658 switch (sprn) { in kvmppc_find_bat()
660 bat = &vcpu_book3s->ibat[(sprn - SPRN_IBAT0U) / 2]; in kvmppc_find_bat()
663 bat = &vcpu_book3s->ibat[4 + ((sprn - SPRN_IBAT4U) / 2)]; in kvmppc_find_bat()
666 bat = &vcpu_book3s->dbat[(sprn - SPRN_DBAT0U) / 2]; in kvmppc_find_bat()
669 bat = &vcpu_book3s->dbat[4 + ((sprn - SPRN_DBAT4U) / 2)]; in kvmppc_find_bat()
678 int kvmppc_core_emulate_mtspr_pr(struct kvm_vcpu *vcpu, int sprn, ulong spr_val) in kvmppc_core_emulate_mtspr_pr() argument
682 switch (sprn) { in kvmppc_core_emulate_mtspr_pr()
702 struct kvmppc_bat *bat = kvmppc_find_bat(vcpu, sprn); in kvmppc_core_emulate_mtspr_pr()
704 kvmppc_set_bat(vcpu, bat, !(sprn % 2), (u32)spr_val); in kvmppc_core_emulate_mtspr_pr()
763 to_book3s(vcpu)->gqr[sprn - SPRN_GQR0] = spr_val; in kvmppc_core_emulate_mtspr_pr()
793 (sprn == SPRN_TFHAR))) { in kvmppc_core_emulate_mtspr_pr()
804 if (sprn == SPRN_TFHAR) in kvmppc_core_emulate_mtspr_pr()
806 else if (sprn == SPRN_TEXASR) in kvmppc_core_emulate_mtspr_pr()
846 pr_info_ratelimited("KVM: invalid SPR write: %d\n", sprn); in kvmppc_core_emulate_mtspr_pr()
847 if (sprn & 0x10) { in kvmppc_core_emulate_mtspr_pr()
853 if ((kvmppc_get_msr(vcpu) & MSR_PR) || sprn == 0) { in kvmppc_core_emulate_mtspr_pr()
864 int kvmppc_core_emulate_mfspr_pr(struct kvm_vcpu *vcpu, int sprn, ulong *spr_val) in kvmppc_core_emulate_mfspr_pr() argument
868 switch (sprn) { in kvmppc_core_emulate_mfspr_pr()
874 struct kvmppc_bat *bat = kvmppc_find_bat(vcpu, sprn); in kvmppc_core_emulate_mfspr_pr()
876 if (sprn % 2) in kvmppc_core_emulate_mfspr_pr()
944 *spr_val = to_book3s(vcpu)->gqr[sprn - SPRN_GQR0]; in kvmppc_core_emulate_mfspr_pr()
973 if (sprn == SPRN_TFHAR) in kvmppc_core_emulate_mfspr_pr()
975 else if (sprn == SPRN_TEXASR) in kvmppc_core_emulate_mfspr_pr()
977 else if (sprn == SPRN_TFIAR) in kvmppc_core_emulate_mfspr_pr()
1014 pr_info_ratelimited("KVM: invalid SPR read: %d\n", sprn); in kvmppc_core_emulate_mfspr_pr()
1015 if (sprn & 0x10) { in kvmppc_core_emulate_mfspr_pr()
1021 if ((kvmppc_get_msr(vcpu) & MSR_PR) || sprn == 0 || in kvmppc_core_emulate_mfspr_pr()
1022 sprn == 4 || sprn == 5 || sprn == 6) { in kvmppc_core_emulate_mfspr_pr()