diff options
author | Florian Fainelli <f.fainelli@gmail.com> | 2014-11-11 17:55:14 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-11-12 13:58:07 -0500 |
commit | 0c2fdc25ae4520e98082bc3ecfea4dce06d52018 (patch) | |
tree | 8c86c63824048a3d695b866ff28ee7521769b398 /drivers/net/phy | |
parent | a490631fa61795638c0a0df1bc1ac7185cd41c3b (diff) |
net: phy: bcm7xxx: add workaround for PHY revision E0 and F0
PHY revisions E0 and F0 share the same shorter workaround initialization
sequence. Dedicate a special function for these two PHY revisions to
perform the needed workaround sequence.
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/phy')
-rw-r--r-- | drivers/net/phy/bcm7xxx.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/drivers/net/phy/bcm7xxx.c b/drivers/net/phy/bcm7xxx.c index 095cfc92326e..7a53af4346e4 100644 --- a/drivers/net/phy/bcm7xxx.c +++ b/drivers/net/phy/bcm7xxx.c | |||
@@ -162,6 +162,31 @@ static int bcm7xxx_28nm_d0_afe_config_init(struct phy_device *phydev) | |||
162 | return 0; | 162 | return 0; |
163 | } | 163 | } |
164 | 164 | ||
165 | static int bcm7xxx_28nm_e0_plus_afe_config_init(struct phy_device *phydev) | ||
166 | { | ||
167 | /* AFE_RXCONFIG_1, provide more margin for INL/DNL measurement */ | ||
168 | phy_write_misc(phydev, AFE_RXCONFIG_1, 0x9b2f); | ||
169 | |||
170 | /* AFE_VDCA_ICTRL_0, set Iq=1101 instead of 0111 for AB symmetry */ | ||
171 | phy_write_misc(phydev, AFE_VDCA_ICTRL_0, 0xa7da); | ||
172 | |||
173 | /* AFE_HPF_TRIM_OTHERS, set 100Tx/10BT to -4.5% swing and set rCal | ||
174 | * offset for HT=0 code | ||
175 | */ | ||
176 | phy_write_misc(phydev, AFE_HPF_TRIM_OTHERS, 0x00e3); | ||
177 | |||
178 | /* CORE_BASE1E, force trim to overwrite and set I_ext trim to 0000 */ | ||
179 | phy_write(phydev, MII_BCM7XXX_CORE_BASE1E, 0x0010); | ||
180 | |||
181 | /* DSP_TAP10, adjust bias current trim (+0% swing, +0 tick) */ | ||
182 | phy_write_misc(phydev, DSP_TAP10, 0x011b); | ||
183 | |||
184 | /* Reset R_CAL/RC_CAL engine */ | ||
185 | r_rc_cal_reset(phydev); | ||
186 | |||
187 | return 0; | ||
188 | } | ||
189 | |||
165 | static int bcm7xxx_apd_enable(struct phy_device *phydev) | 190 | static int bcm7xxx_apd_enable(struct phy_device *phydev) |
166 | { | 191 | { |
167 | int val; | 192 | int val; |
@@ -225,6 +250,10 @@ static int bcm7xxx_28nm_config_init(struct phy_device *phydev) | |||
225 | case 0xd0: | 250 | case 0xd0: |
226 | ret = bcm7xxx_28nm_d0_afe_config_init(phydev); | 251 | ret = bcm7xxx_28nm_d0_afe_config_init(phydev); |
227 | break; | 252 | break; |
253 | case 0xe0: | ||
254 | case 0xf0: | ||
255 | ret = bcm7xxx_28nm_e0_plus_afe_config_init(phydev); | ||
256 | break; | ||
228 | default: | 257 | default: |
229 | break; | 258 | break; |
230 | } | 259 | } |