KVM: Portability: Move kvm{pic,ioapic} accesors to x86 specific code

Signed-off-by: Zhang Xiantao <xiantao.zhang@intel.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
This commit is contained in:
Zhang Xiantao 2007-12-11 20:36:00 +08:00 committed by Avi Kivity
parent 2bacc55c7c
commit 682c59a3f3
3 changed files with 19 additions and 18 deletions

View File

@ -26,6 +26,7 @@
#include <linux/hrtimer.h> #include <linux/hrtimer.h>
#include <asm/kvm.h> #include <asm/kvm.h>
#include "iodev.h" #include "iodev.h"
#include "x86.h"
struct kvm; struct kvm;
struct kvm_vcpu; struct kvm_vcpu;
@ -63,8 +64,6 @@ struct kvm_pic {
struct kvm_pic *kvm_create_pic(struct kvm *kvm); struct kvm_pic *kvm_create_pic(struct kvm *kvm);
void kvm_pic_set_irq(void *opaque, int irq, int level); void kvm_pic_set_irq(void *opaque, int irq, int level);
int kvm_pic_read_irq(struct kvm_pic *s); int kvm_pic_read_irq(struct kvm_pic *s);
int kvm_cpu_get_interrupt(struct kvm_vcpu *v);
int kvm_cpu_has_interrupt(struct kvm_vcpu *v);
void kvm_pic_update_irq(struct kvm_pic *s); void kvm_pic_update_irq(struct kvm_pic *s);
#define IOAPIC_NUM_PINS KVM_IOAPIC_NUM_PINS #define IOAPIC_NUM_PINS KVM_IOAPIC_NUM_PINS
@ -147,6 +146,21 @@ do { \
#define ASSERT(x) do { } while (0) #define ASSERT(x) do { } while (0)
#endif #endif
static inline struct kvm_pic *pic_irqchip(struct kvm *kvm)
{
return kvm->vpic;
}
static inline struct kvm_ioapic *ioapic_irqchip(struct kvm *kvm)
{
return kvm->vioapic;
}
static inline int irqchip_in_kernel(struct kvm *kvm)
{
return pic_irqchip(kvm) != NULL;
}
void kvm_vcpu_kick(struct kvm_vcpu *vcpu); void kvm_vcpu_kick(struct kvm_vcpu *vcpu);
int kvm_apic_has_interrupt(struct kvm_vcpu *vcpu); int kvm_apic_has_interrupt(struct kvm_vcpu *vcpu);
int kvm_apic_accept_pic_intr(struct kvm_vcpu *vcpu); int kvm_apic_accept_pic_intr(struct kvm_vcpu *vcpu);

View File

@ -273,21 +273,6 @@ struct kvm {
struct kvm_vm_stat stat; struct kvm_vm_stat stat;
}; };
static inline struct kvm_pic *pic_irqchip(struct kvm *kvm)
{
return kvm->vpic;
}
static inline struct kvm_ioapic *ioapic_irqchip(struct kvm *kvm)
{
return kvm->vioapic;
}
static inline int irqchip_in_kernel(struct kvm *kvm)
{
return pic_irqchip(kvm) != NULL;
}
/* The guest did something we don't support. */ /* The guest did something we don't support. */
#define pr_unimpl(vcpu, fmt, ...) \ #define pr_unimpl(vcpu, fmt, ...) \
do { \ do { \
@ -417,6 +402,9 @@ void kvm_free_physmem(struct kvm *kvm);
struct kvm *kvm_arch_create_vm(void); struct kvm *kvm_arch_create_vm(void);
void kvm_arch_destroy_vm(struct kvm *kvm); void kvm_arch_destroy_vm(struct kvm *kvm);
int kvm_cpu_get_interrupt(struct kvm_vcpu *v);
int kvm_cpu_has_interrupt(struct kvm_vcpu *v);
static inline void kvm_guest_enter(void) static inline void kvm_guest_enter(void)
{ {
account_system_vtime(current); account_system_vtime(current);

View File

@ -12,7 +12,6 @@
#define KVM_X86_H #define KVM_X86_H
#include "kvm.h" #include "kvm.h"
#include "irq.h"
#include <linux/types.h> #include <linux/types.h>
#include <linux/mm.h> #include <linux/mm.h>