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:
parent
ddd535c713
commit
b2af2c1d3e
1 changed files with 6 additions and 3 deletions
|
@ -7204,10 +7204,13 @@ static void
|
|||
poll_bnx2(struct net_device *dev)
|
||||
{
|
||||
struct bnx2 *bp = netdev_priv(dev);
|
||||
int i;
|
||||
|
||||
disable_irq(bp->pdev->irq);
|
||||
bnx2_interrupt(bp->pdev->irq, dev);
|
||||
enable_irq(bp->pdev->irq);
|
||||
for (i = 0; i < bp->irq_nvecs; i++) {
|
||||
disable_irq(bp->irq_tbl[i].vector);
|
||||
bnx2_interrupt(bp->irq_tbl[i].vector, &bp->bnx2_napi[i]);
|
||||
enable_irq(bp->irq_tbl[i].vector);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
Loading…
Reference in a new issue