aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGlauber Costa <glommer@redhat.com>2009-07-21 12:26:58 -0300
committerAnthony Liguori <aliguori@us.ibm.com>2009-07-22 10:58:49 -0500
commit6f725c139ae975646c44ace77bf796318a5783da (patch)
tree8cf60b827ab2d649b4dd7954bce465e51874793e
parent609f2fabab3ca9cedd69c499dc94bb2019d4f665 (diff)
downloadqemu-6f725c139ae975646c44ace77bf796318a5783da.zip
qemu-6f725c139ae975646c44ace77bf796318a5783da.tar.gz
qemu-6f725c139ae975646c44ace77bf796318a5783da.tar.bz2
provide tests for pit in kernel and irqchip in kernel
KVM can have an in-kernel pit or irqchip. While we don't implement it yet, having a way for test for it (that always returns zero) will allow us to reuse code in qemu-kvm that tests for it. Signed-off-by: Glauber Costa <glommer@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
-rw-r--r--kvm-all.c13
-rw-r--r--kvm.h3
2 files changed, 16 insertions, 0 deletions
diff --git a/kvm-all.c b/kvm-all.c
index 7b34c8d..824bb4c 100644
--- a/kvm-all.c
+++ b/kvm-all.c
@@ -63,6 +63,8 @@ struct KVMState
#ifdef KVM_CAP_SET_GUEST_DEBUG
struct kvm_sw_breakpoint_head kvm_sw_breakpoints;
#endif
+ int irqchip_in_kernel;
+ int pit_in_kernel;
};
static KVMState *kvm_state;
@@ -162,6 +164,17 @@ static void on_vcpu(CPUState *env, void (*func)(void *data), void *data)
abort();
}
+int kvm_irqchip_in_kernel(void)
+{
+ return kvm_state->irqchip_in_kernel;
+}
+
+int kvm_pit_in_kernel(void)
+{
+ return kvm_state->pit_in_kernel;
+}
+
+
int kvm_init_vcpu(CPUState *env)
{
KVMState *s = kvm_state;
diff --git a/kvm.h b/kvm.h
index 96b4d72..0d4dd53 100644
--- a/kvm.h
+++ b/kvm.h
@@ -60,6 +60,9 @@ int kvm_remove_breakpoint(CPUState *current_env, target_ulong addr,
void kvm_remove_all_breakpoints(CPUState *current_env);
int kvm_update_guest_debug(CPUState *env, unsigned long reinject_trap);
+int kvm_pit_in_kernel(void);
+int kvm_irqchip_in_kernel(void);
+
/* internal API */
struct KVMState;