aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
authorAvi Kivity <avi@redhat.com>2011-04-20 08:53:23 -0400
committerAvi Kivity <avi@redhat.com>2011-05-22 08:39:20 -0400
commitbcaf5cc543bdb8f61fc3ce09944e0ecde2966595 (patch)
tree51aea97914f2886819cae24cc7c4073cfaab2a0d /arch/x86
parentd6aa10003b0cded5a538af0d198460e89dc2d6d2 (diff)
KVM: x86 emulator: add new ->wbinvd() callback
Instead of calling kvm_emulate_wbinvd() directly. Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86')
-rw-r--r--arch/x86/include/asm/kvm_emulate.h1
-rw-r--r--arch/x86/kvm/emulate.c2
-rw-r--r--arch/x86/kvm/x86.c6
3 files changed, 8 insertions, 1 deletions
diff --git a/arch/x86/include/asm/kvm_emulate.h b/arch/x86/include/asm/kvm_emulate.h
index d30840ddd2f3..51341d6b2f31 100644
--- a/arch/x86/include/asm/kvm_emulate.h
+++ b/arch/x86/include/asm/kvm_emulate.h
@@ -187,6 +187,7 @@ struct x86_emulate_ops {
187 int (*set_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 data); 187 int (*set_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 data);
188 int (*get_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 *pdata); 188 int (*get_msr)(struct x86_emulate_ctxt *ctxt, u32 msr_index, u64 *pdata);
189 void (*halt)(struct x86_emulate_ctxt *ctxt); 189 void (*halt)(struct x86_emulate_ctxt *ctxt);
190 void (*wbinvd)(struct x86_emulate_ctxt *ctxt);
190 int (*fix_hypercall)(struct x86_emulate_ctxt *ctxt); 191 int (*fix_hypercall)(struct x86_emulate_ctxt *ctxt);
191 void (*get_fpu)(struct x86_emulate_ctxt *ctxt); /* disables preempt */ 192 void (*get_fpu)(struct x86_emulate_ctxt *ctxt); /* disables preempt */
192 void (*put_fpu)(struct x86_emulate_ctxt *ctxt); /* reenables preempt */ 193 void (*put_fpu)(struct x86_emulate_ctxt *ctxt); /* reenables preempt */
diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
index 64e7373d3b2b..522bc35d290c 100644
--- a/arch/x86/kvm/emulate.c
+++ b/arch/x86/kvm/emulate.c
@@ -4092,7 +4092,7 @@ twobyte_insn:
4092 rc = em_clts(ctxt); 4092 rc = em_clts(ctxt);
4093 break; 4093 break;
4094 case 0x09: /* wbinvd */ 4094 case 0x09: /* wbinvd */
4095 kvm_emulate_wbinvd(ctxt->vcpu); 4095 ctxt->ops->wbinvd(ctxt);
4096 break; 4096 break;
4097 case 0x08: /* invd */ 4097 case 0x08: /* invd */
4098 case 0x0d: /* GrpP (prefetch) */ 4098 case 0x0d: /* GrpP (prefetch) */
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index 4a2b40e25021..5d853d540f95 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -4154,6 +4154,11 @@ int kvm_emulate_wbinvd(struct kvm_vcpu *vcpu)
4154} 4154}
4155EXPORT_SYMBOL_GPL(kvm_emulate_wbinvd); 4155EXPORT_SYMBOL_GPL(kvm_emulate_wbinvd);
4156 4156
4157static void emulator_wbinvd(struct x86_emulate_ctxt *ctxt)
4158{
4159 kvm_emulate_wbinvd(emul_to_vcpu(ctxt));
4160}
4161
4157int emulator_get_dr(struct x86_emulate_ctxt *ctxt, int dr, unsigned long *dest) 4162int emulator_get_dr(struct x86_emulate_ctxt *ctxt, int dr, unsigned long *dest)
4158{ 4163{
4159 return _kvm_get_dr(emul_to_vcpu(ctxt), dr, dest); 4164 return _kvm_get_dr(emul_to_vcpu(ctxt), dr, dest);
@@ -4408,6 +4413,7 @@ static struct x86_emulate_ops emulate_ops = {
4408 .set_msr = emulator_set_msr, 4413 .set_msr = emulator_set_msr,
4409 .get_msr = emulator_get_msr, 4414 .get_msr = emulator_get_msr,
4410 .halt = emulator_halt, 4415 .halt = emulator_halt,
4416 .wbinvd = emulator_wbinvd,
4411 .fix_hypercall = emulator_fix_hypercall, 4417 .fix_hypercall = emulator_fix_hypercall,
4412 .get_fpu = emulator_get_fpu, 4418 .get_fpu = emulator_get_fpu,
4413 .put_fpu = emulator_put_fpu, 4419 .put_fpu = emulator_put_fpu,