net: phy: smsc: reintroduced unconditional soft reset
We detected some problems using the smsc lan8720a in combination with i.MX28 and tracked this down to commit2100968666
("net: phy: smsc: move smsc_phy_config_init reset part in a soft_reset function") With2100968666
the generic soft reset is replaced by a specific function which handles power down state correctly. But additionally the soft reset itself got conditional and is therefore also only performed if the phy is in power down state. This patch keeps the conditional wake up from power down, but re-introduces the unconditional soft reset using the generic soft reset function. It was tested on linux-4.1.25 and linux-4.7.0-rc2. Signed-off-by: Manfred Schlaegl <manfred.schlaegl@ginzinger.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Родитель
698ea54dde
Коммит
fc0f7e3317
|
@ -75,22 +75,13 @@ static int smsc_phy_reset(struct phy_device *phydev)
|
|||
* in all capable mode before using it.
|
||||
*/
|
||||
if ((rc & MII_LAN83C185_MODE_MASK) == MII_LAN83C185_MODE_POWERDOWN) {
|
||||
int timeout = 50000;
|
||||
|
||||
/* set "all capable" mode and reset the phy */
|
||||
/* set "all capable" mode */
|
||||
rc |= MII_LAN83C185_MODE_ALL;
|
||||
phy_write(phydev, MII_LAN83C185_SPECIAL_MODES, rc);
|
||||
phy_write(phydev, MII_BMCR, BMCR_RESET);
|
||||
|
||||
/* wait end of reset (max 500 ms) */
|
||||
do {
|
||||
udelay(10);
|
||||
if (timeout-- == 0)
|
||||
return -1;
|
||||
rc = phy_read(phydev, MII_BMCR);
|
||||
} while (rc & BMCR_RESET);
|
||||
}
|
||||
return 0;
|
||||
|
||||
/* reset the phy */
|
||||
return genphy_soft_reset(phydev);
|
||||
}
|
||||
|
||||
static int lan911x_config_init(struct phy_device *phydev)
|
||||
|
|
Загрузка…
Ссылка в новой задаче