@@ -650,6 +650,20 @@ static CPUPhysMemoryClient kvm_cpu_phys_memory_client = {
.log_stop = kvm_log_stop,
};
+static void kvm_handle_interrupt(CPUState *env, int mask)
+{
+ env->interrupt_request |= mask;
+
+ if (!qemu_cpu_self(env)) {
+ qemu_cpu_kick(env);
+ }
+}
+
+static void kvm_handle_interrupt_kernel_irqchip(CPUState *env, int mask)
+{
+ env->interrupt_request |= mask;
+}
+
int kvm_init(void)
{
static const char upgrade_note[] =
@@ -758,6 +772,9 @@ int kvm_init(void)
s->many_ioeventfds = kvm_check_many_ioeventfds();
+ cpu_interrupt_handler = kvm_irqchip_in_kernel() ?
+ kvm_handle_interrupt_kernel_irqchip : kvm_handle_interrupt;
+
return 0;
err: