Commit 0b9b571d authored by françois romieu's avatar françois romieu Committed by David S. Miller

r8169: phy init for the 8169s

Synced with Realtek's 6.011.00 r8169 driver.
Signed-off-by: default avatarFrancois Romieu <romieu@fr.zoreil.com>
Cc: Edward Hsu <edward_hsu@realtek.com.tw>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 2e955856
...@@ -1222,17 +1222,6 @@ static const struct ethtool_ops rtl8169_ethtool_ops = { ...@@ -1222,17 +1222,6 @@ static const struct ethtool_ops rtl8169_ethtool_ops = {
.get_ethtool_stats = rtl8169_get_ethtool_stats, .get_ethtool_stats = rtl8169_get_ethtool_stats,
}; };
static void rtl8169_write_gmii_reg_bit(void __iomem *ioaddr, int reg,
int bitnum, int bitval)
{
int val;
val = mdio_read(ioaddr, reg);
val = (bitval == 1) ?
val | (bitval << bitnum) : val & ~(0x0001 << bitnum);
mdio_write(ioaddr, reg, val & 0xffff);
}
static void rtl8169_get_mac_version(struct rtl8169_private *tp, static void rtl8169_get_mac_version(struct rtl8169_private *tp,
void __iomem *ioaddr) void __iomem *ioaddr)
{ {
...@@ -1328,54 +1317,69 @@ static void rtl_phy_write(void __iomem *ioaddr, struct phy_reg *regs, int len) ...@@ -1328,54 +1317,69 @@ static void rtl_phy_write(void __iomem *ioaddr, struct phy_reg *regs, int len)
static void rtl8169s_hw_phy_config(void __iomem *ioaddr) static void rtl8169s_hw_phy_config(void __iomem *ioaddr)
{ {
struct { struct phy_reg phy_reg_init[] = {
u16 regs[5]; /* Beware of bit-sign propagation */ { 0x1f, 0x0001 },
} phy_magic[5] = { { { 0x06, 0x006e },
{ 0x0000, //w 4 15 12 0 { 0x08, 0x0708 },
0x00a1, //w 3 15 0 00a1 { 0x15, 0x4000 },
0x0008, //w 2 15 0 0008 { 0x18, 0x65c7 },
0x1020, //w 1 15 0 1020
0x1000 } },{ //w 0 15 0 1000
{ 0x7000, //w 4 15 12 7
0xff41, //w 3 15 0 ff41
0xde60, //w 2 15 0 de60
0x0140, //w 1 15 0 0140
0x0077 } },{ //w 0 15 0 0077
{ 0xa000, //w 4 15 12 a
0xdf01, //w 3 15 0 df01
0xdf20, //w 2 15 0 df20
0xff95, //w 1 15 0 ff95
0xfa00 } },{ //w 0 15 0 fa00
{ 0xb000, //w 4 15 12 b
0xff41, //w 3 15 0 ff41
0xde20, //w 2 15 0 de20
0x0140, //w 1 15 0 0140
0x00bb } },{ //w 0 15 0 00bb
{ 0xf000, //w 4 15 12 f
0xdf01, //w 3 15 0 df01
0xdf20, //w 2 15 0 df20
0xff95, //w 1 15 0 ff95
0xbf00 } //w 0 15 0 bf00
}
}, *p = phy_magic;
unsigned int i;
mdio_write(ioaddr, 0x1f, 0x0001); //w 31 2 0 1 { 0x1f, 0x0001 },
mdio_write(ioaddr, 0x15, 0x1000); //w 21 15 0 1000 { 0x03, 0x00a1 },
mdio_write(ioaddr, 0x18, 0x65c7); //w 24 15 0 65c7 { 0x02, 0x0008 },
rtl8169_write_gmii_reg_bit(ioaddr, 4, 11, 0); //w 4 11 11 0 { 0x01, 0x0120 },
{ 0x00, 0x1000 },
{ 0x04, 0x0800 },
{ 0x04, 0x0000 },
for (i = 0; i < ARRAY_SIZE(phy_magic); i++, p++) { { 0x03, 0xff41 },
int val, pos = 4; { 0x02, 0xdf60 },
{ 0x01, 0x0140 },
{ 0x00, 0x0077 },
{ 0x04, 0x7800 },
{ 0x04, 0x7000 },
val = (mdio_read(ioaddr, pos) & 0x0fff) | (p->regs[0] & 0xffff); { 0x03, 0x802f },
mdio_write(ioaddr, pos, val); { 0x02, 0x4f02 },
while (--pos >= 0) { 0x01, 0x0409 },
mdio_write(ioaddr, pos, p->regs[4 - pos] & 0xffff); { 0x00, 0xf0f9 },
rtl8169_write_gmii_reg_bit(ioaddr, 4, 11, 1); //w 4 11 11 1 { 0x04, 0x9800 },
rtl8169_write_gmii_reg_bit(ioaddr, 4, 11, 0); //w 4 11 11 0 { 0x04, 0x9000 },
}
mdio_write(ioaddr, 0x1f, 0x0000); //w 31 2 0 0 { 0x03, 0xdf01 },
{ 0x02, 0xdf20 },
{ 0x01, 0xff95 },
{ 0x00, 0xba00 },
{ 0x04, 0xa800 },
{ 0x04, 0xa000 },
{ 0x03, 0xff41 },
{ 0x02, 0xdf20 },
{ 0x01, 0x0140 },
{ 0x00, 0x00bb },
{ 0x04, 0xb800 },
{ 0x04, 0xb000 },
{ 0x03, 0xdf41 },
{ 0x02, 0xdc60 },
{ 0x01, 0x6340 },
{ 0x00, 0x007d },
{ 0x04, 0xd800 },
{ 0x04, 0xd000 },
{ 0x03, 0xdf01 },
{ 0x02, 0xdf20 },
{ 0x01, 0x100a },
{ 0x00, 0xa0ff },
{ 0x04, 0xf800 },
{ 0x04, 0xf000 },
{ 0x1f, 0x0000 },
{ 0x0b, 0x0000 },
{ 0x00, 0x9200 }
};
rtl_phy_write(ioaddr, phy_reg_init, ARRAY_SIZE(phy_reg_init));
} }
static void rtl8169sb_hw_phy_config(void __iomem *ioaddr) static void rtl8169sb_hw_phy_config(void __iomem *ioaddr)
......
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