Skip to content

Commit c189dbd

Browse files
ericwouddavem330
authored andcommitted
net: phy: realtek: add get_rate_matching() for rtl822xb PHYs
Uses vendor register to determine if SerDes is setup in rate-matching mode. Rate-matching only supported when SerDes is set to 2500base-x. Signed-off-by: Eric Woudstra <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent deb8af5 commit c189dbd

File tree

1 file changed

+25
-0
lines changed

1 file changed

+25
-0
lines changed

drivers/net/phy/realtek.c

Lines changed: 25 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -726,6 +726,27 @@ static int rtl822xb_config_init(struct phy_device *phydev)
726726
return phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x6f11, 0x8020);
727727
}
728728

729+
static int rtl822xb_get_rate_matching(struct phy_device *phydev,
730+
phy_interface_t iface)
731+
{
732+
int val;
733+
734+
/* Only rate matching at 2500base-x */
735+
if (iface != PHY_INTERFACE_MODE_2500BASEX)
736+
return RATE_MATCH_NONE;
737+
738+
val = phy_read_mmd(phydev, MDIO_MMD_VEND1, RTL822X_VND1_SERDES_OPTION);
739+
if (val < 0)
740+
return val;
741+
742+
if ((val & RTL822X_VND1_SERDES_OPTION_MODE_MASK) ==
743+
RTL822X_VND1_SERDES_OPTION_MODE_2500BASEX)
744+
return RATE_MATCH_PAUSE;
745+
746+
/* RTL822X_VND1_SERDES_OPTION_MODE_2500BASEX_SGMII */
747+
return RATE_MATCH_NONE;
748+
}
749+
729750
static int rtl822x_get_features(struct phy_device *phydev)
730751
{
731752
int val;
@@ -1091,6 +1112,7 @@ static struct phy_driver realtek_drvs[] = {
10911112
.get_features = rtl822x_get_features,
10921113
.config_aneg = rtl822x_config_aneg,
10931114
.config_init = rtl822xb_config_init,
1115+
.get_rate_matching = rtl822xb_get_rate_matching,
10941116
.read_status = rtl822xb_read_status,
10951117
.suspend = genphy_suspend,
10961118
.resume = rtlgen_resume,
@@ -1114,6 +1136,7 @@ static struct phy_driver realtek_drvs[] = {
11141136
.get_features = rtl822x_get_features,
11151137
.config_aneg = rtl822x_config_aneg,
11161138
.config_init = rtl822xb_config_init,
1139+
.get_rate_matching = rtl822xb_get_rate_matching,
11171140
.read_status = rtl822xb_read_status,
11181141
.suspend = genphy_suspend,
11191142
.resume = rtlgen_resume,
@@ -1125,6 +1148,7 @@ static struct phy_driver realtek_drvs[] = {
11251148
.get_features = rtl822x_get_features,
11261149
.config_aneg = rtl822x_config_aneg,
11271150
.config_init = rtl822xb_config_init,
1151+
.get_rate_matching = rtl822xb_get_rate_matching,
11281152
.read_status = rtl822xb_read_status,
11291153
.suspend = genphy_suspend,
11301154
.resume = rtlgen_resume,
@@ -1136,6 +1160,7 @@ static struct phy_driver realtek_drvs[] = {
11361160
.get_features = rtl822x_get_features,
11371161
.config_aneg = rtl822x_config_aneg,
11381162
.config_init = rtl822xb_config_init,
1163+
.get_rate_matching = rtl822xb_get_rate_matching,
11391164
.read_status = rtl822xb_read_status,
11401165
.suspend = genphy_suspend,
11411166
.resume = rtlgen_resume,

0 commit comments

Comments
 (0)