summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Makefile2
-rw-r--r--kvm.c2
-rw-r--r--kvm_cache_regs.c2
-rw-r--r--kvm_coalesced_mmio.c2
-rw-r--r--kvm_i8254.c2
-rw-r--r--kvm_i8259.c2
-rw-r--r--kvm_ioapic.c2
-rw-r--r--kvm_irq.c36
-rw-r--r--kvm_irq.h (renamed from irq.h)17
-rw-r--r--kvm_irq_comm.c2
-rw-r--r--kvm_lapic.c2
-rw-r--r--kvm_mmu.c2
-rw-r--r--kvm_vmx.c2
-rw-r--r--kvm_x86.c16
14 files changed, 39 insertions, 52 deletions
diff --git a/Makefile b/Makefile
index 10ec1e5..398a5a2 100644
--- a/Makefile
+++ b/Makefile
@@ -9,7 +9,7 @@ LD=/usr/bin/ld
CTFCONVERT=$(KERNEL_SOURCE)/usr/src/tools/ctf/cvt/i386/ctfconvert
CTFMERGE=$(KERNEL_SOURCE)/usr/src/tools/ctf/cvt/i386/ctfmerge
DESTDIR=
-CFLAGS += -DCONFIG_HAVE_KVM_IRQCHIP -D__KVM_HAVE_IOAPIC -DCONFIG_X86_64 -DCONFIG_X86 -D_KERNEL -D_MACHDEP -Dx86 -DDEBUG -c -g -DCONFIG_SOLARIS -DCONFIG_KVM_MMIO -DCONFIG_KVM_APIC_ARCHITECTURE -DCONFIG_HAVE_KVM_IRQCHIP -O2 -fident -fno-inline -fno-inline-functions -fno-builtin -fno-asm -nodefaultlibs -D__sun -O -D_ASM_INLINES -ffreestanding -Wall -Wno-unknown-pragmas -Wpointer-arith -Wno-unused -gdwarf-2 -std=gnu99 -fno-dwarf2-indirect-strings -Werror -DDIS_MEM -D_KERNEL -ffreestanding -D_SYSCALL32 -D_DDI_STRICT -Di86pc -D_MACHDEP -DOPTERON_ERRATUM_88 -DOPTERON_ERRATUM_91 -DOPTERON_ERRATUM_93 -DOPTERON_ERRATUM_95 -DOPTERON_ERRATUM_99 -DOPTERON_ERRATUM_100 -DOPTERON_ERRATUM_101 -DOPTERON_ERRATUM_108 -DOPTERON_ERRATUM_109 -DOPTERON_ERRATUM_121 -DOPTERON_ERRATUM_122 -DOPTERON_ERRATUM_123 -DOPTERON_ERRATUM_131 -DOPTERON_WORKAROUND_6336786 -DOPTERON_WORKAROUND_6323525 -DOPTERON_ERRATUM_172 -DOPTERON_ERRATUM_298 -I$(KERNEL_SOURCE)/usr/src/uts/common -nostdinc -c -DUTS_RELEASE="5.11" -DUTS_VERSION="joyent.147" -DUTS_PLATFORM="i86pc" -mno-red-zone
+CFLAGS += -DCONFIG_HAVE_KVM_IRQCHIP -D__KVM_HAVE_IOAPIC -DCONFIG_X86_64 -DCONFIG_X86 -D_KERNEL -D_MACHDEP -Dx86 -DDEBUG -c -g -DCONFIG_SOLARIS -DCONFIG_KVM_MMIO -DCONFIG_KVM_APIC_ARCHITECTURE -DCONFIG_HAVE_KVM_IRQCHIP -O2 -fident -fno-inline -fno-inline-functions -fno-builtin -fno-asm -nodefaultlibs -D__sun -O -D_ASM_INLINES -ffreestanding -Wall -Wno-unknown-pragmas -Wpointer-arith -Wno-unused -gdwarf-2 -std=c99 -fms-extensions -fno-dwarf2-indirect-strings -Werror -DDIS_MEM -D_KERNEL -ffreestanding -D_SYSCALL32 -D_DDI_STRICT -Di86pc -D_MACHDEP -DOPTERON_ERRATUM_88 -DOPTERON_ERRATUM_91 -DOPTERON_ERRATUM_93 -DOPTERON_ERRATUM_95 -DOPTERON_ERRATUM_99 -DOPTERON_ERRATUM_100 -DOPTERON_ERRATUM_101 -DOPTERON_ERRATUM_108 -DOPTERON_ERRATUM_109 -DOPTERON_ERRATUM_121 -DOPTERON_ERRATUM_122 -DOPTERON_ERRATUM_123 -DOPTERON_ERRATUM_131 -DOPTERON_WORKAROUND_6336786 -DOPTERON_WORKAROUND_6323525 -DOPTERON_ERRATUM_172 -DOPTERON_ERRATUM_298 -I$(KERNEL_SOURCE)/usr/src/uts/common -nostdinc -c -DUTS_RELEASE="5.11" -DUTS_VERSION="joyent.147" -DUTS_PLATFORM="i86pc" -mno-red-zone
INCLUDEDIR= -I $(KERNEL_SOURCE)/usr/src/uts/intel -I $(KERNEL_SOURCE)/usr/src/uts/i86pc -I $(KERNEL_SOURCE)/usr/src/uts/common
CSTYLE=$(KERNEL_SOURCE)/usr/src/tools/scripts/cstyle
diff --git a/kvm.c b/kvm.c
index d3b17b1..ce4b176 100644
--- a/kvm.c
+++ b/kvm.c
@@ -47,7 +47,7 @@
#include "apicdef.h"
#include "kvm_iodev.h"
#include "kvm.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "tss.h"
#include "kvm_ioapic.h"
#include "kvm_coalesced_mmio.h"
diff --git a/kvm_cache_regs.c b/kvm_cache_regs.c
index 599afd2..cc34963 100644
--- a/kvm_cache_regs.c
+++ b/kvm_cache_regs.c
@@ -15,7 +15,7 @@
#include "apicdef.h"
#include "kvm_ioapic.h"
#include "kvm_lapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "kvm_cache_regs.h"
diff --git a/kvm_coalesced_mmio.c b/kvm_coalesced_mmio.c
index 3635c49..319d980 100644
--- a/kvm_coalesced_mmio.c
+++ b/kvm_coalesced_mmio.c
@@ -20,7 +20,7 @@
#include "kvm.h"
#include "apicdef.h"
#include "kvm_ioapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "kvm_iodev.h"
#include "kvm_coalesced_mmio.h"
diff --git a/kvm_i8254.c b/kvm_i8254.c
index 91ce910..4b0c2bc 100644
--- a/kvm_i8254.c
+++ b/kvm_i8254.c
@@ -42,7 +42,7 @@
#include "kvm_iodev.h"
#include "kvm.h"
#include "kvm_i8254.h"
-#include "irq.h"
+#include "kvm_irq.h"
extern int kvm_vcpu_is_bsp(struct kvm_vcpu *vcpu);
diff --git a/kvm_i8259.c b/kvm_i8259.c
index e6d5e55..04e1fe7 100644
--- a/kvm_i8259.c
+++ b/kvm_i8259.c
@@ -41,7 +41,7 @@
#include "apicdef.h"
#include "kvm_ioapic.h"
#include "kvm_lapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
static void
pic_clear_isr(struct kvm_kpic_state *s, int irq)
diff --git a/kvm_ioapic.c b/kvm_ioapic.c
index 285cf72..4628f56 100644
--- a/kvm_ioapic.c
+++ b/kvm_ioapic.c
@@ -40,7 +40,7 @@
#include "kvm.h"
#include "apicdef.h"
#include "kvm_ioapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
static int ioapic_deliver(struct kvm_ioapic *, int);
diff --git a/kvm_irq.c b/kvm_irq.c
index 3e20edd..8772afc 100644
--- a/kvm_irq.c
+++ b/kvm_irq.c
@@ -21,21 +21,29 @@
* Copyright 2011 Joyent, Inc. All rights reserved.
*/
-/*
- * XXX These header includes are really broken
- */
-#include "msr.h"
-#include "irqflags.h"
#include "kvm_host.h"
-#include "kvm_x86host.h"
-#include "kvm_iodev.h"
-#include "kvm.h"
-#include "irq.h"
-#include "kvm_lapic.h"
-#include "kvm_ioapic.h"
-
-/* XXX This should never exist */
-extern int irqchip_in_kernel(struct kvm *);
+#include "kvm_i8254.h"
+#include "kvm_irq.h"
+
+struct kvm_pic *
+pic_irqchip(struct kvm *kvm)
+{
+ return (kvm->arch.vpic);
+}
+
+int
+irqchip_in_kernel(struct kvm *kvm)
+{
+ int ret;
+
+ ret = (pic_irqchip(kvm) != NULL);
+#ifdef XXX
+ smp_rmb();
+#else
+ XXX_KVM_SYNC_PROBE;
+#endif
+ return (ret);
+}
/*
* check if there are pending timer events
diff --git a/irq.h b/kvm_irq.h
index db01e69..88dc129 100644
--- a/irq.h
+++ b/kvm_irq.h
@@ -1,5 +1,5 @@
/*
- * irq.h: in kernel interrupt controller related definitions
+ * kvm_irq.h: in kernel interrupt controller related definitions
* Copyright (c) 2007, Intel Corporation.
*
* This program is free software; you can redistribute it and/or modify it
@@ -22,16 +22,12 @@
#ifndef __IRQ_H
#define __IRQ_H
-#ifdef XXX
-#include <linux/mm_types.h>
-#include <linux/hrtimer.h>
-#include <linux/kvm_host.h>
-#include <linux/spinlock.h>
+#include <sys/mutex.h>
+#include "kvm_host.h"
#include "kvm_iodev.h"
#include "kvm_ioapic.h"
#include "kvm_lapic.h"
-#endif /*XXX*/
#define PIC_NUM_PINS 16
#define SELECT_PIC(irq) \
@@ -82,11 +78,8 @@ int kvm_pic_read_irq(struct kvm *kvm);
void kvm_pic_update_irq(struct kvm_pic *s);
void kvm_pic_clear_isr_ack(struct kvm *kvm);
-static struct kvm_pic *pic_irqchip(struct kvm *kvm)
-{
- return kvm->arch.vpic;
-}
-
+struct kvm_pic *pic_irqchip(struct kvm *kvm);
+int irqchip_in_kernel(struct kvm *kvm);
void kvm_pic_reset(struct kvm_kpic_state *s);
void kvm_inject_pit_timer_irqs(struct kvm_vcpu *vcpu);
diff --git a/kvm_irq_comm.c b/kvm_irq_comm.c
index f4df4e1..aa2ef74 100644
--- a/kvm_irq_comm.c
+++ b/kvm_irq_comm.c
@@ -35,7 +35,7 @@
#include "apicdef.h"
#include "kvm_lapic.h"
#include "kvm_ioapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
extern long find_first_zero_bit(const unsigned long *, unsigned long);
extern int kvm_pic_set_irq(void *, int, int);
diff --git a/kvm_lapic.c b/kvm_lapic.c
index 86710ed..986c59d 100644
--- a/kvm_lapic.c
+++ b/kvm_lapic.c
@@ -35,7 +35,7 @@
#include "apicdef.h"
#include "kvm_ioapic.h"
#include "kvm_lapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
int __apic_accept_irq(struct kvm_lapic *, int, int, int, int);
/* XXX */
diff --git a/kvm_mmu.c b/kvm_mmu.c
index 87b90e6..da74bef 100644
--- a/kvm_mmu.c
+++ b/kvm_mmu.c
@@ -8,7 +8,7 @@
#include "kvm_x86host.h"
#include "kvm_iodev.h"
#include "kvm.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "kvm_mmu.h"
/*
diff --git a/kvm_vmx.c b/kvm_vmx.c
index 82fac4c..ab3b27c 100644
--- a/kvm_vmx.c
+++ b/kvm_vmx.c
@@ -35,7 +35,7 @@
#include "apicdef.h"
#include "kvm_ioapic.h"
#include "kvm_lapic.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "kvm_mmu.h"
#include "vmx.h"
diff --git a/kvm_x86.c b/kvm_x86.c
index 35a51d7..8715df5 100644
--- a/kvm_x86.c
+++ b/kvm_x86.c
@@ -40,7 +40,7 @@
#include "percpu-defs.h"
#include "kvm_coalesced_mmio.h"
#include "kvm.h"
-#include "irq.h"
+#include "kvm_irq.h"
#include "kvm_i8254.h"
#include "kvm_lapic.h"
#include "kvm_cache_regs.h"
@@ -440,20 +440,6 @@ kvm_dev_ioctl_check_extension(long ext, int *rval_p)
return (r);
}
-int
-irqchip_in_kernel(struct kvm *kvm)
-{
- int ret;
-
- ret = (pic_irqchip(kvm) != NULL);
-#ifdef XXX
- smp_rmb();
-#else
- XXX_KVM_SYNC_PROBE;
-#endif
- return (ret);
-}
-
extern page_t *alloc_page(size_t size, int flag);
extern caddr_t page_address(page_t *page);