Lines Matching refs:sprn
657 static struct kvmppc_bat *kvmppc_find_bat(struct kvm_vcpu *vcpu, int sprn)
662 switch (sprn) {
664 bat = &vcpu_book3s->ibat[(sprn - SPRN_IBAT0U) / 2];
667 bat = &vcpu_book3s->ibat[4 + ((sprn - SPRN_IBAT4U) / 2)];
670 bat = &vcpu_book3s->dbat[(sprn - SPRN_DBAT0U) / 2];
673 bat = &vcpu_book3s->dbat[4 + ((sprn - SPRN_DBAT4U) / 2)];
682 int kvmppc_core_emulate_mtspr_pr(struct kvm_vcpu *vcpu, int sprn, ulong spr_val)
686 switch (sprn) {
706 struct kvmppc_bat *bat = kvmppc_find_bat(vcpu, sprn);
708 kvmppc_set_bat(vcpu, bat, !(sprn % 2), (u32)spr_val);
767 to_book3s(vcpu)->gqr[sprn - SPRN_GQR0] = spr_val;
797 (sprn == SPRN_TFHAR))) {
808 if (sprn == SPRN_TFHAR)
810 else if (sprn == SPRN_TEXASR)
847 pr_info_ratelimited("KVM: invalid SPR write: %d\n", sprn);
848 if (sprn & 0x10) {
854 if ((kvmppc_get_msr(vcpu) & MSR_PR) || sprn == 0) {
865 int kvmppc_core_emulate_mfspr_pr(struct kvm_vcpu *vcpu, int sprn, ulong *spr_val)
869 switch (sprn) {
875 struct kvmppc_bat *bat = kvmppc_find_bat(vcpu, sprn);
877 if (sprn % 2)
945 *spr_val = to_book3s(vcpu)->gqr[sprn - SPRN_GQR0];
974 if (sprn == SPRN_TFHAR)
976 else if (sprn == SPRN_TEXASR)
978 else if (sprn == SPRN_TFIAR)
1012 pr_info_ratelimited("KVM: invalid SPR read: %d\n", sprn);
1013 if (sprn & 0x10) {
1019 if ((kvmppc_get_msr(vcpu) & MSR_PR) || sprn == 0 ||
1020 sprn == 4 || sprn == 5 || sprn == 6) {