]> git.baikalelectronics.ru Git - kernel.git/commit
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)
commitcaf918fac37e3e8c2b5c66001ae4872e97996f92
tree81f29a6e27ee90a6f4c2a446db9233c2b4d253eb
parente663cdd6a6c0aa1f69d8ae4314377b2170a1a457
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: 7dee5ee94062 ("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