From: Vladislav Zolotarov Date: Tue, 19 Jul 2011 01:39:41 +0000 (+0000) Subject: bnx2x: stop tx before CNIC_STOP X-Git-Tag: v2.6.39-400.9.0~423^2~19^2~11^2~603 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=a54f40b998a61562c905080b12b191c99fb6b477;p=users%2Fjedix%2Flinux-maple.git bnx2x: stop tx before CNIC_STOP It may take some time to cnic to respond, this prevents tx_timeout when it happens. Signed-off-by: Dmitry Kravkov Signed-off-by: Eilon Greenstein Signed-off-by: David S. Miller (cherry picked from commit 9505ee376739c26cf1d7d4e551d2f63b9d7e5729) Signed-off-by: Joe Jin --- diff --git a/drivers/net/bnx2x/bnx2x_cmn.c b/drivers/net/bnx2x/bnx2x_cmn.c index 48efddf8d24e5..deb17a4fc29fa 100644 --- a/drivers/net/bnx2x/bnx2x_cmn.c +++ b/drivers/net/bnx2x/bnx2x_cmn.c @@ -1987,6 +1987,9 @@ int bnx2x_nic_unload(struct bnx2x *bp, int unload_mode) return -EINVAL; } + /* Stop Tx */ + bnx2x_tx_disable(bp); + #ifdef BCM_CNIC bnx2x_cnic_notify(bp, CNIC_CTL_STOP_CMD); #endif @@ -1995,9 +1998,6 @@ int bnx2x_nic_unload(struct bnx2x *bp, int unload_mode) bp->rx_mode = BNX2X_RX_MODE_NONE; - /* Stop Tx */ - bnx2x_tx_disable(bp); - del_timer_sync(&bp->timer); /* Set ALWAYS_ALIVE bit in shmem */