mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-11 08:18:47 +00:00
3a43970d55
Implement the H_SVM_INIT_ABORT hcall which the Ultravisor can use to abort an SVM after it has issued the H_SVM_INIT_START and before the H_SVM_INIT_DONE hcalls. This hcall could be used when Ultravisor encounters security violations or other errors when starting an SVM. Note that this hcall is different from UV_SVM_TERMINATE ucall which is used by HV to terminate/cleanup an VM that has becore secure. The H_SVM_INIT_ABORT basically undoes operations that were done since the H_SVM_INIT_START hcall - i.e page-out all the VM pages back to normal memory, and terminate the SVM. (If we do not bring the pages back to normal memory, the text/data of the VM would be stuck in secure memory and since the SVM did not go secure, its MSR_S bit will be clear and the VM wont be able to access its pages even to do a clean exit). Based on patches and discussion with Paul Mackerras, Ram Pai and Bharata Rao. Signed-off-by: Ram Pai <linuxram@linux.ibm.com> Signed-off-by: Sukadev Bhattiprolu <sukadev@linux.ibm.com> Signed-off-by: Bharata B Rao <bharata@linux.ibm.com> Signed-off-by: Paul Mackerras <paulus@ozlabs.org>
81 lines
2.2 KiB
C
81 lines
2.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __ASM_KVM_BOOK3S_UVMEM_H__
|
|
#define __ASM_KVM_BOOK3S_UVMEM_H__
|
|
|
|
#ifdef CONFIG_PPC_UV
|
|
int kvmppc_uvmem_init(void);
|
|
void kvmppc_uvmem_free(void);
|
|
int kvmppc_uvmem_slot_init(struct kvm *kvm, const struct kvm_memory_slot *slot);
|
|
void kvmppc_uvmem_slot_free(struct kvm *kvm,
|
|
const struct kvm_memory_slot *slot);
|
|
unsigned long kvmppc_h_svm_page_in(struct kvm *kvm,
|
|
unsigned long gra,
|
|
unsigned long flags,
|
|
unsigned long page_shift);
|
|
unsigned long kvmppc_h_svm_page_out(struct kvm *kvm,
|
|
unsigned long gra,
|
|
unsigned long flags,
|
|
unsigned long page_shift);
|
|
unsigned long kvmppc_h_svm_init_start(struct kvm *kvm);
|
|
unsigned long kvmppc_h_svm_init_done(struct kvm *kvm);
|
|
int kvmppc_send_page_to_uv(struct kvm *kvm, unsigned long gfn);
|
|
unsigned long kvmppc_h_svm_init_abort(struct kvm *kvm);
|
|
void kvmppc_uvmem_drop_pages(const struct kvm_memory_slot *free,
|
|
struct kvm *kvm, bool skip_page_out);
|
|
#else
|
|
static inline int kvmppc_uvmem_init(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void kvmppc_uvmem_free(void) { }
|
|
|
|
static inline int
|
|
kvmppc_uvmem_slot_init(struct kvm *kvm, const struct kvm_memory_slot *slot)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void
|
|
kvmppc_uvmem_slot_free(struct kvm *kvm, const struct kvm_memory_slot *slot) { }
|
|
|
|
static inline unsigned long
|
|
kvmppc_h_svm_page_in(struct kvm *kvm, unsigned long gra,
|
|
unsigned long flags, unsigned long page_shift)
|
|
{
|
|
return H_UNSUPPORTED;
|
|
}
|
|
|
|
static inline unsigned long
|
|
kvmppc_h_svm_page_out(struct kvm *kvm, unsigned long gra,
|
|
unsigned long flags, unsigned long page_shift)
|
|
{
|
|
return H_UNSUPPORTED;
|
|
}
|
|
|
|
static inline unsigned long kvmppc_h_svm_init_start(struct kvm *kvm)
|
|
{
|
|
return H_UNSUPPORTED;
|
|
}
|
|
|
|
static inline unsigned long kvmppc_h_svm_init_done(struct kvm *kvm)
|
|
{
|
|
return H_UNSUPPORTED;
|
|
}
|
|
|
|
static inline unsigned long kvmppc_h_svm_init_abort(struct kvm *kvm)
|
|
{
|
|
return H_UNSUPPORTED;
|
|
}
|
|
|
|
static inline int kvmppc_send_page_to_uv(struct kvm *kvm, unsigned long gfn)
|
|
{
|
|
return -EFAULT;
|
|
}
|
|
|
|
static inline void
|
|
kvmppc_uvmem_drop_pages(const struct kvm_memory_slot *free,
|
|
struct kvm *kvm, bool skip_page_out) { }
|
|
#endif /* CONFIG_PPC_UV */
|
|
#endif /* __ASM_KVM_BOOK3S_UVMEM_H__ */
|