Increment virtio-net savevm version to avoid conflict with upstream QEMU.
[qemu-kvm/fedora.git] / qemu-kvm.h
blobca59af8d9e238afe4f597ce17c23d869d02deeaf
1 /*
2 * qemu/kvm integration
4 * Copyright (C) 2006-2008 Qumranet Technologies
6 * Licensed under the terms of the GNU GPL version 2 or higher.
7 */
8 #ifndef THE_ORIGINAL_AND_TRUE_QEMU_KVM_H
9 #define THE_ORIGINAL_AND_TRUE_QEMU_KVM_H
11 #include "cpu.h"
13 #include <signal.h>
15 int kvm_main_loop(void);
16 int kvm_qemu_init(void);
17 int kvm_qemu_create_context(void);
18 int kvm_init_ap(void);
19 void kvm_qemu_destroy(void);
20 void kvm_load_registers(CPUState *env);
21 void kvm_save_registers(CPUState *env);
22 void kvm_load_mpstate(CPUState *env);
23 void kvm_save_mpstate(CPUState *env);
24 int kvm_cpu_exec(CPUState *env);
25 int kvm_insert_breakpoint(CPUState *current_env, target_ulong addr,
26 target_ulong len, int type);
27 int kvm_remove_breakpoint(CPUState *current_env, target_ulong addr,
28 target_ulong len, int type);
29 void kvm_remove_all_breakpoints(CPUState *current_env);
30 int kvm_update_guest_debug(CPUState *env, unsigned long reinject_trap);
31 int kvm_qemu_init_env(CPUState *env);
32 int kvm_qemu_check_extension(int ext);
33 void kvm_apic_init(CPUState *env);
34 int kvm_set_irq(int irq, int level, int *status);
36 int kvm_physical_memory_set_dirty_tracking(int enable);
37 int kvm_update_dirty_pages_log(void);
38 int kvm_get_phys_ram_page_bitmap(unsigned char *bitmap);
40 void qemu_kvm_call_with_env(void (*func)(void *), void *data, CPUState *env);
41 void qemu_kvm_cpuid_on_env(CPUState *env);
42 void kvm_inject_interrupt(CPUState *env, int mask);
43 void kvm_update_after_sipi(CPUState *env);
44 void kvm_update_interrupt_request(CPUState *env);
45 void kvm_cpu_register_physical_memory(target_phys_addr_t start_addr,
46 unsigned long size,
47 unsigned long phys_offset);
48 void kvm_cpu_unregister_physical_memory(target_phys_addr_t start_addr,
49 target_phys_addr_t size,
50 unsigned long phys_offset);
51 void *kvm_cpu_create_phys_mem(target_phys_addr_t start_addr,
52 unsigned long size, int log, int writable);
54 void kvm_cpu_destroy_phys_mem(target_phys_addr_t start_addr,
55 unsigned long size);
56 void kvm_qemu_log_memory(target_phys_addr_t start, target_phys_addr_t size,
57 int log);
58 int kvm_setup_guest_memory(void *area, unsigned long size);
59 int kvm_qemu_create_memory_alias(uint64_t phys_start,
60 uint64_t len,
61 uint64_t target_phys);
62 int kvm_qemu_destroy_memory_alias(uint64_t phys_start);
64 int kvm_arch_qemu_create_context(void);
66 void kvm_arch_save_regs(CPUState *env);
67 void kvm_arch_load_regs(CPUState *env);
68 int kvm_arch_qemu_init_env(CPUState *cenv);
69 int kvm_arch_halt(void *opaque, int vcpu);
70 void kvm_arch_pre_kvm_run(void *opaque, CPUState *env);
71 void kvm_arch_post_kvm_run(void *opaque, CPUState *env);
72 int kvm_arch_has_work(CPUState *env);
73 int kvm_arch_try_push_interrupts(void *opaque);
74 void kvm_arch_push_nmi(void *opaque);
75 void kvm_arch_update_regs_for_sipi(CPUState *env);
76 void kvm_arch_cpu_reset(CPUState *env);
78 struct kvm_guest_debug;
79 struct kvm_debug_exit_arch;
81 struct kvm_sw_breakpoint {
82 target_ulong pc;
83 target_ulong saved_insn;
84 int use_count;
85 TAILQ_ENTRY(kvm_sw_breakpoint) entry;
87 TAILQ_HEAD(kvm_sw_breakpoint_head, kvm_sw_breakpoint);
89 extern struct kvm_sw_breakpoint_head kvm_sw_breakpoints;
91 int kvm_arch_debug(struct kvm_debug_exit_arch *arch_info);
92 struct kvm_sw_breakpoint *kvm_find_sw_breakpoint(target_ulong pc);
93 int kvm_arch_insert_sw_breakpoint(CPUState *current_env,
94 struct kvm_sw_breakpoint *bp);
95 int kvm_arch_remove_sw_breakpoint(CPUState *current_env,
96 struct kvm_sw_breakpoint *bp);
97 int kvm_arch_insert_hw_breakpoint(target_ulong addr,
98 target_ulong len, int type);
99 int kvm_arch_remove_hw_breakpoint(target_ulong addr,
100 target_ulong len, int type);
101 void kvm_arch_remove_all_hw_breakpoints(void);
102 void kvm_arch_update_guest_debug(CPUState *env, struct kvm_guest_debug *dbg);
104 void qemu_kvm_aio_wait_start(void);
105 void qemu_kvm_aio_wait(void);
106 void qemu_kvm_aio_wait_end(void);
108 void qemu_kvm_notify_work(void);
110 void kvm_tpr_opt_setup(void);
111 void kvm_tpr_access_report(CPUState *env, uint64_t rip, int is_write);
112 int handle_tpr_access(void *opaque, int vcpu,
113 uint64_t rip, int is_write);
114 void kvm_tpr_vcpu_start(CPUState *env);
116 int qemu_kvm_get_dirty_pages(unsigned long phys_addr, void *buf);
117 int qemu_kvm_register_coalesced_mmio(target_phys_addr_t addr,
118 unsigned int size);
119 int qemu_kvm_unregister_coalesced_mmio(target_phys_addr_t addr,
120 unsigned int size);
122 void qemu_kvm_pause_all_threads(void);
123 void qemu_kvm_resume_all_threads(void);
125 int kvm_coalesce_mmio_region(target_phys_addr_t start, ram_addr_t size);
126 int kvm_uncoalesce_mmio_region(target_phys_addr_t start, ram_addr_t size);
128 #ifdef USE_KVM_DEVICE_ASSIGNMENT
129 struct ioperm_data;
131 void kvm_ioperm(CPUState *env, void *data);
132 void kvm_add_ioperm_data(struct ioperm_data *data);
133 void kvm_remove_ioperm_data(unsigned long start_port, unsigned long num);
134 void kvm_arch_do_ioperm(void *_data);
135 #endif
137 #ifdef TARGET_PPC
138 int handle_powerpc_dcr_read(int vcpu, uint32_t dcrn, uint32_t *data);
139 int handle_powerpc_dcr_write(int vcpu,uint32_t dcrn, uint32_t data);
140 #endif
142 #define ALIGN(x, y) (((x)+(y)-1) & ~((y)-1))
143 #define BITMAP_SIZE(m) (ALIGN(((m)>>TARGET_PAGE_BITS), HOST_LONG_BITS) / 8)
145 #ifdef USE_KVM
146 #include "libkvm.h"
147 #include "sys-queue.h"
149 extern int kvm_allowed;
150 extern int kvm_irqchip;
151 extern int kvm_pit;
152 extern int kvm_pit_reinject;
153 extern int kvm_nested;
154 extern kvm_context_t kvm_context;
156 struct ioperm_data {
157 unsigned long start_port;
158 unsigned long num;
159 int turn_on;
160 LIST_ENTRY(ioperm_data) entries;
163 int qemu_kvm_has_sync_mmu(void);
164 void qemu_kvm_cpu_stop(CPUState *env);
166 #define kvm_enabled() (kvm_allowed)
167 #define qemu_kvm_irqchip_in_kernel() kvm_irqchip_in_kernel(kvm_context)
168 #define qemu_kvm_pit_in_kernel() kvm_pit_in_kernel(kvm_context)
169 #define kvm_has_sync_mmu() qemu_kvm_has_sync_mmu()
170 void kvm_init_vcpu(CPUState *env);
171 void kvm_load_tsc(CPUState *env);
172 #else
173 #define kvm_enabled() (0)
174 #define kvm_nested 0
175 #define qemu_kvm_irqchip_in_kernel() (0)
176 #define qemu_kvm_pit_in_kernel() (0)
177 #define kvm_has_sync_mmu() (0)
178 #define kvm_load_registers(env) do {} while(0)
179 #define kvm_save_registers(env) do {} while(0)
180 #define qemu_kvm_cpu_stop(env) do {} while(0)
181 static inline void kvm_init_vcpu(CPUState *env) { }
182 static inline void kvm_load_tsc(CPUState *env) {}
183 #endif
185 void kvm_mutex_unlock(void);
186 void kvm_mutex_lock(void);
188 static inline void kvm_sleep_begin(void)
190 if (kvm_enabled())
191 kvm_mutex_unlock();
194 static inline void kvm_sleep_end(void)
196 if (kvm_enabled())
197 kvm_mutex_lock();
200 static inline void kvm_set_phys_mem(target_phys_addr_t start_addr,
201 ram_addr_t size,
202 ram_addr_t phys_offset)
204 kvm_cpu_register_physical_memory(start_addr, size, phys_offset);
208 void kvm_physical_sync_dirty_bitmap(target_phys_addr_t start_addr, target_phys_addr_t end_addr);
210 int kvm_log_start(target_phys_addr_t phys_addr, target_phys_addr_t len);
211 int kvm_log_stop(target_phys_addr_t phys_addr, target_phys_addr_t len);
214 static inline int kvm_sync_vcpus(void) { return 0; }
216 static inline void kvm_arch_get_registers(CPUState *env)
218 kvm_save_registers(env);
221 static inline void kvm_arch_put_registers(CPUState *env)
223 kvm_load_registers(env);
226 static inline void cpu_synchronize_state(CPUState *env, int modified)
228 if (kvm_enabled()) {
229 if (modified)
230 kvm_arch_put_registers(env);
231 else
232 kvm_arch_get_registers(env);
236 #endif