Commit 8bfdce1d authored by Heiner Kallweit's avatar Heiner Kallweit Committed by David S. Miller

r8169: add helper r8168g_phy_param

Integrated PHY's from RTL8168g support an indirect access method for
PHY parameters. On page 0x0a43 parameter number is written to register
0x13, then the parameter can be accessed via register 0x14.
Add a helper for this to improve readability and simplify the code.
Signed-off-by: default avatarHeiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 727b3668
...@@ -1086,6 +1086,17 @@ static void rtl_w0w1_phy(struct rtl8169_private *tp, int reg_addr, int p, int m) ...@@ -1086,6 +1086,17 @@ static void rtl_w0w1_phy(struct rtl8169_private *tp, int reg_addr, int p, int m)
rtl_writephy(tp, reg_addr, (val & ~m) | p); rtl_writephy(tp, reg_addr, (val & ~m) | p);
} }
static void r8168g_phy_param(struct phy_device *phydev, u16 parm,
u16 mask, u16 val)
{
int oldpage = phy_select_page(phydev, 0x0a43);
__phy_write(phydev, 0x13, parm);
__phy_modify(phydev, 0x14, mask, val);
phy_restore_page(phydev, oldpage, 0);
}
DECLARE_RTL_COND(rtl_ephyar_cond) DECLARE_RTL_COND(rtl_ephyar_cond)
{ {
return RTL_R32(tp, EPHYAR) & EPHYAR_FLAG; return RTL_R32(tp, EPHYAR) & EPHYAR_FLAG;
...@@ -3222,12 +3233,8 @@ static void rtl8168g_phy_adjust_10m_aldps(struct rtl8169_private *tp) ...@@ -3222,12 +3233,8 @@ static void rtl8168g_phy_adjust_10m_aldps(struct rtl8169_private *tp)
phy_modify_paged(phydev, 0x0bcc, 0x14, BIT(8), 0); phy_modify_paged(phydev, 0x0bcc, 0x14, BIT(8), 0);
phy_modify_paged(phydev, 0x0a44, 0x11, 0, BIT(7) | BIT(6)); phy_modify_paged(phydev, 0x0a44, 0x11, 0, BIT(7) | BIT(6));
phy_write(phydev, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x8084, 0x6000, 0x0000);
phy_write(phydev, 0x13, 0x8084); phy_modify_paged(phydev, 0x0a43, 0x10, 0x0000, 0x1003);
phy_clear_bits(phydev, 0x14, BIT(14) | BIT(13));
phy_set_bits(phydev, 0x10, BIT(12) | BIT(1) | BIT(0));
phy_write(phydev, 0x1f, 0x0000);
} }
static void rtl8168g_1_hw_phy_config(struct rtl8169_private *tp) static void rtl8168g_1_hw_phy_config(struct rtl8169_private *tp)
...@@ -3257,9 +3264,7 @@ static void rtl8168g_1_hw_phy_config(struct rtl8169_private *tp) ...@@ -3257,9 +3264,7 @@ static void rtl8168g_1_hw_phy_config(struct rtl8169_private *tp)
phy_modify_paged(tp->phydev, 0x0a4b, 0x11, 0, BIT(2)); phy_modify_paged(tp->phydev, 0x0a4b, 0x11, 0, BIT(2));
/* Enable UC LPF tune function */ /* Enable UC LPF tune function */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(tp->phydev, 0x8012, 0x0000, 0x8000);
rtl_writephy(tp, 0x13, 0x8012);
rtl_w0w1_phy(tp, 0x14, 0x8000, 0x0000);
phy_modify_paged(tp->phydev, 0x0c42, 0x11, BIT(13), BIT(14)); phy_modify_paged(tp->phydev, 0x0c42, 0x11, BIT(13), BIT(14));
...@@ -3289,73 +3294,48 @@ static void rtl8168g_2_hw_phy_config(struct rtl8169_private *tp) ...@@ -3289,73 +3294,48 @@ static void rtl8168g_2_hw_phy_config(struct rtl8169_private *tp)
static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp) static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp)
{ {
struct phy_device *phydev = tp->phydev;
u16 dout_tapbin; u16 dout_tapbin;
u32 data; u32 data;
rtl_apply_firmware(tp); rtl_apply_firmware(tp);
/* CHN EST parameters adjust - giga master */ /* CHN EST parameters adjust - giga master */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x809b, 0xf800, 0x8000);
rtl_writephy(tp, 0x13, 0x809b); r8168g_phy_param(phydev, 0x80a2, 0xff00, 0x8000);
rtl_w0w1_phy(tp, 0x14, 0x8000, 0xf800); r8168g_phy_param(phydev, 0x80a4, 0xff00, 0x8500);
rtl_writephy(tp, 0x13, 0x80a2); r8168g_phy_param(phydev, 0x809c, 0xff00, 0xbd00);
rtl_w0w1_phy(tp, 0x14, 0x8000, 0xff00);
rtl_writephy(tp, 0x13, 0x80a4);
rtl_w0w1_phy(tp, 0x14, 0x8500, 0xff00);
rtl_writephy(tp, 0x13, 0x809c);
rtl_w0w1_phy(tp, 0x14, 0xbd00, 0xff00);
rtl_writephy(tp, 0x1f, 0x0000);
/* CHN EST parameters adjust - giga slave */ /* CHN EST parameters adjust - giga slave */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x80ad, 0xf800, 0x7000);
rtl_writephy(tp, 0x13, 0x80ad); r8168g_phy_param(phydev, 0x80b4, 0xff00, 0x5000);
rtl_w0w1_phy(tp, 0x14, 0x7000, 0xf800); r8168g_phy_param(phydev, 0x80ac, 0xff00, 0x4000);
rtl_writephy(tp, 0x13, 0x80b4);
rtl_w0w1_phy(tp, 0x14, 0x5000, 0xff00);
rtl_writephy(tp, 0x13, 0x80ac);
rtl_w0w1_phy(tp, 0x14, 0x4000, 0xff00);
rtl_writephy(tp, 0x1f, 0x0000);
/* CHN EST parameters adjust - fnet */ /* CHN EST parameters adjust - fnet */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x808e, 0xff00, 0x1200);
rtl_writephy(tp, 0x13, 0x808e); r8168g_phy_param(phydev, 0x8090, 0xff00, 0xe500);
rtl_w0w1_phy(tp, 0x14, 0x1200, 0xff00); r8168g_phy_param(phydev, 0x8092, 0xff00, 0x9f00);
rtl_writephy(tp, 0x13, 0x8090);
rtl_w0w1_phy(tp, 0x14, 0xe500, 0xff00);
rtl_writephy(tp, 0x13, 0x8092);
rtl_w0w1_phy(tp, 0x14, 0x9f00, 0xff00);
rtl_writephy(tp, 0x1f, 0x0000);
/* enable R-tune & PGA-retune function */ /* enable R-tune & PGA-retune function */
dout_tapbin = 0; dout_tapbin = 0;
rtl_writephy(tp, 0x1f, 0x0a46); data = phy_read_paged(phydev, 0x0a46, 0x13);
data = rtl_readphy(tp, 0x13);
data &= 3; data &= 3;
data <<= 2; data <<= 2;
dout_tapbin |= data; dout_tapbin |= data;
data = rtl_readphy(tp, 0x12); data = phy_read_paged(phydev, 0x0a46, 0x12);
data &= 0xc000; data &= 0xc000;
data >>= 14; data >>= 14;
dout_tapbin |= data; dout_tapbin |= data;
dout_tapbin = ~(dout_tapbin^0x08); dout_tapbin = ~(dout_tapbin^0x08);
dout_tapbin <<= 12; dout_tapbin <<= 12;
dout_tapbin &= 0xf000; dout_tapbin &= 0xf000;
rtl_writephy(tp, 0x1f, 0x0a43);
rtl_writephy(tp, 0x13, 0x827a); r8168g_phy_param(phydev, 0x827a, 0xf000, dout_tapbin);
rtl_w0w1_phy(tp, 0x14, dout_tapbin, 0xf000); r8168g_phy_param(phydev, 0x827b, 0xf000, dout_tapbin);
rtl_writephy(tp, 0x13, 0x827b); r8168g_phy_param(phydev, 0x827c, 0xf000, dout_tapbin);
rtl_w0w1_phy(tp, 0x14, dout_tapbin, 0xf000); r8168g_phy_param(phydev, 0x827d, 0xf000, dout_tapbin);
rtl_writephy(tp, 0x13, 0x827c); r8168g_phy_param(phydev, 0x0811, 0x0000, 0x0800);
rtl_w0w1_phy(tp, 0x14, dout_tapbin, 0xf000); phy_modify_paged(phydev, 0x0a42, 0x16, 0x0000, 0x0002);
rtl_writephy(tp, 0x13, 0x827d);
rtl_w0w1_phy(tp, 0x14, dout_tapbin, 0xf000);
rtl_writephy(tp, 0x1f, 0x0a43);
rtl_writephy(tp, 0x13, 0x0811);
rtl_w0w1_phy(tp, 0x14, 0x0800, 0x0000);
rtl_writephy(tp, 0x1f, 0x0a42);
rtl_w0w1_phy(tp, 0x16, 0x0002, 0x0000);
rtl_writephy(tp, 0x1f, 0x0000);
/* enable GPHY 10M */ /* enable GPHY 10M */
phy_modify_paged(tp->phydev, 0x0a44, 0x11, 0, BIT(11)); phy_modify_paged(tp->phydev, 0x0a44, 0x11, 0, BIT(11));
...@@ -3363,22 +3343,13 @@ static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp) ...@@ -3363,22 +3343,13 @@ static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp)
/* SAR ADC performance */ /* SAR ADC performance */
phy_modify_paged(tp->phydev, 0x0bca, 0x17, BIT(12) | BIT(13), BIT(14)); phy_modify_paged(tp->phydev, 0x0bca, 0x17, BIT(12) | BIT(13), BIT(14));
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x803f, 0x3000, 0x0000);
rtl_writephy(tp, 0x13, 0x803f); r8168g_phy_param(phydev, 0x8047, 0x3000, 0x0000);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000); r8168g_phy_param(phydev, 0x804f, 0x3000, 0x0000);
rtl_writephy(tp, 0x13, 0x8047); r8168g_phy_param(phydev, 0x8057, 0x3000, 0x0000);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000); r8168g_phy_param(phydev, 0x805f, 0x3000, 0x0000);
rtl_writephy(tp, 0x13, 0x804f); r8168g_phy_param(phydev, 0x8067, 0x3000, 0x0000);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000); r8168g_phy_param(phydev, 0x806f, 0x3000, 0x0000);
rtl_writephy(tp, 0x13, 0x8057);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000);
rtl_writephy(tp, 0x13, 0x805f);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000);
rtl_writephy(tp, 0x13, 0x8067);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000);
rtl_writephy(tp, 0x13, 0x806f);
rtl_w0w1_phy(tp, 0x14, 0x0000, 0x3000);
rtl_writephy(tp, 0x1f, 0x0000);
/* disable phy pfm mode */ /* disable phy pfm mode */
phy_modify_paged(tp->phydev, 0x0a44, 0x11, BIT(7), 0); phy_modify_paged(tp->phydev, 0x0a44, 0x11, BIT(7), 0);
...@@ -3391,24 +3362,18 @@ static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp) ...@@ -3391,24 +3362,18 @@ static void rtl8168h_1_hw_phy_config(struct rtl8169_private *tp)
static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp) static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp)
{ {
u16 ioffset_p3, ioffset_p2, ioffset_p1, ioffset_p0; u16 ioffset_p3, ioffset_p2, ioffset_p1, ioffset_p0;
struct phy_device *phydev = tp->phydev;
u16 rlen; u16 rlen;
u32 data; u32 data;
rtl_apply_firmware(tp); rtl_apply_firmware(tp);
/* CHIN EST parameter update */ /* CHIN EST parameter update */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x808a, 0x003f, 0x000a);
rtl_writephy(tp, 0x13, 0x808a);
rtl_w0w1_phy(tp, 0x14, 0x000a, 0x003f);
rtl_writephy(tp, 0x1f, 0x0000);
/* enable R-tune & PGA-retune function */ /* enable R-tune & PGA-retune function */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x0811, 0x0000, 0x0800);
rtl_writephy(tp, 0x13, 0x0811); phy_modify_paged(phydev, 0x0a42, 0x16, 0x0000, 0x0002);
rtl_w0w1_phy(tp, 0x14, 0x0800, 0x0000);
rtl_writephy(tp, 0x1f, 0x0a42);
rtl_w0w1_phy(tp, 0x16, 0x0002, 0x0000);
rtl_writephy(tp, 0x1f, 0x0000);
/* enable GPHY 10M */ /* enable GPHY 10M */
phy_modify_paged(tp->phydev, 0x0a44, 0x11, 0, BIT(11)); phy_modify_paged(tp->phydev, 0x0a44, 0x11, 0, BIT(11));
...@@ -3428,26 +3393,20 @@ static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp) ...@@ -3428,26 +3393,20 @@ static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp)
data = (ioffset_p3<<12)|(ioffset_p2<<8)|(ioffset_p1<<4)|(ioffset_p0); data = (ioffset_p3<<12)|(ioffset_p2<<8)|(ioffset_p1<<4)|(ioffset_p0);
if ((ioffset_p3 != 0x0f) || (ioffset_p2 != 0x0f) || if ((ioffset_p3 != 0x0f) || (ioffset_p2 != 0x0f) ||
(ioffset_p1 != 0x0f) || (ioffset_p0 != 0x0f)) { (ioffset_p1 != 0x0f) || (ioffset_p0 != 0x0f))
rtl_writephy(tp, 0x1f, 0x0bcf); phy_write_paged(phydev, 0x0bcf, 0x16, data);
rtl_writephy(tp, 0x16, data);
rtl_writephy(tp, 0x1f, 0x0000);
}
/* Modify rlen (TX LPF corner frequency) level */ /* Modify rlen (TX LPF corner frequency) level */
rtl_writephy(tp, 0x1f, 0x0bcd); data = phy_read_paged(phydev, 0x0bcd, 0x16);
data = rtl_readphy(tp, 0x16);
data &= 0x000f; data &= 0x000f;
rlen = 0; rlen = 0;
if (data > 3) if (data > 3)
rlen = data - 3; rlen = data - 3;
data = rlen | (rlen<<4) | (rlen<<8) | (rlen<<12); data = rlen | (rlen<<4) | (rlen<<8) | (rlen<<12);
rtl_writephy(tp, 0x17, data); phy_write_paged(phydev, 0x0bcd, 0x17, data);
rtl_writephy(tp, 0x1f, 0x0bcd);
rtl_writephy(tp, 0x1f, 0x0000);
/* disable phy pfm mode */ /* disable phy pfm mode */
phy_modify_paged(tp->phydev, 0x0a44, 0x11, BIT(7), 0); phy_modify_paged(phydev, 0x0a44, 0x11, BIT(7), 0);
rtl8168g_disable_aldps(tp); rtl8168g_disable_aldps(tp);
rtl8168g_config_eee_phy(tp); rtl8168g_config_eee_phy(tp);
...@@ -3456,22 +3415,21 @@ static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp) ...@@ -3456,22 +3415,21 @@ static void rtl8168h_2_hw_phy_config(struct rtl8169_private *tp)
static void rtl8168ep_1_hw_phy_config(struct rtl8169_private *tp) static void rtl8168ep_1_hw_phy_config(struct rtl8169_private *tp)
{ {
struct phy_device *phydev = tp->phydev;
/* Enable PHY auto speed down */ /* Enable PHY auto speed down */
phy_modify_paged(tp->phydev, 0x0a44, 0x11, 0, BIT(3) | BIT(2)); phy_modify_paged(phydev, 0x0a44, 0x11, 0, BIT(3) | BIT(2));
rtl8168g_phy_adjust_10m_aldps(tp); rtl8168g_phy_adjust_10m_aldps(tp);
/* Enable EEE auto-fallback function */ /* Enable EEE auto-fallback function */
phy_modify_paged(tp->phydev, 0x0a4b, 0x11, 0, BIT(2)); phy_modify_paged(phydev, 0x0a4b, 0x11, 0, BIT(2));
/* Enable UC LPF tune function */ /* Enable UC LPF tune function */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x8012, 0x0000, 0x8000);
rtl_writephy(tp, 0x13, 0x8012);
rtl_w0w1_phy(tp, 0x14, 0x8000, 0x0000);
rtl_writephy(tp, 0x1f, 0x0000);
/* set rg_sel_sdm_rate */ /* set rg_sel_sdm_rate */
phy_modify_paged(tp->phydev, 0x0c42, 0x11, BIT(13), BIT(14)); phy_modify_paged(phydev, 0x0c42, 0x11, BIT(13), BIT(14));
rtl8168g_disable_aldps(tp); rtl8168g_disable_aldps(tp);
rtl8168g_config_eee_phy(tp); rtl8168g_config_eee_phy(tp);
...@@ -3480,63 +3438,38 @@ static void rtl8168ep_1_hw_phy_config(struct rtl8169_private *tp) ...@@ -3480,63 +3438,38 @@ static void rtl8168ep_1_hw_phy_config(struct rtl8169_private *tp)
static void rtl8168ep_2_hw_phy_config(struct rtl8169_private *tp) static void rtl8168ep_2_hw_phy_config(struct rtl8169_private *tp)
{ {
struct phy_device *phydev = tp->phydev;
rtl8168g_phy_adjust_10m_aldps(tp); rtl8168g_phy_adjust_10m_aldps(tp);
/* Enable UC LPF tune function */ /* Enable UC LPF tune function */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x8012, 0x0000, 0x8000);
rtl_writephy(tp, 0x13, 0x8012);
rtl_w0w1_phy(tp, 0x14, 0x8000, 0x0000);
rtl_writephy(tp, 0x1f, 0x0000);
/* Set rg_sel_sdm_rate */ /* Set rg_sel_sdm_rate */
phy_modify_paged(tp->phydev, 0x0c42, 0x11, BIT(13), BIT(14)); phy_modify_paged(tp->phydev, 0x0c42, 0x11, BIT(13), BIT(14));
/* Channel estimation parameters */ /* Channel estimation parameters */
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x80f3, 0xff00, 0x8b00);
rtl_writephy(tp, 0x13, 0x80f3); r8168g_phy_param(phydev, 0x80f0, 0xff00, 0x3a00);
rtl_w0w1_phy(tp, 0x14, 0x8b00, ~0x8bff); r8168g_phy_param(phydev, 0x80ef, 0xff00, 0x0500);
rtl_writephy(tp, 0x13, 0x80f0); r8168g_phy_param(phydev, 0x80f6, 0xff00, 0x6e00);
rtl_w0w1_phy(tp, 0x14, 0x3a00, ~0x3aff); r8168g_phy_param(phydev, 0x80ec, 0xff00, 0x6800);
rtl_writephy(tp, 0x13, 0x80ef); r8168g_phy_param(phydev, 0x80ed, 0xff00, 0x7c00);
rtl_w0w1_phy(tp, 0x14, 0x0500, ~0x05ff); r8168g_phy_param(phydev, 0x80f2, 0xff00, 0xf400);
rtl_writephy(tp, 0x13, 0x80f6); r8168g_phy_param(phydev, 0x80f4, 0xff00, 0x8500);
rtl_w0w1_phy(tp, 0x14, 0x6e00, ~0x6eff); r8168g_phy_param(phydev, 0x8110, 0xff00, 0xa800);
rtl_writephy(tp, 0x13, 0x80ec); r8168g_phy_param(phydev, 0x810f, 0xff00, 0x1d00);
rtl_w0w1_phy(tp, 0x14, 0x6800, ~0x68ff); r8168g_phy_param(phydev, 0x8111, 0xff00, 0xf500);
rtl_writephy(tp, 0x13, 0x80ed); r8168g_phy_param(phydev, 0x8113, 0xff00, 0x6100);
rtl_w0w1_phy(tp, 0x14, 0x7c00, ~0x7cff); r8168g_phy_param(phydev, 0x8115, 0xff00, 0x9200);
rtl_writephy(tp, 0x13, 0x80f2); r8168g_phy_param(phydev, 0x810e, 0xff00, 0x0400);
rtl_w0w1_phy(tp, 0x14, 0xf400, ~0xf4ff); r8168g_phy_param(phydev, 0x810c, 0xff00, 0x7c00);
rtl_writephy(tp, 0x13, 0x80f4); r8168g_phy_param(phydev, 0x810b, 0xff00, 0x5a00);
rtl_w0w1_phy(tp, 0x14, 0x8500, ~0x85ff); r8168g_phy_param(phydev, 0x80d1, 0xff00, 0xff00);
rtl_writephy(tp, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x80cd, 0xff00, 0x9e00);
rtl_writephy(tp, 0x13, 0x8110); r8168g_phy_param(phydev, 0x80d3, 0xff00, 0x0e00);
rtl_w0w1_phy(tp, 0x14, 0xa800, ~0xa8ff); r8168g_phy_param(phydev, 0x80d5, 0xff00, 0xca00);
rtl_writephy(tp, 0x13, 0x810f); r8168g_phy_param(phydev, 0x80d7, 0xff00, 0x8400);
rtl_w0w1_phy(tp, 0x14, 0x1d00, ~0x1dff);
rtl_writephy(tp, 0x13, 0x8111);
rtl_w0w1_phy(tp, 0x14, 0xf500, ~0xf5ff);
rtl_writephy(tp, 0x13, 0x8113);
rtl_w0w1_phy(tp, 0x14, 0x6100, ~0x61ff);
rtl_writephy(tp, 0x13, 0x8115);
rtl_w0w1_phy(tp, 0x14, 0x9200, ~0x92ff);
rtl_writephy(tp, 0x13, 0x810e);
rtl_w0w1_phy(tp, 0x14, 0x0400, ~0x04ff);
rtl_writephy(tp, 0x13, 0x810c);
rtl_w0w1_phy(tp, 0x14, 0x7c00, ~0x7cff);
rtl_writephy(tp, 0x13, 0x810b);
rtl_w0w1_phy(tp, 0x14, 0x5a00, ~0x5aff);
rtl_writephy(tp, 0x1f, 0x0a43);
rtl_writephy(tp, 0x13, 0x80d1);
rtl_w0w1_phy(tp, 0x14, 0xff00, ~0xffff);
rtl_writephy(tp, 0x13, 0x80cd);
rtl_w0w1_phy(tp, 0x14, 0x9e00, ~0x9eff);
rtl_writephy(tp, 0x13, 0x80d3);
rtl_w0w1_phy(tp, 0x14, 0x0e00, ~0x0eff);
rtl_writephy(tp, 0x13, 0x80d5);
rtl_w0w1_phy(tp, 0x14, 0xca00, ~0xcaff);
rtl_writephy(tp, 0x13, 0x80d7);
rtl_w0w1_phy(tp, 0x14, 0x8400, ~0x84ff);
/* Force PWM-mode */ /* Force PWM-mode */
rtl_writephy(tp, 0x1f, 0x0bcd); rtl_writephy(tp, 0x1f, 0x0bcd);
...@@ -3651,38 +3584,22 @@ static void rtl8125_1_hw_phy_config(struct rtl8169_private *tp) ...@@ -3651,38 +3584,22 @@ static void rtl8125_1_hw_phy_config(struct rtl8169_private *tp)
phy_modify_paged(phydev, 0xad1, 0x15, 0x0000, 0x03ff); phy_modify_paged(phydev, 0xad1, 0x15, 0x0000, 0x03ff);
phy_modify_paged(phydev, 0xad1, 0x16, 0x0000, 0x03ff); phy_modify_paged(phydev, 0xad1, 0x16, 0x0000, 0x03ff);
phy_write(phydev, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x80ea, 0xff00, 0xc400);
phy_write(phydev, 0x13, 0x80ea); r8168g_phy_param(phydev, 0x80eb, 0x0700, 0x0300);
phy_modify(phydev, 0x14, 0xff00, 0xc400); r8168g_phy_param(phydev, 0x80f8, 0xff00, 0x1c00);
phy_write(phydev, 0x13, 0x80eb); r8168g_phy_param(phydev, 0x80f1, 0xff00, 0x3000);
phy_modify(phydev, 0x14, 0x0700, 0x0300); r8168g_phy_param(phydev, 0x80fe, 0xff00, 0xa500);
phy_write(phydev, 0x13, 0x80f8); r8168g_phy_param(phydev, 0x8102, 0xff00, 0x5000);
phy_modify(phydev, 0x14, 0xff00, 0x1c00); r8168g_phy_param(phydev, 0x8105, 0xff00, 0x3300);
phy_write(phydev, 0x13, 0x80f1); r8168g_phy_param(phydev, 0x8100, 0xff00, 0x7000);
phy_modify(phydev, 0x14, 0xff00, 0x3000); r8168g_phy_param(phydev, 0x8104, 0xff00, 0xf000);
phy_write(phydev, 0x13, 0x80fe); r8168g_phy_param(phydev, 0x8106, 0xff00, 0x6500);
phy_modify(phydev, 0x14, 0xff00, 0xa500); r8168g_phy_param(phydev, 0x80dc, 0xff00, 0xed00);
phy_write(phydev, 0x13, 0x8102); r8168g_phy_param(phydev, 0x80df, 0x0000, 0x0100);
phy_modify(phydev, 0x14, 0xff00, 0x5000); r8168g_phy_param(phydev, 0x80e1, 0x0100, 0x0000);
phy_write(phydev, 0x13, 0x8105);
phy_modify(phydev, 0x14, 0xff00, 0x3300);
phy_write(phydev, 0x13, 0x8100);
phy_modify(phydev, 0x14, 0xff00, 0x7000);
phy_write(phydev, 0x13, 0x8104);
phy_modify(phydev, 0x14, 0xff00, 0xf000);
phy_write(phydev, 0x13, 0x8106);
phy_modify(phydev, 0x14, 0xff00, 0x6500);
phy_write(phydev, 0x13, 0x80dc);
phy_modify(phydev, 0x14, 0xff00, 0xed00);
phy_write(phydev, 0x13, 0x80df);
phy_set_bits(phydev, 0x14, BIT(8));
phy_write(phydev, 0x13, 0x80e1);
phy_clear_bits(phydev, 0x14, BIT(8));
phy_write(phydev, 0x1f, 0x0000);
phy_modify_paged(phydev, 0xbf0, 0x13, 0x003f, 0x0038); phy_modify_paged(phydev, 0xbf0, 0x13, 0x003f, 0x0038);
phy_write_paged(phydev, 0xa43, 0x13, 0x819f); r8168g_phy_param(phydev, 0x819f, 0xffff, 0xd0b6);
phy_write_paged(phydev, 0xa43, 0x14, 0xd0b6);
phy_write_paged(phydev, 0xbc3, 0x12, 0x5555); phy_write_paged(phydev, 0xbc3, 0x12, 0x5555);
phy_modify_paged(phydev, 0xbf0, 0x15, 0x0e00, 0x0a00); phy_modify_paged(phydev, 0xbf0, 0x15, 0x0e00, 0x0a00);
...@@ -3737,22 +3654,16 @@ static void rtl8125_2_hw_phy_config(struct rtl8169_private *tp) ...@@ -3737,22 +3654,16 @@ static void rtl8125_2_hw_phy_config(struct rtl8169_private *tp)
phy_write(phydev, 0x14, 0x0002); phy_write(phydev, 0x14, 0x0002);
for (i = 0; i < 25; i++) for (i = 0; i < 25; i++)
phy_write(phydev, 0x14, 0x0000); phy_write(phydev, 0x14, 0x0000);
phy_write(phydev, 0x13, 0x8257);
phy_write(phydev, 0x14, 0x020F);
phy_write(phydev, 0x13, 0x80EA);
phy_write(phydev, 0x14, 0x7843);
phy_write(phydev, 0x1f, 0x0000); phy_write(phydev, 0x1f, 0x0000);
r8168g_phy_param(phydev, 0x8257, 0xffff, 0x020F);
r8168g_phy_param(phydev, 0x80ea, 0xffff, 0x7843);
rtl_apply_firmware(tp); rtl_apply_firmware(tp);
phy_modify_paged(phydev, 0xd06, 0x14, 0x0000, 0x2000); phy_modify_paged(phydev, 0xd06, 0x14, 0x0000, 0x2000);
phy_write(phydev, 0x1f, 0x0a43); r8168g_phy_param(phydev, 0x81a2, 0x0000, 0x0100);
phy_write(phydev, 0x13, 0x81a2);
phy_set_bits(phydev, 0x14, BIT(8));
phy_write(phydev, 0x1f, 0x0000);
phy_modify_paged(phydev, 0xb54, 0x16, 0xff00, 0xdb00); phy_modify_paged(phydev, 0xb54, 0x16, 0xff00, 0xdb00);
phy_modify_paged(phydev, 0xa45, 0x12, 0x0001, 0x0000); phy_modify_paged(phydev, 0xa45, 0x12, 0x0001, 0x0000);
......
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