Re: [PATCH v3 00/24] pic/ioapic/irqchip cleanups + minor fixes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



2017-04-07 10:50+0200, David Hildenbrand:
> My attempt to further cleanup pic/ioapic checks using irqchip_mode + other
> cleanups in that area.
> 
> The goal is to only check against irqchip_mode and not to rely on
> vpic/vioapic variables anymore to test for existence of pic/ioapic. This
> will avoid any possible races when creating the kernel irqchip fails.

Looks good, applied to kvm/queue to get testing, thanks.

I have noted cosmetical changes for barriers, but they are not big
enough to need a v4 of the series.

> v2 -> v3:
> - Added memory barriers as requested by Paolo to patch 2-4
> 
> David Hildenbrand (24):
>   KVM: x86: race between KVM_SET_GSI_ROUTING and KVM_CREATE_IRQCHIP
>   KVM: x86: new irqchip mode KVM_IRQCHIP_INIT_IN_PROGRESS
>   KVM: x86: check against irqchip_mode in kvm_set_routing_entry()
>   KVM: x86: check against irqchip_mode in pic_in_kernel()
>   KVM: x86: check against irqchip_mode in ioapic_in_kernel()
>   KVM: x86: get rid of pic_irqchip()
>   KVM: x86: get rid of ioapic_irqchip()
>   KVM: x86: use ioapic_in_kernel() to check for ioapic existence
>   KVM: x86: remove duplicate checks for ioapic
>   KVM: x86: convert kvm_(set|get)_ioapic() into void
>   KVM: x86: don't take kvm->irq_lock when creating IRQCHIP
>   KVM: x86: push usage of slots_lock down
>   KVM: x86: KVM_IRQCHIP_PIC_MASTER only has 8 pins
>   KVM: x86: remove all-vcpu request from kvm_ioapic_init()
>   KVM: x86: directly call kvm_make_scan_ioapic_request() in ioapic.c
>   KVM: x86: rename kvm_vcpu_request_scan_ioapic()
>   KVM: x86: drop goto label in kvm_set_routing_entry()
>   KVM: x86: cleanup return handling in setup_routing_entry()
>   KVM: x86: simplify pic_unlock()
>   KVM: x86: make kvm_pic_reset() static
>   KVM: x86: drop picdev_in_range()
>   KVM: x86: set data directly in picdev_read()
>   KVM: x86: simplify pic_ioport_read()
>   KVM: x86: use irqchip_kernel() to check for pic+ioapic
> 
>  arch/x86/include/asm/kvm_host.h |  1 +
>  arch/x86/kvm/i8259.c            | 72 ++++++++++++++++-------------------------
>  arch/x86/kvm/ioapic.c           | 28 ++++++----------
>  arch/x86/kvm/ioapic.h           | 16 ++++-----
>  arch/x86/kvm/irq.c              |  2 +-
>  arch/x86/kvm/irq.h              | 32 +++++++++---------
>  arch/x86/kvm/irq_comm.c         | 45 ++++++++++++--------------
>  arch/x86/kvm/x86.c              | 45 +++++++++++++-------------
>  include/linux/kvm_host.h        |  4 +--
>  virt/kvm/eventfd.c              |  4 +--
>  virt/kvm/irqchip.c              | 11 +++----
>  virt/kvm/kvm_main.c             |  3 ++
>  12 files changed, 117 insertions(+), 146 deletions(-)
> 
> -- 
> 2.9.3
> 



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux