Commit fba87559 authored by Sathya Perla's avatar Sathya Perla Committed by David S. Miller

be2net: disable TX in be_close()

be_close() followed by be_clear() is called as a part of cleanup in the
EEH/AER flow.  This patch stops TX in be_close() before cleaning/freeing
up the TX queues in be_clear(). This prevents be_xmit() from being called
while TX queues no longer exist.
Signed-off-by: default avatarSathya Perla <sathya.perla@emulex.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3f5dffe6
...@@ -2559,6 +2559,7 @@ static int be_close(struct net_device *netdev) ...@@ -2559,6 +2559,7 @@ static int be_close(struct net_device *netdev)
* all tx skbs are freed. * all tx skbs are freed.
*/ */
be_tx_compl_clean(adapter); be_tx_compl_clean(adapter);
netif_tx_disable(netdev);
be_rx_qs_destroy(adapter); be_rx_qs_destroy(adapter);
...@@ -2667,6 +2668,7 @@ static int be_open(struct net_device *netdev) ...@@ -2667,6 +2668,7 @@ static int be_open(struct net_device *netdev)
if (!status) if (!status)
be_link_status_update(adapter, link_status); be_link_status_update(adapter, link_status);
netif_tx_start_all_queues(netdev);
be_roce_dev_open(adapter); be_roce_dev_open(adapter);
return 0; return 0;
err: err:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment