• Keith Busch's avatar
    x86/apic: Handle zero vector gracefully in clear_vector_irq() · 1bdb8970
    Keith Busch authored
    If x86_vector_alloc_irq() fails x86_vector_free_irqs() is invoked to cleanup
    the already allocated vectors. This subsequently calls clear_vector_irq().
    
    The failed irq has no vector assigned, which triggers the BUG_ON(!vector) in
    clear_vector_irq().
    
    We cannot suppress the call to x86_vector_free_irqs() for the failed
    interrupt, because the other data related to this irq must be cleaned up as
    well. So calling clear_vector_irq() with vector == 0 is legitimate.
    
    Remove the BUG_ON and return if vector is zero,
    
    [ tglx: Massaged changelog ]
    
    Fixes: b5dc8e6c "x86/irq: Use hierarchical irqdomain to manage CPU interrupt vectors"
    Signed-off-by: default avatarKeith Busch <keith.busch@intel.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
    1bdb8970
vector.c 24.7 KB