diff options
author | Paul Mackerras <paulus@samba.org> | 2007-05-07 23:37:51 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2007-05-07 23:37:51 -0400 |
commit | 02bbc0f09c90cefdb2837605c96a66c5ce4ba2e1 (patch) | |
tree | 04ef573cd4de095c500c9fc3477f4278c0b36300 /drivers/kvm/kvm.h | |
parent | 7487a2245b8841c77ba9db406cf99a483b9334e9 (diff) | |
parent | 5b94f675f57e4ff16c8fda09088d7480a84dcd91 (diff) |
Merge branch 'linux-2.6'
Diffstat (limited to 'drivers/kvm/kvm.h')
-rw-r--r-- | drivers/kvm/kvm.h | 100 |
1 files changed, 68 insertions, 32 deletions
diff --git a/drivers/kvm/kvm.h b/drivers/kvm/kvm.h index 0d122bf889db..41634fde8e13 100644 --- a/drivers/kvm/kvm.h +++ b/drivers/kvm/kvm.h | |||
@@ -51,16 +51,19 @@ | |||
51 | #define UNMAPPED_GVA (~(gpa_t)0) | 51 | #define UNMAPPED_GVA (~(gpa_t)0) |
52 | 52 | ||
53 | #define KVM_MAX_VCPUS 1 | 53 | #define KVM_MAX_VCPUS 1 |
54 | #define KVM_ALIAS_SLOTS 4 | ||
54 | #define KVM_MEMORY_SLOTS 4 | 55 | #define KVM_MEMORY_SLOTS 4 |
55 | #define KVM_NUM_MMU_PAGES 256 | 56 | #define KVM_NUM_MMU_PAGES 256 |
56 | #define KVM_MIN_FREE_MMU_PAGES 5 | 57 | #define KVM_MIN_FREE_MMU_PAGES 5 |
57 | #define KVM_REFILL_PAGES 25 | 58 | #define KVM_REFILL_PAGES 25 |
59 | #define KVM_MAX_CPUID_ENTRIES 40 | ||
58 | 60 | ||
59 | #define FX_IMAGE_SIZE 512 | 61 | #define FX_IMAGE_SIZE 512 |
60 | #define FX_IMAGE_ALIGN 16 | 62 | #define FX_IMAGE_ALIGN 16 |
61 | #define FX_BUF_SIZE (2 * FX_IMAGE_SIZE + FX_IMAGE_ALIGN) | 63 | #define FX_BUF_SIZE (2 * FX_IMAGE_SIZE + FX_IMAGE_ALIGN) |
62 | 64 | ||
63 | #define DE_VECTOR 0 | 65 | #define DE_VECTOR 0 |
66 | #define NM_VECTOR 7 | ||
64 | #define DF_VECTOR 8 | 67 | #define DF_VECTOR 8 |
65 | #define TS_VECTOR 10 | 68 | #define TS_VECTOR 10 |
66 | #define NP_VECTOR 11 | 69 | #define NP_VECTOR 11 |
@@ -73,6 +76,8 @@ | |||
73 | 76 | ||
74 | #define IOPL_SHIFT 12 | 77 | #define IOPL_SHIFT 12 |
75 | 78 | ||
79 | #define KVM_PIO_PAGE_OFFSET 1 | ||
80 | |||
76 | /* | 81 | /* |
77 | * Address types: | 82 | * Address types: |
78 | * | 83 | * |
@@ -106,6 +111,7 @@ struct kvm_pte_chain { | |||
106 | * bits 4:7 - page table level for this shadow (1-4) | 111 | * bits 4:7 - page table level for this shadow (1-4) |
107 | * bits 8:9 - page table quadrant for 2-level guests | 112 | * bits 8:9 - page table quadrant for 2-level guests |
108 | * bit 16 - "metaphysical" - gfn is not a real page (huge page/real mode) | 113 | * bit 16 - "metaphysical" - gfn is not a real page (huge page/real mode) |
114 | * bits 17:18 - "access" - the user and writable bits of a huge page pde | ||
109 | */ | 115 | */ |
110 | union kvm_mmu_page_role { | 116 | union kvm_mmu_page_role { |
111 | unsigned word; | 117 | unsigned word; |
@@ -115,6 +121,7 @@ union kvm_mmu_page_role { | |||
115 | unsigned quadrant : 2; | 121 | unsigned quadrant : 2; |
116 | unsigned pad_for_nice_hex_output : 6; | 122 | unsigned pad_for_nice_hex_output : 6; |
117 | unsigned metaphysical : 1; | 123 | unsigned metaphysical : 1; |
124 | unsigned hugepage_access : 2; | ||
118 | }; | 125 | }; |
119 | }; | 126 | }; |
120 | 127 | ||
@@ -133,7 +140,6 @@ struct kvm_mmu_page { | |||
133 | unsigned long slot_bitmap; /* One bit set per slot which has memory | 140 | unsigned long slot_bitmap; /* One bit set per slot which has memory |
134 | * in this shadow page. | 141 | * in this shadow page. |
135 | */ | 142 | */ |
136 | int global; /* Set if all ptes in this page are global */ | ||
137 | int multimapped; /* More than one parent_pte? */ | 143 | int multimapped; /* More than one parent_pte? */ |
138 | int root_count; /* Currently serving as active root */ | 144 | int root_count; /* Currently serving as active root */ |
139 | union { | 145 | union { |
@@ -219,6 +225,34 @@ enum { | |||
219 | VCPU_SREG_LDTR, | 225 | VCPU_SREG_LDTR, |
220 | }; | 226 | }; |
221 | 227 | ||
228 | struct kvm_pio_request { | ||
229 | unsigned long count; | ||
230 | int cur_count; | ||
231 | struct page *guest_pages[2]; | ||
232 | unsigned guest_page_offset; | ||
233 | int in; | ||
234 | int size; | ||
235 | int string; | ||
236 | int down; | ||
237 | int rep; | ||
238 | }; | ||
239 | |||
240 | struct kvm_stat { | ||
241 | u32 pf_fixed; | ||
242 | u32 pf_guest; | ||
243 | u32 tlb_flush; | ||
244 | u32 invlpg; | ||
245 | |||
246 | u32 exits; | ||
247 | u32 io_exits; | ||
248 | u32 mmio_exits; | ||
249 | u32 signal_exits; | ||
250 | u32 irq_window_exits; | ||
251 | u32 halt_exits; | ||
252 | u32 request_irq_exits; | ||
253 | u32 irq_exits; | ||
254 | }; | ||
255 | |||
222 | struct kvm_vcpu { | 256 | struct kvm_vcpu { |
223 | struct kvm *kvm; | 257 | struct kvm *kvm; |
224 | union { | 258 | union { |
@@ -228,6 +262,8 @@ struct kvm_vcpu { | |||
228 | struct mutex mutex; | 262 | struct mutex mutex; |
229 | int cpu; | 263 | int cpu; |
230 | int launched; | 264 | int launched; |
265 | u64 host_tsc; | ||
266 | struct kvm_run *run; | ||
231 | int interrupt_window_open; | 267 | int interrupt_window_open; |
232 | unsigned long irq_summary; /* bit vector: 1 per word in irq_pending */ | 268 | unsigned long irq_summary; /* bit vector: 1 per word in irq_pending */ |
233 | #define NR_IRQ_WORDS KVM_IRQ_BITMAP_SIZE(unsigned long) | 269 | #define NR_IRQ_WORDS KVM_IRQ_BITMAP_SIZE(unsigned long) |
@@ -266,6 +302,7 @@ struct kvm_vcpu { | |||
266 | char fx_buf[FX_BUF_SIZE]; | 302 | char fx_buf[FX_BUF_SIZE]; |
267 | char *host_fx_image; | 303 | char *host_fx_image; |
268 | char *guest_fx_image; | 304 | char *guest_fx_image; |
305 | int fpu_active; | ||
269 | 306 | ||
270 | int mmio_needed; | 307 | int mmio_needed; |
271 | int mmio_read_completed; | 308 | int mmio_read_completed; |
@@ -273,6 +310,14 @@ struct kvm_vcpu { | |||
273 | int mmio_size; | 310 | int mmio_size; |
274 | unsigned char mmio_data[8]; | 311 | unsigned char mmio_data[8]; |
275 | gpa_t mmio_phys_addr; | 312 | gpa_t mmio_phys_addr; |
313 | gva_t mmio_fault_cr2; | ||
314 | struct kvm_pio_request pio; | ||
315 | void *pio_data; | ||
316 | |||
317 | int sigset_active; | ||
318 | sigset_t sigset; | ||
319 | |||
320 | struct kvm_stat stat; | ||
276 | 321 | ||
277 | struct { | 322 | struct { |
278 | int active; | 323 | int active; |
@@ -284,6 +329,15 @@ struct kvm_vcpu { | |||
284 | u32 ar; | 329 | u32 ar; |
285 | } tr, es, ds, fs, gs; | 330 | } tr, es, ds, fs, gs; |
286 | } rmode; | 331 | } rmode; |
332 | |||
333 | int cpuid_nent; | ||
334 | struct kvm_cpuid_entry cpuid_entries[KVM_MAX_CPUID_ENTRIES]; | ||
335 | }; | ||
336 | |||
337 | struct kvm_mem_alias { | ||
338 | gfn_t base_gfn; | ||
339 | unsigned long npages; | ||
340 | gfn_t target_gfn; | ||
287 | }; | 341 | }; |
288 | 342 | ||
289 | struct kvm_memory_slot { | 343 | struct kvm_memory_slot { |
@@ -296,6 +350,8 @@ struct kvm_memory_slot { | |||
296 | 350 | ||
297 | struct kvm { | 351 | struct kvm { |
298 | spinlock_t lock; /* protects everything except vcpus */ | 352 | spinlock_t lock; /* protects everything except vcpus */ |
353 | int naliases; | ||
354 | struct kvm_mem_alias aliases[KVM_ALIAS_SLOTS]; | ||
299 | int nmemslots; | 355 | int nmemslots; |
300 | struct kvm_memory_slot memslots[KVM_MEMORY_SLOTS]; | 356 | struct kvm_memory_slot memslots[KVM_MEMORY_SLOTS]; |
301 | /* | 357 | /* |
@@ -312,22 +368,6 @@ struct kvm { | |||
312 | struct file *filp; | 368 | struct file *filp; |
313 | }; | 369 | }; |
314 | 370 | ||
315 | struct kvm_stat { | ||
316 | u32 pf_fixed; | ||
317 | u32 pf_guest; | ||
318 | u32 tlb_flush; | ||
319 | u32 invlpg; | ||
320 | |||
321 | u32 exits; | ||
322 | u32 io_exits; | ||
323 | u32 mmio_exits; | ||
324 | u32 signal_exits; | ||
325 | u32 irq_window_exits; | ||
326 | u32 halt_exits; | ||
327 | u32 request_irq_exits; | ||
328 | u32 irq_exits; | ||
329 | }; | ||
330 | |||
331 | struct descriptor_table { | 371 | struct descriptor_table { |
332 | u16 limit; | 372 | u16 limit; |
333 | unsigned long base; | 373 | unsigned long base; |
@@ -358,10 +398,8 @@ struct kvm_arch_ops { | |||
358 | void (*set_segment)(struct kvm_vcpu *vcpu, | 398 | void (*set_segment)(struct kvm_vcpu *vcpu, |
359 | struct kvm_segment *var, int seg); | 399 | struct kvm_segment *var, int seg); |
360 | void (*get_cs_db_l_bits)(struct kvm_vcpu *vcpu, int *db, int *l); | 400 | void (*get_cs_db_l_bits)(struct kvm_vcpu *vcpu, int *db, int *l); |
361 | void (*decache_cr0_cr4_guest_bits)(struct kvm_vcpu *vcpu); | 401 | void (*decache_cr4_guest_bits)(struct kvm_vcpu *vcpu); |
362 | void (*set_cr0)(struct kvm_vcpu *vcpu, unsigned long cr0); | 402 | void (*set_cr0)(struct kvm_vcpu *vcpu, unsigned long cr0); |
363 | void (*set_cr0_no_modeswitch)(struct kvm_vcpu *vcpu, | ||
364 | unsigned long cr0); | ||
365 | void (*set_cr3)(struct kvm_vcpu *vcpu, unsigned long cr3); | 403 | void (*set_cr3)(struct kvm_vcpu *vcpu, unsigned long cr3); |
366 | void (*set_cr4)(struct kvm_vcpu *vcpu, unsigned long cr4); | 404 | void (*set_cr4)(struct kvm_vcpu *vcpu, unsigned long cr4); |
367 | void (*set_efer)(struct kvm_vcpu *vcpu, u64 efer); | 405 | void (*set_efer)(struct kvm_vcpu *vcpu, u64 efer); |
@@ -391,7 +429,6 @@ struct kvm_arch_ops { | |||
391 | unsigned char *hypercall_addr); | 429 | unsigned char *hypercall_addr); |
392 | }; | 430 | }; |
393 | 431 | ||
394 | extern struct kvm_stat kvm_stat; | ||
395 | extern struct kvm_arch_ops *kvm_arch_ops; | 432 | extern struct kvm_arch_ops *kvm_arch_ops; |
396 | 433 | ||
397 | #define kvm_printf(kvm, fmt ...) printk(KERN_DEBUG fmt) | 434 | #define kvm_printf(kvm, fmt ...) printk(KERN_DEBUG fmt) |
@@ -400,28 +437,29 @@ extern struct kvm_arch_ops *kvm_arch_ops; | |||
400 | int kvm_init_arch(struct kvm_arch_ops *ops, struct module *module); | 437 | int kvm_init_arch(struct kvm_arch_ops *ops, struct module *module); |
401 | void kvm_exit_arch(void); | 438 | void kvm_exit_arch(void); |
402 | 439 | ||
440 | int kvm_mmu_module_init(void); | ||
441 | void kvm_mmu_module_exit(void); | ||
442 | |||
403 | void kvm_mmu_destroy(struct kvm_vcpu *vcpu); | 443 | void kvm_mmu_destroy(struct kvm_vcpu *vcpu); |
404 | int kvm_mmu_create(struct kvm_vcpu *vcpu); | 444 | int kvm_mmu_create(struct kvm_vcpu *vcpu); |
405 | int kvm_mmu_setup(struct kvm_vcpu *vcpu); | 445 | int kvm_mmu_setup(struct kvm_vcpu *vcpu); |
406 | 446 | ||
407 | int kvm_mmu_reset_context(struct kvm_vcpu *vcpu); | 447 | int kvm_mmu_reset_context(struct kvm_vcpu *vcpu); |
408 | void kvm_mmu_slot_remove_write_access(struct kvm_vcpu *vcpu, int slot); | 448 | void kvm_mmu_slot_remove_write_access(struct kvm_vcpu *vcpu, int slot); |
449 | void kvm_mmu_zap_all(struct kvm_vcpu *vcpu); | ||
409 | 450 | ||
410 | hpa_t gpa_to_hpa(struct kvm_vcpu *vcpu, gpa_t gpa); | 451 | hpa_t gpa_to_hpa(struct kvm_vcpu *vcpu, gpa_t gpa); |
411 | #define HPA_MSB ((sizeof(hpa_t) * 8) - 1) | 452 | #define HPA_MSB ((sizeof(hpa_t) * 8) - 1) |
412 | #define HPA_ERR_MASK ((hpa_t)1 << HPA_MSB) | 453 | #define HPA_ERR_MASK ((hpa_t)1 << HPA_MSB) |
413 | static inline int is_error_hpa(hpa_t hpa) { return hpa >> HPA_MSB; } | 454 | static inline int is_error_hpa(hpa_t hpa) { return hpa >> HPA_MSB; } |
414 | hpa_t gva_to_hpa(struct kvm_vcpu *vcpu, gva_t gva); | 455 | hpa_t gva_to_hpa(struct kvm_vcpu *vcpu, gva_t gva); |
456 | struct page *gva_to_page(struct kvm_vcpu *vcpu, gva_t gva); | ||
415 | 457 | ||
416 | void kvm_emulator_want_group7_invlpg(void); | 458 | void kvm_emulator_want_group7_invlpg(void); |
417 | 459 | ||
418 | extern hpa_t bad_page_address; | 460 | extern hpa_t bad_page_address; |
419 | 461 | ||
420 | static inline struct page *gfn_to_page(struct kvm_memory_slot *slot, gfn_t gfn) | 462 | struct page *gfn_to_page(struct kvm *kvm, gfn_t gfn); |
421 | { | ||
422 | return slot->phys_mem[gfn - slot->base_gfn]; | ||
423 | } | ||
424 | |||
425 | struct kvm_memory_slot *gfn_to_memslot(struct kvm *kvm, gfn_t gfn); | 463 | struct kvm_memory_slot *gfn_to_memslot(struct kvm *kvm, gfn_t gfn); |
426 | void mark_page_dirty(struct kvm *kvm, gfn_t gfn); | 464 | void mark_page_dirty(struct kvm *kvm, gfn_t gfn); |
427 | 465 | ||
@@ -444,6 +482,10 @@ void realmode_set_cr(struct kvm_vcpu *vcpu, int cr, unsigned long value, | |||
444 | 482 | ||
445 | struct x86_emulate_ctxt; | 483 | struct x86_emulate_ctxt; |
446 | 484 | ||
485 | int kvm_setup_pio(struct kvm_vcpu *vcpu, struct kvm_run *run, int in, | ||
486 | int size, unsigned long count, int string, int down, | ||
487 | gva_t address, int rep, unsigned port); | ||
488 | void kvm_emulate_cpuid(struct kvm_vcpu *vcpu); | ||
447 | int emulate_invlpg(struct kvm_vcpu *vcpu, gva_t address); | 489 | int emulate_invlpg(struct kvm_vcpu *vcpu, gva_t address); |
448 | int emulate_clts(struct kvm_vcpu *vcpu); | 490 | int emulate_clts(struct kvm_vcpu *vcpu); |
449 | int emulator_get_dr(struct x86_emulate_ctxt* ctxt, int dr, | 491 | int emulator_get_dr(struct x86_emulate_ctxt* ctxt, int dr, |
@@ -493,12 +535,6 @@ static inline int kvm_mmu_page_fault(struct kvm_vcpu *vcpu, gva_t gva, | |||
493 | return vcpu->mmu.page_fault(vcpu, gva, error_code); | 535 | return vcpu->mmu.page_fault(vcpu, gva, error_code); |
494 | } | 536 | } |
495 | 537 | ||
496 | static inline struct page *_gfn_to_page(struct kvm *kvm, gfn_t gfn) | ||
497 | { | ||
498 | struct kvm_memory_slot *slot = gfn_to_memslot(kvm, gfn); | ||
499 | return (slot) ? slot->phys_mem[gfn - slot->base_gfn] : NULL; | ||
500 | } | ||
501 | |||
502 | static inline int is_long_mode(struct kvm_vcpu *vcpu) | 538 | static inline int is_long_mode(struct kvm_vcpu *vcpu) |
503 | { | 539 | { |
504 | #ifdef CONFIG_X86_64 | 540 | #ifdef CONFIG_X86_64 |