sfc: fix calling of free_irq with already free vector
authorNikolay Aleksandrov <nikolay@redhat.com>
Fri, 9 May 2014 09:11:39 +0000 (11:11 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 12 May 2014 18:56:45 +0000 (14:56 -0400)
commit1c3639005f48492e5f2d965779efd814e80f8b15
tree81f29a6e27ee90a6f4c2a446db9233c2b4d253eb
parentbbeb0eadcf9fe74fb2b9b1a6fea82cd538b1e556
sfc: fix calling of free_irq with already free vector

If the sfc driver is in legacy interrupt mode (either explicitly by
using interrupt_mode module param or by falling back to it) it will
hit a warning at kernel/irq/manage.c because it will try to free an irq
which wasn't allocated by it in the first place because the MSI(X) irqs are
zero and it'll try to free them unconditionally. So fix it by checking if
we're in legacy mode and freeing the appropriate irqs.

CC: Zenghui Shi <zshi@redhat.com>
CC: Ben Hutchings <ben@decadent.org.uk>
CC: <linux-net-drivers@solarflare.com>
CC: Shradha Shah <sshah@solarflare.com>
CC: David S. Miller <davem@davemloft.net>
Fixes: 1899c111a535 ("sfc: Fix IRQ cleanup in case of a probe failure")
Reported-by: Zenghui Shi <zshi@redhat.com>
Signed-off-by: Nikolay Aleksandrov <nikolay@redhat.com>
Acked-by: Shradha Shah <sshah@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/sfc/nic.c