Drop the qemu-kvm version in favor of the equivalent upstream implementation. Signed-off-by: Jan Kiszka <jan.kiszka@xxxxxxxxxxx> --- hw/apic.c | 151 +--------------------------------------------------- hw/pc.c | 5 +-- qemu-kvm-x86.c | 31 ----------- qemu-kvm.h | 25 --------- target-i386/kvm.c | 8 --- 5 files changed, 4 insertions(+), 216 deletions(-) diff --git a/hw/apic.c b/hw/apic.c index b767b87..086c544 100644 --- a/hw/apic.c +++ b/hw/apic.c @@ -22,7 +22,6 @@ #include "host-utils.h" #include "trace.h" #include "pc.h" -#include "kvm.h" #define MAX_APIC_WORDS 8 @@ -133,35 +132,9 @@ void apic_deliver_pic_intr(DeviceState *d, int level) } } -static inline uint32_t kapic_reg(struct kvm_lapic_state *kapic, int reg_id); - -static void kvm_irqchip_deliver_nmi(void *p) -{ - APICCommonState *s = p; - struct kvm_lapic_state klapic; - uint32_t lvt; - - kvm_get_lapic(s->cpu_env, &klapic); - lvt = kapic_reg(&klapic, 0x32 + APIC_LVT_LINT1); - - if (lvt & APIC_LVT_MASKED) { - return; - } - - if (((lvt >> 8) & 7) != APIC_DM_NMI) { - return; - } - - kvm_vcpu_ioctl(s->cpu_env, KVM_NMI); -} - static void apic_external_nmi(APICCommonState *s) { - if (kvm_irqchip_in_kernel()) { - run_on_cpu(s->cpu_env, kvm_irqchip_deliver_nmi, s); - } else { - apic_local_deliver(s, APIC_LVT_LINT1); - } + apic_local_deliver(s, APIC_LVT_LINT1); } #define foreach_apic(apic, deliver_bitmask, code) \ @@ -254,11 +227,8 @@ void apic_deliver_irq(uint8_t dest, uint8_t dest_mode, uint8_t delivery_mode, static void apic_set_base(APICCommonState *s, uint64_t val) { - if (kvm_enabled() && kvm_irqchip_in_kernel()) - s->apicbase = val; - else - s->apicbase = (val & 0xfffff000) | - (s->apicbase & (MSR_IA32_APICBASE_BSP | MSR_IA32_APICBASE_ENABLE)); + s->apicbase = (val & 0xfffff000) | + (s->apicbase & (MSR_IA32_APICBASE_BSP | MSR_IA32_APICBASE_ENABLE)); /* if disabled, cannot be enabled again */ if (!(val & MSR_IA32_APICBASE_ENABLE)) { s->apicbase &= ~MSR_IA32_APICBASE_ENABLE; @@ -270,9 +240,6 @@ static void apic_set_base(APICCommonState *s, uint64_t val) static void apic_set_tpr(APICCommonState *s, uint8_t val) { s->tpr = (val & 0x0f) << 4; - if (kvm_enabled() && kvm_irqchip_in_kernel()) { - return; - } apic_update_irq(s); } @@ -770,120 +737,8 @@ static void apic_mem_writel(void *opaque, target_phys_addr_t addr, uint32_t val) } } -#ifdef KVM_CAP_IRQCHIP - -static inline uint32_t kapic_reg(struct kvm_lapic_state *kapic, int reg_id) -{ - return *((uint32_t *) (kapic->regs + (reg_id << 4))); -} - -static inline void kapic_set_reg(struct kvm_lapic_state *kapic, - int reg_id, uint32_t val) -{ - *((uint32_t *) (kapic->regs + (reg_id << 4))) = val; -} - -static void kvm_kernel_lapic_save_to_user(APICCommonState *s) -{ - struct kvm_lapic_state apic; - struct kvm_lapic_state *kapic = &apic; - int i, v; - - kvm_get_lapic(s->cpu_env, kapic); - - s->id = kapic_reg(kapic, 0x2) >> 24; - s->tpr = kapic_reg(kapic, 0x8); - s->arb_id = kapic_reg(kapic, 0x9); - s->log_dest = kapic_reg(kapic, 0xd) >> 24; - s->dest_mode = kapic_reg(kapic, 0xe) >> 28; - s->spurious_vec = kapic_reg(kapic, 0xf); - for (i = 0; i < 8; i++) { - s->isr[i] = kapic_reg(kapic, 0x10 + i); - s->tmr[i] = kapic_reg(kapic, 0x18 + i); - s->irr[i] = kapic_reg(kapic, 0x20 + i); - } - s->esr = kapic_reg(kapic, 0x28); - s->icr[0] = kapic_reg(kapic, 0x30); - s->icr[1] = kapic_reg(kapic, 0x31); - for (i = 0; i < APIC_LVT_NB; i++) - s->lvt[i] = kapic_reg(kapic, 0x32 + i); - s->initial_count = kapic_reg(kapic, 0x38); - s->divide_conf = kapic_reg(kapic, 0x3e); - - v = (s->divide_conf & 3) | ((s->divide_conf >> 1) & 4); - s->count_shift = (v + 1) & 7; - - s->initial_count_load_time = qemu_get_clock_ns(vm_clock); - apic_next_timer(s, s->initial_count_load_time); -} - -static void kvm_kernel_lapic_load_from_user(APICCommonState *s) -{ - struct kvm_lapic_state apic; - struct kvm_lapic_state *klapic = &apic; - int i; - - memset(klapic, 0, sizeof apic); - kapic_set_reg(klapic, 0x2, s->id << 24); - kapic_set_reg(klapic, 0x8, s->tpr); - kapic_set_reg(klapic, 0xd, s->log_dest << 24); - kapic_set_reg(klapic, 0xe, s->dest_mode << 28 | 0x0fffffff); - kapic_set_reg(klapic, 0xf, s->spurious_vec); - for (i = 0; i < 8; i++) { - kapic_set_reg(klapic, 0x10 + i, s->isr[i]); - kapic_set_reg(klapic, 0x18 + i, s->tmr[i]); - kapic_set_reg(klapic, 0x20 + i, s->irr[i]); - } - kapic_set_reg(klapic, 0x28, s->esr); - kapic_set_reg(klapic, 0x30, s->icr[0]); - kapic_set_reg(klapic, 0x31, s->icr[1]); - for (i = 0; i < APIC_LVT_NB; i++) - kapic_set_reg(klapic, 0x32 + i, s->lvt[i]); - kapic_set_reg(klapic, 0x38, s->initial_count); - kapic_set_reg(klapic, 0x3e, s->divide_conf); - - kvm_set_lapic(s->cpu_env, klapic); -} - -#endif - -void kvm_load_lapic(CPUState *env) -{ -#ifdef KVM_CAP_IRQCHIP - APICCommonState *s = - DO_UPCAST(APICCommonState, busdev.qdev, env->apic_state); - - if (!s) { - return; - } - - if (kvm_enabled() && kvm_irqchip_in_kernel()) { - kvm_kernel_lapic_load_from_user(s); - } -#endif -} - -void kvm_save_lapic(CPUState *env) -{ -#ifdef KVM_CAP_IRQCHIP - APICCommonState *s = - DO_UPCAST(APICCommonState, busdev.qdev, env->apic_state); - - if (!s) { - return; - } - - if (kvm_enabled() && kvm_irqchip_in_kernel()) { - kvm_kernel_lapic_save_to_user(s); - } -#endif -} - static void apic_post_load(APICCommonState *s) { - if (kvm_enabled() && kvm_irqchip_in_kernel()) { - return; - } if (s->timer_expiry != -1) { qemu_mod_timer(s->timer, s->timer_expiry); } else { diff --git a/hw/pc.c b/hw/pc.c index e38a63d..26623f7 100644 --- a/hw/pc.c +++ b/hw/pc.c @@ -890,12 +890,9 @@ static DeviceState *apic_init(void *env, uint8_t apic_id) DeviceState *dev; static int apic_mapped; -#ifdef UNUSED_UPSTREAM_KVM if (kvm_enabled() && kvm_irqchip_in_kernel()) { dev = qdev_create(NULL, "kvm-apic"); - } else -#endif - { + } else { dev = qdev_create(NULL, "apic"); } qdev_prop_set_uint8(dev, "id", apic_id); diff --git a/qemu-kvm-x86.c b/qemu-kvm-x86.c index e5b94b0..2dad5af 100644 --- a/qemu-kvm-x86.c +++ b/qemu-kvm-x86.c @@ -64,37 +64,6 @@ int kvm_enable_vapic(CPUState *env, uint64_t vapic) return kvm_vcpu_ioctl(env, KVM_SET_VAPIC_ADDR, &va); } -int kvm_get_lapic(CPUState *env, struct kvm_lapic_state *s) -{ - int r = 0; - - if (!kvm_irqchip_in_kernel()) { - return r; - } - - r = kvm_vcpu_ioctl(env, KVM_GET_LAPIC, s); - if (r < 0) { - fprintf(stderr, "KVM_GET_LAPIC failed\n"); - } - return r; -} - -int kvm_set_lapic(CPUState *env, struct kvm_lapic_state *s) -{ - int r = 0; - - if (!kvm_irqchip_in_kernel()) { - return 0; - } - - r = kvm_vcpu_ioctl(env, KVM_SET_LAPIC, s); - - if (r < 0) { - fprintf(stderr, "KVM_SET_LAPIC failed\n"); - } - return r; -} - int kvm_get_pit(KVMState *s, struct kvm_pit_state *pit_state) { if (!kvm_irqchip_in_kernel()) { diff --git a/qemu-kvm.h b/qemu-kvm.h index 433e2fe..3c4f023 100644 --- a/qemu-kvm.h +++ b/qemu-kvm.h @@ -34,28 +34,6 @@ #if defined(__i386__) || defined(__x86_64__) /*! - * \brief Get in kernel local APIC for vcpu - * - * Save the local apic state including the timer of a virtual CPU - * - * \param kvm Pointer to the current kvm_context - * \param vcpu Which virtual CPU should be accessed - * \param s Local apic state of the specific virtual CPU - */ -int kvm_get_lapic(CPUState *env, struct kvm_lapic_state *s); - -/*! - * \brief Set in kernel local APIC for vcpu - * - * Restore the local apic state including the timer of a virtual CPU - * - * \param kvm Pointer to the current kvm_context - * \param vcpu Which virtual CPU should be accessed - * \param s Local apic state of the specific virtual CPU - */ -int kvm_set_lapic(CPUState *env, struct kvm_lapic_state *s); - -/*! * \brief Get in kernel PIT of the virtual domain * * Save the PIT state. @@ -199,9 +177,6 @@ struct kvm_pit_state { #endif /* !CONFIG_KVM */ -void kvm_save_lapic(CPUState *env); -void kvm_load_lapic(CPUState *env); - void kvm_hpet_enable_kpit(void); void kvm_hpet_disable_kpit(void); diff --git a/target-i386/kvm.c b/target-i386/kvm.c index 7096752..be45fc0 100644 --- a/target-i386/kvm.c +++ b/target-i386/kvm.c @@ -1364,7 +1364,6 @@ static int kvm_get_mp_state(CPUState *env) static int kvm_get_apic(CPUState *env) { -#ifdef UNUSED_UPSTREAM_KVM DeviceState *apic = env->apic_state; struct kvm_lapic_state kapic; int ret; @@ -1377,15 +1376,11 @@ static int kvm_get_apic(CPUState *env) kvm_get_apic_state(apic, &kapic); } -#else - kvm_save_lapic(env); -#endif return 0; } static int kvm_put_apic(CPUState *env) { -#ifdef UNUSED_UPSTREAM_KVM DeviceState *apic = env->apic_state; struct kvm_lapic_state kapic; @@ -1394,9 +1389,6 @@ static int kvm_put_apic(CPUState *env) return kvm_vcpu_ioctl(env, KVM_SET_LAPIC, &kapic); } -#else - kvm_load_lapic(env); -#endif return 0; } -- 1.7.3.4 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html