|
@@ -1178,6 +1178,8 @@ int mlx4_en_start_port(struct net_device *dev)
|
|
|
|
|
|
priv->port_up = true;
|
|
|
netif_tx_start_all_queues(dev);
|
|
|
+ netif_device_attach(dev);
|
|
|
+
|
|
|
return 0;
|
|
|
|
|
|
tx_err:
|
|
@@ -1200,7 +1202,7 @@ cq_err:
|
|
|
}
|
|
|
|
|
|
|
|
|
-void mlx4_en_stop_port(struct net_device *dev)
|
|
|
+void mlx4_en_stop_port(struct net_device *dev, int detach)
|
|
|
{
|
|
|
struct mlx4_en_priv *priv = netdev_priv(dev);
|
|
|
struct mlx4_en_dev *mdev = priv->mdev;
|
|
@@ -1216,9 +1218,13 @@ void mlx4_en_stop_port(struct net_device *dev)
|
|
|
|
|
|
/* Synchronize with tx routine */
|
|
|
netif_tx_lock_bh(dev);
|
|
|
+ if (detach)
|
|
|
+ netif_device_detach(dev);
|
|
|
netif_tx_stop_all_queues(dev);
|
|
|
netif_tx_unlock_bh(dev);
|
|
|
|
|
|
+ netif_tx_disable(dev);
|
|
|
+
|
|
|
/* Set port as not active */
|
|
|
priv->port_up = false;
|
|
|
|
|
@@ -1323,7 +1329,7 @@ static void mlx4_en_restart(struct work_struct *work)
|
|
|
|
|
|
mutex_lock(&mdev->state_lock);
|
|
|
if (priv->port_up) {
|
|
|
- mlx4_en_stop_port(dev);
|
|
|
+ mlx4_en_stop_port(dev, 1);
|
|
|
for (i = 0; i < priv->tx_ring_num; i++)
|
|
|
netdev_tx_reset_queue(priv->tx_ring[i].tx_queue);
|
|
|
if (mlx4_en_start_port(dev))
|
|
@@ -1395,7 +1401,7 @@ static int mlx4_en_close(struct net_device *dev)
|
|
|
|
|
|
mutex_lock(&mdev->state_lock);
|
|
|
|
|
|
- mlx4_en_stop_port(dev);
|
|
|
+ mlx4_en_stop_port(dev, 0);
|
|
|
netif_carrier_off(dev);
|
|
|
|
|
|
mutex_unlock(&mdev->state_lock);
|
|
@@ -1533,7 +1539,7 @@ static int mlx4_en_change_mtu(struct net_device *dev, int new_mtu)
|
|
|
* the port */
|
|
|
en_dbg(DRV, priv, "Change MTU called with card down!?\n");
|
|
|
} else {
|
|
|
- mlx4_en_stop_port(dev);
|
|
|
+ mlx4_en_stop_port(dev, 1);
|
|
|
err = mlx4_en_start_port(dev);
|
|
|
if (err) {
|
|
|
en_err(priv, "Failed restarting port:%d\n",
|