提交 ef83337d 编写于 作者: R Russell King 提交者: David S. Miller

net: fec: clean up duplex mode handling

Many places call fec_restart() with the second parameter being some kind
of previously saved duplex value, but only two places call it with some
other setting.  This is at odds with how the other link settings are
handled, and used to be racy before the rtnl locks were added to
fec_restart()'s various call paths.

Clean this up so all link capabilities are handled in the same way -
saved into the fec_enet_private structure, and then fec_restart() acts
on those settings.
Acked-by: NFugang Duan <B38611@freescale.com>
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 f208ce10
...@@ -824,7 +824,7 @@ static void fec_enet_bd_init(struct net_device *dev) ...@@ -824,7 +824,7 @@ static void fec_enet_bd_init(struct net_device *dev)
* packet processing for this device must be stopped before this call. * packet processing for this device must be stopped before this call.
*/ */
static void static void
fec_restart(struct net_device *ndev, int duplex) fec_restart(struct net_device *ndev)
{ {
struct fec_enet_private *fep = netdev_priv(ndev); struct fec_enet_private *fep = netdev_priv(ndev);
const struct platform_device_id *id_entry = const struct platform_device_id *id_entry =
...@@ -875,7 +875,7 @@ fec_restart(struct net_device *ndev, int duplex) ...@@ -875,7 +875,7 @@ fec_restart(struct net_device *ndev, int duplex)
} }
/* Enable MII mode */ /* Enable MII mode */
if (duplex) { if (fep->full_duplex == DUPLEX_FULL) {
/* FD enable */ /* FD enable */
writel(0x04, fep->hwp + FEC_X_CNTRL); writel(0x04, fep->hwp + FEC_X_CNTRL);
} else { } else {
...@@ -884,8 +884,6 @@ fec_restart(struct net_device *ndev, int duplex) ...@@ -884,8 +884,6 @@ fec_restart(struct net_device *ndev, int duplex)
writel(0x0, fep->hwp + FEC_X_CNTRL); writel(0x0, fep->hwp + FEC_X_CNTRL);
} }
fep->full_duplex = duplex;
/* Set MII speed */ /* Set MII speed */
writel(fep->phy_speed, fep->hwp + FEC_MII_SPEED); writel(fep->phy_speed, fep->hwp + FEC_MII_SPEED);
...@@ -1060,7 +1058,7 @@ static void fec_enet_work(struct work_struct *work) ...@@ -1060,7 +1058,7 @@ static void fec_enet_work(struct work_struct *work)
if (netif_device_present(ndev) || netif_running(ndev)) { if (netif_device_present(ndev) || netif_running(ndev)) {
napi_disable(&fep->napi); napi_disable(&fep->napi);
netif_tx_lock_bh(ndev); netif_tx_lock_bh(ndev);
fec_restart(ndev, fep->full_duplex); fec_restart(ndev);
netif_wake_queue(ndev); netif_wake_queue(ndev);
netif_tx_unlock_bh(ndev); netif_tx_unlock_bh(ndev);
napi_enable(&fep->napi); napi_enable(&fep->napi);
...@@ -1511,8 +1509,10 @@ static void fec_enet_adjust_link(struct net_device *ndev) ...@@ -1511,8 +1509,10 @@ static void fec_enet_adjust_link(struct net_device *ndev)
status_change = 1; status_change = 1;
} }
if (fep->full_duplex != phy_dev->duplex) if (fep->full_duplex != phy_dev->duplex) {
fep->full_duplex = phy_dev->duplex;
status_change = 1; status_change = 1;
}
if (phy_dev->speed != fep->speed) { if (phy_dev->speed != fep->speed) {
fep->speed = phy_dev->speed; fep->speed = phy_dev->speed;
...@@ -1523,7 +1523,7 @@ static void fec_enet_adjust_link(struct net_device *ndev) ...@@ -1523,7 +1523,7 @@ static void fec_enet_adjust_link(struct net_device *ndev)
if (status_change) { if (status_change) {
napi_disable(&fep->napi); napi_disable(&fep->napi);
netif_tx_lock_bh(ndev); netif_tx_lock_bh(ndev);
fec_restart(ndev, phy_dev->duplex); fec_restart(ndev);
netif_wake_queue(ndev); netif_wake_queue(ndev);
netif_tx_unlock_bh(ndev); netif_tx_unlock_bh(ndev);
napi_enable(&fep->napi); napi_enable(&fep->napi);
...@@ -1919,7 +1919,7 @@ static int fec_enet_set_pauseparam(struct net_device *ndev, ...@@ -1919,7 +1919,7 @@ static int fec_enet_set_pauseparam(struct net_device *ndev,
if (netif_running(ndev)) { if (netif_running(ndev)) {
napi_disable(&fep->napi); napi_disable(&fep->napi);
netif_tx_lock_bh(ndev); netif_tx_lock_bh(ndev);
fec_restart(ndev, fep->full_duplex); fec_restart(ndev);
netif_wake_queue(ndev); netif_wake_queue(ndev);
netif_tx_unlock_bh(ndev); netif_tx_unlock_bh(ndev);
napi_enable(&fep->napi); napi_enable(&fep->napi);
...@@ -2201,7 +2201,7 @@ fec_enet_open(struct net_device *ndev) ...@@ -2201,7 +2201,7 @@ fec_enet_open(struct net_device *ndev)
return ret; return ret;
} }
fec_restart(ndev, fep->full_duplex); fec_restart(ndev);
napi_enable(&fep->napi); napi_enable(&fep->napi);
phy_start(fep->phy_dev); phy_start(fep->phy_dev);
netif_start_queue(ndev); netif_start_queue(ndev);
...@@ -2377,7 +2377,7 @@ static int fec_set_features(struct net_device *netdev, ...@@ -2377,7 +2377,7 @@ static int fec_set_features(struct net_device *netdev,
/* Resume the device after updates */ /* Resume the device after updates */
if (netif_running(netdev) && changed & FEATURES_NEED_QUIESCE) { if (netif_running(netdev) && changed & FEATURES_NEED_QUIESCE) {
fec_restart(netdev, fep->phy_dev->duplex); fec_restart(netdev);
netif_wake_queue(netdev); netif_wake_queue(netdev);
netif_tx_unlock_bh(netdev); netif_tx_unlock_bh(netdev);
napi_enable(&fep->napi); napi_enable(&fep->napi);
...@@ -2481,7 +2481,7 @@ static int fec_enet_init(struct net_device *ndev) ...@@ -2481,7 +2481,7 @@ static int fec_enet_init(struct net_device *ndev)
ndev->hw_features = ndev->features; ndev->hw_features = ndev->features;
fec_restart(ndev, 0); fec_restart(ndev);
return 0; return 0;
} }
...@@ -2750,7 +2750,7 @@ fec_resume(struct device *dev) ...@@ -2750,7 +2750,7 @@ fec_resume(struct device *dev)
rtnl_lock(); rtnl_lock();
if (netif_running(ndev)) { if (netif_running(ndev)) {
fec_restart(ndev, fep->full_duplex); fec_restart(ndev);
netif_tx_lock_bh(ndev); netif_tx_lock_bh(ndev);
netif_device_attach(ndev); netif_device_attach(ndev);
netif_tx_unlock_bh(ndev); netif_tx_unlock_bh(ndev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册