Lines Matching refs:sprn

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