net: phy: at803x: only the AT8030 needs a hardware reset on link change

Commit 13a56b44 ("at803x: Add support for hardware reset") added a
work-around for a hardware bug on the AT8030.  However, the work-around
was being called for all 803x PHYs, even those that don't need it.
Function at803x_link_change_notify() checks to make sure that it only
resets the PHY on the 8030, but it makes more sense to not call that
function at all if it isn't needed.

Signed-off-by: Timur Tabi <timur@codeaurora.org>
Reviewed-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Timur Tabi 2016-04-26 12:44:18 -05:00 committed by David S. Miller
parent 956a7ffe00
commit a05d7dfc51
1 changed files with 14 additions and 18 deletions

View File

@ -359,27 +359,25 @@ static void at803x_link_change_notify(struct phy_device *phydev)
* in the FIFO. In such cases, the FIFO enters an error mode it * in the FIFO. In such cases, the FIFO enters an error mode it
* cannot recover from by software. * cannot recover from by software.
*/ */
if (phydev->drv->phy_id == ATH8030_PHY_ID) { if (phydev->state == PHY_NOLINK) {
if (phydev->state == PHY_NOLINK) { if (priv->gpiod_reset && !priv->phy_reset) {
if (priv->gpiod_reset && !priv->phy_reset) { struct at803x_context context;
struct at803x_context context;
at803x_context_save(phydev, &context); at803x_context_save(phydev, &context);
gpiod_set_value(priv->gpiod_reset, 1); gpiod_set_value(priv->gpiod_reset, 1);
msleep(1); msleep(1);
gpiod_set_value(priv->gpiod_reset, 0); gpiod_set_value(priv->gpiod_reset, 0);
msleep(1); msleep(1);
at803x_context_restore(phydev, &context); at803x_context_restore(phydev, &context);
phydev_dbg(phydev, "%s(): phy was reset\n", phydev_dbg(phydev, "%s(): phy was reset\n",
__func__); __func__);
priv->phy_reset = true; priv->phy_reset = true;
}
} else {
priv->phy_reset = false;
} }
} else {
priv->phy_reset = false;
} }
} }
@ -391,7 +389,6 @@ static struct phy_driver at803x_driver[] = {
.phy_id_mask = 0xffffffef, .phy_id_mask = 0xffffffef,
.probe = at803x_probe, .probe = at803x_probe,
.config_init = at803x_config_init, .config_init = at803x_config_init,
.link_change_notify = at803x_link_change_notify,
.set_wol = at803x_set_wol, .set_wol = at803x_set_wol,
.get_wol = at803x_get_wol, .get_wol = at803x_get_wol,
.suspend = at803x_suspend, .suspend = at803x_suspend,
@ -427,7 +424,6 @@ static struct phy_driver at803x_driver[] = {
.phy_id_mask = 0xffffffef, .phy_id_mask = 0xffffffef,
.probe = at803x_probe, .probe = at803x_probe,
.config_init = at803x_config_init, .config_init = at803x_config_init,
.link_change_notify = at803x_link_change_notify,
.set_wol = at803x_set_wol, .set_wol = at803x_set_wol,
.get_wol = at803x_get_wol, .get_wol = at803x_get_wol,
.suspend = at803x_suspend, .suspend = at803x_suspend,