aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorAvi Kivity <avi@qumranet.com>2007-10-22 10:50:39 -0400
committerAvi Kivity <avi@qumranet.com>2008-01-30 11:01:20 -0500
commitb209749f528488c4c0d20a42c0fbcbf49e6933b3 (patch)
tree0e0a24225a5c6bca1c1986cc0daaf8753424cfe6 /include
parent565f1fbd9d2f766dcfed5db90b89ef80afe8b49a (diff)
KVM: local APIC TPR access reporting facility
Add a facility to report on accesses to the local apic tpr even if the local apic is emulated in the kernel. This is basically a hack that allows userspace to patch Windows which tends to bang on the tpr a lot. Signed-off-by: Avi Kivity <avi@qumranet.com>
Diffstat (limited to 'include')
-rw-r--r--include/asm-x86/kvm_host.h1
-rw-r--r--include/linux/kvm.h17
-rw-r--r--include/linux/kvm_host.h2
3 files changed, 19 insertions, 1 deletions
diff --git a/include/asm-x86/kvm_host.h b/include/asm-x86/kvm_host.h
index ced1bebabbc8..6e649af08d19 100644
--- a/include/asm-x86/kvm_host.h
+++ b/include/asm-x86/kvm_host.h
@@ -211,6 +211,7 @@ struct kvm_vcpu_arch {
211 int mp_state; 211 int mp_state;
212 int sipi_vector; 212 int sipi_vector;
213 u64 ia32_misc_enable_msr; 213 u64 ia32_misc_enable_msr;
214 bool tpr_access_reporting;
214 215
215 struct kvm_mmu mmu; 216 struct kvm_mmu mmu;
216 217
diff --git a/include/linux/kvm.h b/include/linux/kvm.h
index de9f28d96ced..850f5ef76636 100644
--- a/include/linux/kvm.h
+++ b/include/linux/kvm.h
@@ -72,6 +72,7 @@ struct kvm_irqchip {
72#define KVM_EXIT_FAIL_ENTRY 9 72#define KVM_EXIT_FAIL_ENTRY 9
73#define KVM_EXIT_INTR 10 73#define KVM_EXIT_INTR 10
74#define KVM_EXIT_SET_TPR 11 74#define KVM_EXIT_SET_TPR 11
75#define KVM_EXIT_TPR_ACCESS 12
75 76
76/* for KVM_RUN, returned by mmap(vcpu_fd, offset=0) */ 77/* for KVM_RUN, returned by mmap(vcpu_fd, offset=0) */
77struct kvm_run { 78struct kvm_run {
@@ -130,6 +131,12 @@ struct kvm_run {
130 __u32 longmode; 131 __u32 longmode;
131 __u32 pad; 132 __u32 pad;
132 } hypercall; 133 } hypercall;
134 /* KVM_EXIT_TPR_ACCESS */
135 struct {
136 __u64 rip;
137 __u32 is_write;
138 __u32 pad;
139 } tpr_access;
133 /* Fix the size of the union. */ 140 /* Fix the size of the union. */
134 char padding[256]; 141 char padding[256];
135 }; 142 };
@@ -202,6 +209,13 @@ struct kvm_signal_mask {
202 __u8 sigset[0]; 209 __u8 sigset[0];
203}; 210};
204 211
212/* for KVM_TPR_ACCESS_REPORTING */
213struct kvm_tpr_access_ctl {
214 __u32 enabled;
215 __u32 flags;
216 __u32 reserved[8];
217};
218
205#define KVMIO 0xAE 219#define KVMIO 0xAE
206 220
207/* 221/*
@@ -229,6 +243,7 @@ struct kvm_signal_mask {
229#define KVM_CAP_USER_MEMORY 3 243#define KVM_CAP_USER_MEMORY 3
230#define KVM_CAP_SET_TSS_ADDR 4 244#define KVM_CAP_SET_TSS_ADDR 4
231#define KVM_CAP_EXT_CPUID 5 245#define KVM_CAP_EXT_CPUID 5
246#define KVM_CAP_VAPIC 6
232 247
233/* 248/*
234 * ioctls for VM fds 249 * ioctls for VM fds
@@ -274,5 +289,7 @@ struct kvm_signal_mask {
274#define KVM_SET_LAPIC _IOW(KVMIO, 0x8f, struct kvm_lapic_state) 289#define KVM_SET_LAPIC _IOW(KVMIO, 0x8f, struct kvm_lapic_state)
275#define KVM_SET_CPUID2 _IOW(KVMIO, 0x90, struct kvm_cpuid2) 290#define KVM_SET_CPUID2 _IOW(KVMIO, 0x90, struct kvm_cpuid2)
276#define KVM_GET_CPUID2 _IOWR(KVMIO, 0x91, struct kvm_cpuid2) 291#define KVM_GET_CPUID2 _IOWR(KVMIO, 0x91, struct kvm_cpuid2)
292/* Available with KVM_CAP_VAPIC */
293#define KVM_TPR_ACCESS_REPORTING _IOWR(KVMIO, 0x92, struct kvm_tpr_access_ctl)
277 294
278#endif 295#endif
diff --git a/include/linux/kvm_host.h b/include/linux/kvm_host.h
index 953b50aa0e61..9ff5904c5072 100644
--- a/include/linux/kvm_host.h
+++ b/include/linux/kvm_host.h
@@ -35,7 +35,7 @@
35 * vcpu->requests bit members 35 * vcpu->requests bit members
36 */ 36 */
37#define KVM_REQ_TLB_FLUSH 0 37#define KVM_REQ_TLB_FLUSH 0
38 38#define KVM_REQ_REPORT_TPR_ACCESS 2
39 39
40struct kvm_vcpu; 40struct kvm_vcpu;
41extern struct kmem_cache *kvm_vcpu_cache; 41extern struct kmem_cache *kvm_vcpu_cache;