42
42
extern bool kvm_allowed;
43
43
extern bool kvm_kernel_irqchip;
44
44
extern bool kvm_async_interrupts_allowed;
45
extern bool kvm_halt_in_kernel_allowed;
45
46
extern bool kvm_irqfds_allowed;
46
47
extern bool kvm_msi_via_irqfd_allowed;
47
48
extern bool kvm_gsi_routing_allowed;
49
extern bool kvm_readonly_mem_allowed;
49
51
#if defined CONFIG_KVM || !defined NEED_CPU_H
50
52
#define kvm_enabled() (kvm_allowed)
72
74
#define kvm_async_interrupts_enabled() (kvm_async_interrupts_allowed)
79
* Returns: true if halted cpus should still get a KVM_RUN ioctl to run
80
* inside of kernel space. This only works if MP state is implemented.
82
#define kvm_halt_in_kernel() (kvm_halt_in_kernel_allowed)
75
85
* kvm_irqfds_enabled:
77
87
* Returns: true if we can use irqfds to inject interrupts into
98
108
#define kvm_gsi_routing_enabled() (kvm_gsi_routing_allowed)
111
* kvm_readonly_mem_enabled:
113
* Returns: true if KVM readonly memory is enabled (ie the kernel
114
* supports it and we're running in a configuration that permits it).
116
#define kvm_readonly_mem_enabled() (kvm_readonly_mem_allowed)
101
119
#define kvm_enabled() (0)
102
120
#define kvm_irqchip_in_kernel() (false)
103
121
#define kvm_async_interrupts_enabled() (false)
122
#define kvm_halt_in_kernel() (false)
104
123
#define kvm_irqfds_enabled() (false)
105
124
#define kvm_msi_via_irqfd_enabled() (false)
106
125
#define kvm_gsi_routing_allowed() (false)
126
#define kvm_readonly_mem_enabled() (false)
137
157
int kvm_has_intx_set_mask(void);
139
159
int kvm_init_vcpu(CPUState *cpu);
160
int kvm_cpu_exec(CPUState *cpu);
141
162
#ifdef NEED_CPU_H
142
int kvm_cpu_exec(CPUArchState *env);
144
164
#if !defined(CONFIG_USER_ONLY)
145
165
void *kvm_ram_alloc(ram_addr_t size);
149
169
void kvm_setup_guest_memory(void *start, size_t size);
150
170
void kvm_flush_coalesced_mmio_buffer(void);
152
int kvm_insert_breakpoint(CPUArchState *current_env, target_ulong addr,
153
target_ulong len, int type);
154
int kvm_remove_breakpoint(CPUArchState *current_env, target_ulong addr,
155
target_ulong len, int type);
156
void kvm_remove_all_breakpoints(CPUArchState *current_env);
157
int kvm_update_guest_debug(CPUArchState *env, unsigned long reinject_trap);
172
int kvm_insert_breakpoint(CPUState *cpu, target_ulong addr,
173
target_ulong len, int type);
174
int kvm_remove_breakpoint(CPUState *cpu, target_ulong addr,
175
target_ulong len, int type);
176
void kvm_remove_all_breakpoints(CPUState *cpu);
177
int kvm_update_guest_debug(CPUState *cpu, unsigned long reinject_trap);
159
int kvm_set_signal_mask(CPUArchState *env, const sigset_t *sigset);
179
int kvm_set_signal_mask(CPUState *cpu, const sigset_t *sigset);
162
182
int kvm_on_sigbus_vcpu(CPUState *cpu, int code, void *addr);
210
230
int kvm_irqchip_send_msi(KVMState *s, MSIMessage msg);
212
232
void kvm_irqchip_add_irq_route(KVMState *s, int gsi, int irqchip, int pin);
233
void kvm_irqchip_commit_routes(KVMState *s);
214
235
void kvm_put_apic_state(DeviceState *d, struct kvm_lapic_state *kapic);
215
236
void kvm_get_apic_state(DeviceState *d, struct kvm_lapic_state *kapic);
232
253
int kvm_sw_breakpoints_active(CPUState *cpu);
234
int kvm_arch_insert_sw_breakpoint(CPUState *current_cpu,
255
int kvm_arch_insert_sw_breakpoint(CPUState *cpu,
235
256
struct kvm_sw_breakpoint *bp);
236
int kvm_arch_remove_sw_breakpoint(CPUState *current_cpu,
257
int kvm_arch_remove_sw_breakpoint(CPUState *cpu,
237
258
struct kvm_sw_breakpoint *bp);
238
259
int kvm_arch_insert_hw_breakpoint(target_ulong addr,
239
260
target_ulong len, int type);
250
271
uint32_t kvm_arch_get_supported_cpuid(KVMState *env, uint32_t function,
251
272
uint32_t index, int reg);
252
void kvm_cpu_synchronize_state(CPUArchState *env);
273
void kvm_cpu_synchronize_state(CPUState *cpu);
254
275
/* generic hooks - to be moved/refactored once there are more users */
256
static inline void cpu_synchronize_state(CPUArchState *env)
277
static inline void cpu_synchronize_state(CPUState *cpu)
258
279
if (kvm_enabled()) {
259
kvm_cpu_synchronize_state(env);
280
kvm_cpu_synchronize_state(cpu);
292
313
int kvm_irqchip_remove_irqfd_notifier(KVMState *s, EventNotifier *n, int virq);
293
314
void kvm_pc_gsi_handler(void *opaque, int n, int level);
294
315
void kvm_pc_setup_irq_routing(bool pci_enabled);
316
void kvm_init_irq_routing(KVMState *s);