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
drivers/net
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue