aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390/kvm/kvm-s390.h
diff options
context:
space:
mode:
authorChristian Borntraeger <borntraeger@de.ibm.com>2008-03-25 13:47:23 -0400
committerAvi Kivity <avi@qumranet.com>2008-04-27 05:00:43 -0400
commit8f2abe6a1e525e878bdf58f68ccd146d543fde84 (patch)
tree5f52959474a16847c740fb8668ebd9d6cbc75d07 /arch/s390/kvm/kvm-s390.h
parentb0c632db637d68ad39d9f97f452ce176253f5f4e (diff)
KVM: s390: sie intercept handling
This path introduces handling of sie intercepts in three flavors: Intercepts are either handled completely in-kernel by kvm_handle_sie_intercept(), or passed to userspace with corresponding data in struct kvm_run in case kvm_handle_sie_intercept() returns -ENOTSUPP. In case of partial execution in kernel with the need of userspace support, kvm_handle_sie_intercept() may choose to set up struct kvm_run and return -EREMOTE. The trivial intercept reasons are handled in this patch: handle_noop() just does nothing for intercepts that don't require our support at all handle_stop() is called when a cpu enters stopped state, and it drops out to userland after updating our vcpu state handle_validity() faults in the cpu lowcore if needed, or passes the request to userland Acked-by: Martin Schwidefsky <schwidefsky@de.ibm.com> Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com> Signed-off-by: Carsten Otte <cotte@de.ibm.com> Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'arch/s390/kvm/kvm-s390.h')
-rw-r--r--arch/s390/kvm/kvm-s390.h7
1 files changed, 7 insertions, 0 deletions
diff --git a/arch/s390/kvm/kvm-s390.h b/arch/s390/kvm/kvm-s390.h
index ed64a22ca86f..5b82527b7f86 100644
--- a/arch/s390/kvm/kvm-s390.h
+++ b/arch/s390/kvm/kvm-s390.h
@@ -13,6 +13,13 @@
13 13
14#ifndef ARCH_S390_KVM_S390_H 14#ifndef ARCH_S390_KVM_S390_H
15#define ARCH_S390_KVM_S390_H 15#define ARCH_S390_KVM_S390_H
16
17#include <linux/kvm_host.h>
18
19typedef int (*intercept_handler_t)(struct kvm_vcpu *vcpu);
20
21int kvm_handle_sie_intercept(struct kvm_vcpu *vcpu);
22
16#define VM_EVENT(d_kvm, d_loglevel, d_string, d_args...)\ 23#define VM_EVENT(d_kvm, d_loglevel, d_string, d_args...)\
17do { \ 24do { \
18 debug_sprintf_event(d_kvm->arch.dbf, d_loglevel, d_string "\n", \ 25 debug_sprintf_event(d_kvm->arch.dbf, d_loglevel, d_string "\n", \