ppc: Fix signal delivery in ppc-user and ppc64-user
[qemu/kevin.git] / kvm-stub.c
blob322712764f98d399d16043c09794f28c9f22bfbe
1 /*
2 * QEMU KVM stub
4 * Copyright Red Hat, Inc. 2010
6 * Author: Paolo Bonzini <pbonzini@redhat.com>
8 * This work is licensed under the terms of the GNU GPL, version 2 or later.
9 * See the COPYING file in the top-level directory.
13 #include "qemu/osdep.h"
14 #include "qemu-common.h"
15 #include "cpu.h"
16 #include "sysemu/kvm.h"
18 #ifndef CONFIG_USER_ONLY
19 #include "hw/pci/msi.h"
20 #endif
22 KVMState *kvm_state;
23 bool kvm_kernel_irqchip;
24 bool kvm_async_interrupts_allowed;
25 bool kvm_eventfds_allowed;
26 bool kvm_irqfds_allowed;
27 bool kvm_resamplefds_allowed;
28 bool kvm_msi_via_irqfd_allowed;
29 bool kvm_gsi_routing_allowed;
30 bool kvm_gsi_direct_mapping;
31 bool kvm_allowed;
32 bool kvm_readonly_mem_allowed;
33 bool kvm_ioeventfd_any_length_allowed;
35 int kvm_destroy_vcpu(CPUState *cpu)
37 return -ENOSYS;
40 int kvm_init_vcpu(CPUState *cpu)
42 return -ENOSYS;
45 void kvm_flush_coalesced_mmio_buffer(void)
49 void kvm_cpu_synchronize_state(CPUState *cpu)
53 void kvm_cpu_synchronize_post_reset(CPUState *cpu)
57 void kvm_cpu_synchronize_post_init(CPUState *cpu)
61 int kvm_cpu_exec(CPUState *cpu)
63 abort();
66 int kvm_has_sync_mmu(void)
68 return 0;
71 int kvm_has_many_ioeventfds(void)
73 return 0;
76 int kvm_update_guest_debug(CPUState *cpu, unsigned long reinject_trap)
78 return -ENOSYS;
81 int kvm_insert_breakpoint(CPUState *cpu, target_ulong addr,
82 target_ulong len, int type)
84 return -EINVAL;
87 int kvm_remove_breakpoint(CPUState *cpu, target_ulong addr,
88 target_ulong len, int type)
90 return -EINVAL;
93 void kvm_remove_all_breakpoints(CPUState *cpu)
97 #ifndef _WIN32
98 int kvm_set_signal_mask(CPUState *cpu, const sigset_t *sigset)
100 abort();
102 #endif
104 int kvm_on_sigbus_vcpu(CPUState *cpu, int code, void *addr)
106 return 1;
109 int kvm_on_sigbus(int code, void *addr)
111 return 1;
114 #ifndef CONFIG_USER_ONLY
115 int kvm_irqchip_add_msi_route(KVMState *s, int vector, PCIDevice *dev)
117 return -ENOSYS;
120 void kvm_init_irq_routing(KVMState *s)
124 void kvm_irqchip_release_virq(KVMState *s, int virq)
128 int kvm_irqchip_update_msi_route(KVMState *s, int virq, MSIMessage msg,
129 PCIDevice *dev)
131 return -ENOSYS;
134 void kvm_irqchip_commit_routes(KVMState *s)
138 int kvm_irqchip_add_adapter_route(KVMState *s, AdapterInfo *adapter)
140 return -ENOSYS;
143 int kvm_irqchip_add_irqfd_notifier_gsi(KVMState *s, EventNotifier *n,
144 EventNotifier *rn, int virq)
146 return -ENOSYS;
149 int kvm_irqchip_remove_irqfd_notifier_gsi(KVMState *s, EventNotifier *n,
150 int virq)
152 return -ENOSYS;
155 bool kvm_has_free_slot(MachineState *ms)
157 return false;
159 #endif