^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0-or-later */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) * Copyright IBM Corporation, 2013
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) * Author Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) #ifndef __POWERPC_KVM_BOOK3S_H__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) #define __POWERPC_KVM_BOOK3S_H__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) extern void kvmppc_core_flush_memslot_hv(struct kvm *kvm,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) struct kvm_memory_slot *memslot);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) extern int kvm_unmap_hva_range_hv(struct kvm *kvm, unsigned long start,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) unsigned long end);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) extern int kvm_age_hva_hv(struct kvm *kvm, unsigned long start,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) unsigned long end);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) extern int kvm_test_age_hva_hv(struct kvm *kvm, unsigned long hva);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) extern void kvm_set_spte_hva_hv(struct kvm *kvm, unsigned long hva, pte_t pte);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) extern int kvmppc_mmu_init_pr(struct kvm_vcpu *vcpu);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) extern void kvmppc_mmu_destroy_pr(struct kvm_vcpu *vcpu);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) extern int kvmppc_core_emulate_op_pr(struct kvm_vcpu *vcpu,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) unsigned int inst, int *advance);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) extern int kvmppc_core_emulate_mtspr_pr(struct kvm_vcpu *vcpu,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) int sprn, ulong spr_val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) extern int kvmppc_core_emulate_mfspr_pr(struct kvm_vcpu *vcpu,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) int sprn, ulong *spr_val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) extern int kvmppc_book3s_init_pr(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) extern void kvmppc_book3s_exit_pr(void);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) #ifdef CONFIG_PPC_TRANSACTIONAL_MEM
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) extern void kvmppc_emulate_tabort(struct kvm_vcpu *vcpu, int ra_val);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) static inline void kvmppc_emulate_tabort(struct kvm_vcpu *vcpu, int ra_val) {}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) extern void kvmppc_set_msr_hv(struct kvm_vcpu *vcpu, u64 msr);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) extern void kvmppc_inject_interrupt_hv(struct kvm_vcpu *vcpu, int vec, u64 srr1_flags);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) #endif