aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kvm
diff options
context:
space:
mode:
authorAvi Kivity <avi@redhat.com>2011-04-20 08:47:13 -0400
committerAvi Kivity <avi@redhat.com>2011-05-22 08:39:18 -0400
commitd6aa10003b0cded5a538af0d198460e89dc2d6d2 (patch)
tree1a98dd6a65d5c9deaa83616b3a74fdcff5ca00fd /arch/x86/kvm
parent6c3287f7c5050076b554145f11bdba058de287d1 (diff)
KVM: x86 emulator: add ->fix_hypercall() callback
Artificial, but needed to remove direct calls to KVM. Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/kvm')
-rw-r--r--arch/x86/kvm/emulate.c4
-rw-r--r--arch/x86/kvm/x86.c6
2 files changed, 7 insertions, 3 deletions
diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index 210df51b76a4..64e7373d3b2b 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -4025,7 +4025,7 @@ twobyte_insn:
4025 if (c->modrm_mod != 3 || c->modrm_rm != 1) 4025 if (c->modrm_mod != 3 || c->modrm_rm != 1)
4026 goto cannot_emulate; 4026 goto cannot_emulate;
4027 4027
4028 rc = kvm_fix_hypercall(ctxt->vcpu); 4028 rc = ctxt->ops->fix_hypercall(ctxt);
4029 if (rc != X86EMUL_CONTINUE) 4029 if (rc != X86EMUL_CONTINUE)
4030 goto done; 4030 goto done;
4031 4031
@@ -4048,7 +4048,7 @@ twobyte_insn:
4048 if (c->modrm_mod == 3) { 4048 if (c->modrm_mod == 3) {
4049 switch (c->modrm_rm) { 4049 switch (c->modrm_rm) {
4050 case 1: 4050 case 1:
4051 rc = kvm_fix_hypercall(ctxt->vcpu); 4051 rc = ctxt->ops->fix_hypercall(ctxt);
4052 break; 4052 break;
4053 default: 4053 default:
4054 goto cannot_emulate; 4054 goto cannot_emulate;
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 2246cf1a4ee0..4a2b40e25021 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -152,6 +152,8 @@ struct kvm_stats_debugfs_item debugfs_entries[] = {
152 152
153u64 __read_mostly host_xcr0; 153u64 __read_mostly host_xcr0;
154 154
155int emulator_fix_hypercall(struct x86_emulate_ctxt *ctxt);
156
155static inline void kvm_async_pf_hash_reset(struct kvm_vcpu *vcpu) 157static inline void kvm_async_pf_hash_reset(struct kvm_vcpu *vcpu)
156{ 158{
157 int i; 159 int i;
@@ -4406,6 +4408,7 @@ static struct x86_emulate_ops emulate_ops = {
4406 .set_msr = emulator_set_msr, 4408 .set_msr = emulator_set_msr,
4407 .get_msr = emulator_get_msr, 4409 .get_msr = emulator_get_msr,
4408 .halt = emulator_halt, 4410 .halt = emulator_halt,
4411 .fix_hypercall = emulator_fix_hypercall,
4409 .get_fpu = emulator_get_fpu, 4412 .get_fpu = emulator_get_fpu,
4410 .put_fpu = emulator_put_fpu, 4413 .put_fpu = emulator_put_fpu,
4411 .intercept = emulator_intercept, 4414 .intercept = emulator_intercept,
@@ -5042,8 +5045,9 @@ out:
5042} 5045}
5043EXPORT_SYMBOL_GPL(kvm_emulate_hypercall); 5046EXPORT_SYMBOL_GPL(kvm_emulate_hypercall);
5044 5047
5045int kvm_fix_hypercall(struct kvm_vcpu *vcpu) 5048int emulator_fix_hypercall(struct x86_emulate_ctxt *ctxt)
5046{ 5049{
5050 struct kvm_vcpu *vcpu = emul_to_vcpu(ctxt);
5047 char instruction[3]; 5051 char instruction[3];
5048 unsigned long rip = kvm_rip_read(vcpu); 5052 unsigned long rip = kvm_rip_read(vcpu);
5049 5053