bnx2: fix poll_controller to pass proper structures and check all rx queues

Fix bnx2 so that netpoll works properly.  Specifically:

1) Fix parameters to bnx2_interrupt to be a struct bnx2_napi rather than a
struct net_device

2) Fix poll_controller method to check every queue in the rx case so frames
aren't missed

Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Neil Horman 2008-11-12 16:23:44 -08:00 committed by David S. Miller
parent ddd535c713
commit b2af2c1d3e
1 changed files with 6 additions and 3 deletions
drivers/net

View File

@ -7204,10 +7204,13 @@ static void
poll_bnx2(struct net_device *dev) poll_bnx2(struct net_device *dev)
{ {
struct bnx2 *bp = netdev_priv(dev); struct bnx2 *bp = netdev_priv(dev);
int i;
disable_irq(bp->pdev->irq); for (i = 0; i < bp->irq_nvecs; i++) {
bnx2_interrupt(bp->pdev->irq, dev); disable_irq(bp->irq_tbl[i].vector);
enable_irq(bp->pdev->irq); bnx2_interrupt(bp->irq_tbl[i].vector, &bp->bnx2_napi[i]);
enable_irq(bp->irq_tbl[i].vector);
}
} }
#endif #endif