Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 352029
b: refs/heads/master
c: 3484aac
h: refs/heads/master
i:
  352027: cf2b4e8
v: v3
  • Loading branch information
Amir Vadai authored and David S. Miller committed Jan 31, 2013
1 parent 5bf3392 commit 5b064e0
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 9 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 955154fa33df2b74f0fea8e7c84df6dfd954dab2
refs/heads/master: 3484aac16149636f0ba5b5b0789a2918c682db7e
6 changes: 3 additions & 3 deletions trunk/drivers/net/ethernet/mellanox/mlx4/en_ethtool.c
Original file line number Diff line number Diff line change
Expand Up @@ -496,7 +496,7 @@ static int mlx4_en_set_ringparam(struct net_device *dev,
mutex_lock(&mdev->state_lock);
if (priv->port_up) {
port_up = 1;
mlx4_en_stop_port(dev);
mlx4_en_stop_port(dev, 1);
}

mlx4_en_free_resources(priv);
Expand Down Expand Up @@ -591,7 +591,7 @@ static int mlx4_en_set_rxfh_indir(struct net_device *dev,
mutex_lock(&mdev->state_lock);
if (priv->port_up) {
port_up = 1;
mlx4_en_stop_port(dev);
mlx4_en_stop_port(dev, 1);
}

priv->prof->rss_rings = rss_rings;
Expand Down Expand Up @@ -1096,7 +1096,7 @@ static int mlx4_en_set_channels(struct net_device *dev,
mutex_lock(&mdev->state_lock);
if (priv->port_up) {
port_up = 1;
mlx4_en_stop_port(dev);
mlx4_en_stop_port(dev, 1);
}

mlx4_en_free_resources(priv);
Expand Down
14 changes: 10 additions & 4 deletions trunk/drivers/net/ethernet/mellanox/mlx4/en_netdev.c
Original file line number Diff line number Diff line change
Expand Up @@ -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:
Expand All @@ -1200,7 +1202,7 @@ int mlx4_en_start_port(struct net_device *dev)
}


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;
Expand All @@ -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;

Expand Down Expand Up @@ -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))
Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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",
Expand Down
2 changes: 1 addition & 1 deletion trunk/drivers/net/ethernet/mellanox/mlx4/mlx4_en.h
Original file line number Diff line number Diff line change
Expand Up @@ -539,7 +539,7 @@ int mlx4_en_init_netdev(struct mlx4_en_dev *mdev, int port,
struct mlx4_en_port_profile *prof);

int mlx4_en_start_port(struct net_device *dev);
void mlx4_en_stop_port(struct net_device *dev);
void mlx4_en_stop_port(struct net_device *dev, int detach);

void mlx4_en_free_resources(struct mlx4_en_priv *priv);
int mlx4_en_alloc_resources(struct mlx4_en_priv *priv);
Expand Down

0 comments on commit 5b064e0

Please sign in to comment.