From 3b65ddab7a1d256718f7842b02516d93de78ee59 Mon Sep 17 00:00:00 2001 From: Michael Chan Date: Fri, 15 Jul 2011 06:53:58 +0000 Subject: [PATCH] --- yaml --- r: 256480 b: refs/heads/master c: cd6340199f65cad63262db0fd561bdcfd69df3bd h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/net/bnx2.c | 13 ++++++++++--- 2 files changed, 11 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 667b90c69eeb..114c34fb958b 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 25009a1ae1171eda6bff44b7e44eb0e076713811 +refs/heads/master: cd6340199f65cad63262db0fd561bdcfd69df3bd diff --git a/trunk/drivers/net/bnx2.c b/trunk/drivers/net/bnx2.c index 4816d6a5fe62..3ad9b70ef1b2 100644 --- a/trunk/drivers/net/bnx2.c +++ b/trunk/drivers/net/bnx2.c @@ -6342,6 +6342,7 @@ static void bnx2_reset_task(struct work_struct *work) { struct bnx2 *bp = container_of(work, struct bnx2, reset_task); + int rc; rtnl_lock(); if (!netif_running(bp->dev)) { @@ -6351,7 +6352,14 @@ bnx2_reset_task(struct work_struct *work) bnx2_netif_stop(bp, true); - bnx2_init_nic(bp, 1); + rc = bnx2_init_nic(bp, 1); + if (rc) { + netdev_err(bp->dev, "failed to reset NIC, closing\n"); + bnx2_napi_enable(bp); + dev_close(bp->dev); + rtnl_unlock(); + return; + } atomic_set(&bp->intr_sem, 1); bnx2_netif_start(bp, true); @@ -6573,8 +6581,6 @@ bnx2_close(struct net_device *dev) { struct bnx2 *bp = netdev_priv(dev); - cancel_work_sync(&bp->reset_task); - bnx2_disable_int_sync(bp); bnx2_napi_disable(bp); del_timer_sync(&bp->timer); @@ -8404,6 +8410,7 @@ bnx2_remove_one(struct pci_dev *pdev) unregister_netdev(dev); del_timer_sync(&bp->timer); + cancel_work_sync(&bp->reset_task); if (bp->mips_firmware) release_firmware(bp->mips_firmware);