|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  | /* | 
|  | * Copyright IBM Corporation, 2013 | 
|  | * Author Aneesh Kumar K.V <aneesh.kumar@linux.vnet.ibm.com> | 
|  | */ | 
|  |  | 
|  | #ifndef __POWERPC_KVM_BOOK3S_H__ | 
|  | #define __POWERPC_KVM_BOOK3S_H__ | 
|  |  | 
|  | extern void kvmppc_core_flush_memslot_hv(struct kvm *kvm, | 
|  | struct kvm_memory_slot *memslot); | 
|  | extern int kvm_unmap_hva_range_hv(struct kvm *kvm, unsigned long start, | 
|  | unsigned long end); | 
|  | extern int kvm_age_hva_hv(struct kvm *kvm, unsigned long start, | 
|  | unsigned long end); | 
|  | extern int kvm_test_age_hva_hv(struct kvm *kvm, unsigned long hva); | 
|  | extern void kvm_set_spte_hva_hv(struct kvm *kvm, unsigned long hva, pte_t pte); | 
|  |  | 
|  | extern int kvmppc_mmu_init_pr(struct kvm_vcpu *vcpu); | 
|  | extern void kvmppc_mmu_destroy_pr(struct kvm_vcpu *vcpu); | 
|  | extern int kvmppc_core_emulate_op_pr(struct kvm_vcpu *vcpu, | 
|  | unsigned int inst, int *advance); | 
|  | extern int kvmppc_core_emulate_mtspr_pr(struct kvm_vcpu *vcpu, | 
|  | int sprn, ulong spr_val); | 
|  | extern int kvmppc_core_emulate_mfspr_pr(struct kvm_vcpu *vcpu, | 
|  | int sprn, ulong *spr_val); | 
|  | extern int kvmppc_book3s_init_pr(void); | 
|  | extern void kvmppc_book3s_exit_pr(void); | 
|  |  | 
|  | #ifdef CONFIG_PPC_TRANSACTIONAL_MEM | 
|  | extern void kvmppc_emulate_tabort(struct kvm_vcpu *vcpu, int ra_val); | 
|  | #else | 
|  | static inline void kvmppc_emulate_tabort(struct kvm_vcpu *vcpu, int ra_val) {} | 
|  | #endif | 
|  |  | 
|  | extern void kvmppc_set_msr_hv(struct kvm_vcpu *vcpu, u64 msr); | 
|  | extern void kvmppc_inject_interrupt_hv(struct kvm_vcpu *vcpu, int vec, u64 srr1_flags); | 
|  |  | 
|  | #endif |