Commit 2441ba48 authored by Heiner Kallweit's avatar Heiner Kallweit Committed by David S. Miller

net: phy: swphy: emulate register MII_ESTATUS

When the genphy driver binds to a swphy it will call
genphy_read_abilites that will try to read MII_ESTATUS if BMSR_ESTATEN
is set in MII_BMSR. So far this would read the default value 0xffff
and 1000FD and 1000HD are reported as supported just by chance.
Better add explicit support for emulating MII_ESTATUS.
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Reviewed-by: default avatarAndrew Lunn <andrew@lunn.ch>
Reviewed-by: default avatarFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 916e571e
...@@ -22,6 +22,7 @@ struct swmii_regs { ...@@ -22,6 +22,7 @@ struct swmii_regs {
u16 bmsr; u16 bmsr;
u16 lpa; u16 lpa;
u16 lpagb; u16 lpagb;
u16 estat;
}; };
enum { enum {
...@@ -48,6 +49,7 @@ static const struct swmii_regs speed[] = { ...@@ -48,6 +49,7 @@ static const struct swmii_regs speed[] = {
[SWMII_SPEED_1000] = { [SWMII_SPEED_1000] = {
.bmsr = BMSR_ESTATEN, .bmsr = BMSR_ESTATEN,
.lpagb = LPA_1000FULL | LPA_1000HALF, .lpagb = LPA_1000FULL | LPA_1000HALF,
.estat = ESTATUS_1000_TFULL | ESTATUS_1000_THALF,
}, },
}; };
...@@ -56,11 +58,13 @@ static const struct swmii_regs duplex[] = { ...@@ -56,11 +58,13 @@ static const struct swmii_regs duplex[] = {
.bmsr = BMSR_ESTATEN | BMSR_100HALF, .bmsr = BMSR_ESTATEN | BMSR_100HALF,
.lpa = LPA_10HALF | LPA_100HALF, .lpa = LPA_10HALF | LPA_100HALF,
.lpagb = LPA_1000HALF, .lpagb = LPA_1000HALF,
.estat = ESTATUS_1000_THALF,
}, },
[SWMII_DUPLEX_FULL] = { [SWMII_DUPLEX_FULL] = {
.bmsr = BMSR_ESTATEN | BMSR_100FULL, .bmsr = BMSR_ESTATEN | BMSR_100FULL,
.lpa = LPA_10FULL | LPA_100FULL, .lpa = LPA_10FULL | LPA_100FULL,
.lpagb = LPA_1000FULL, .lpagb = LPA_1000FULL,
.estat = ESTATUS_1000_TFULL,
}, },
}; };
...@@ -112,6 +116,7 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state) ...@@ -112,6 +116,7 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state)
{ {
int speed_index, duplex_index; int speed_index, duplex_index;
u16 bmsr = BMSR_ANEGCAPABLE; u16 bmsr = BMSR_ANEGCAPABLE;
u16 estat = 0;
u16 lpagb = 0; u16 lpagb = 0;
u16 lpa = 0; u16 lpa = 0;
...@@ -125,6 +130,7 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state) ...@@ -125,6 +130,7 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state)
duplex_index = state->duplex ? SWMII_DUPLEX_FULL : SWMII_DUPLEX_HALF; duplex_index = state->duplex ? SWMII_DUPLEX_FULL : SWMII_DUPLEX_HALF;
bmsr |= speed[speed_index].bmsr & duplex[duplex_index].bmsr; bmsr |= speed[speed_index].bmsr & duplex[duplex_index].bmsr;
estat |= speed[speed_index].estat & duplex[duplex_index].estat;
if (state->link) { if (state->link) {
bmsr |= BMSR_LSTATUS | BMSR_ANEGCOMPLETE; bmsr |= BMSR_LSTATUS | BMSR_ANEGCOMPLETE;
...@@ -151,6 +157,8 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state) ...@@ -151,6 +157,8 @@ int swphy_read_reg(int reg, const struct fixed_phy_status *state)
return lpa; return lpa;
case MII_STAT1000: case MII_STAT1000:
return lpagb; return lpagb;
case MII_ESTATUS:
return estat;
/* /*
* We do not support emulating Clause 45 over Clause 22 register * We do not support emulating Clause 45 over Clause 22 register
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment