diff options
author | Neil Horman <nhorman@tuxdriver.com> | 2008-11-12 16:23:44 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-11-12 16:23:44 -0800 |
commit | b2af2c1d3e4ddeea9d02c46d0df0c322cc7b7061 (patch) | |
tree | 56a9dfa1d01846dc8133823f41d8fa78db35eb7e | |
parent | ddd535c713c788f3c23c6548c4ba985a7593113c (diff) | |
download | lwn-b2af2c1d3e4ddeea9d02c46d0df0c322cc7b7061.tar.gz lwn-b2af2c1d3e4ddeea9d02c46d0df0c322cc7b7061.zip |
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>
-rw-r--r-- | drivers/net/bnx2.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/net/bnx2.c b/drivers/net/bnx2.c index 430d430bce29..d07e3f148951 100644 --- a/drivers/net/bnx2.c +++ b/drivers/net/bnx2.c @@ -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 |