diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/tg3.c | 46 | ||||
-rw-r--r-- | drivers/net/tg3.h | 4 |
2 files changed, 27 insertions, 23 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index a9bca8aa254f..281cd7aff8fe 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -1742,7 +1742,7 @@ static int tg3_wait_macro_done(struct tg3 *tp) | |||
1742 | while (limit--) { | 1742 | while (limit--) { |
1743 | u32 tmp32; | 1743 | u32 tmp32; |
1744 | 1744 | ||
1745 | if (!tg3_readphy(tp, 0x16, &tmp32)) { | 1745 | if (!tg3_readphy(tp, MII_TG3_DSP_CONTROL, &tmp32)) { |
1746 | if ((tmp32 & 0x1000) == 0) | 1746 | if ((tmp32 & 0x1000) == 0) |
1747 | break; | 1747 | break; |
1748 | } | 1748 | } |
@@ -1768,13 +1768,13 @@ static int tg3_phy_write_and_check_testpat(struct tg3 *tp, int *resetp) | |||
1768 | 1768 | ||
1769 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, | 1769 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, |
1770 | (chan * 0x2000) | 0x0200); | 1770 | (chan * 0x2000) | 0x0200); |
1771 | tg3_writephy(tp, 0x16, 0x0002); | 1771 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0002); |
1772 | 1772 | ||
1773 | for (i = 0; i < 6; i++) | 1773 | for (i = 0; i < 6; i++) |
1774 | tg3_writephy(tp, MII_TG3_DSP_RW_PORT, | 1774 | tg3_writephy(tp, MII_TG3_DSP_RW_PORT, |
1775 | test_pat[chan][i]); | 1775 | test_pat[chan][i]); |
1776 | 1776 | ||
1777 | tg3_writephy(tp, 0x16, 0x0202); | 1777 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0202); |
1778 | if (tg3_wait_macro_done(tp)) { | 1778 | if (tg3_wait_macro_done(tp)) { |
1779 | *resetp = 1; | 1779 | *resetp = 1; |
1780 | return -EBUSY; | 1780 | return -EBUSY; |
@@ -1782,13 +1782,13 @@ static int tg3_phy_write_and_check_testpat(struct tg3 *tp, int *resetp) | |||
1782 | 1782 | ||
1783 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, | 1783 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, |
1784 | (chan * 0x2000) | 0x0200); | 1784 | (chan * 0x2000) | 0x0200); |
1785 | tg3_writephy(tp, 0x16, 0x0082); | 1785 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0082); |
1786 | if (tg3_wait_macro_done(tp)) { | 1786 | if (tg3_wait_macro_done(tp)) { |
1787 | *resetp = 1; | 1787 | *resetp = 1; |
1788 | return -EBUSY; | 1788 | return -EBUSY; |
1789 | } | 1789 | } |
1790 | 1790 | ||
1791 | tg3_writephy(tp, 0x16, 0x0802); | 1791 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0802); |
1792 | if (tg3_wait_macro_done(tp)) { | 1792 | if (tg3_wait_macro_done(tp)) { |
1793 | *resetp = 1; | 1793 | *resetp = 1; |
1794 | return -EBUSY; | 1794 | return -EBUSY; |
@@ -1828,10 +1828,10 @@ static int tg3_phy_reset_chanpat(struct tg3 *tp) | |||
1828 | 1828 | ||
1829 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, | 1829 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, |
1830 | (chan * 0x2000) | 0x0200); | 1830 | (chan * 0x2000) | 0x0200); |
1831 | tg3_writephy(tp, 0x16, 0x0002); | 1831 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0002); |
1832 | for (i = 0; i < 6; i++) | 1832 | for (i = 0; i < 6; i++) |
1833 | tg3_writephy(tp, MII_TG3_DSP_RW_PORT, 0x000); | 1833 | tg3_writephy(tp, MII_TG3_DSP_RW_PORT, 0x000); |
1834 | tg3_writephy(tp, 0x16, 0x0202); | 1834 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0202); |
1835 | if (tg3_wait_macro_done(tp)) | 1835 | if (tg3_wait_macro_done(tp)) |
1836 | return -EBUSY; | 1836 | return -EBUSY; |
1837 | } | 1837 | } |
@@ -1891,7 +1891,7 @@ static int tg3_phy_reset_5703_4_5(struct tg3 *tp) | |||
1891 | tg3_phydsp_write(tp, 0x8005, 0x0000); | 1891 | tg3_phydsp_write(tp, 0x8005, 0x0000); |
1892 | 1892 | ||
1893 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, 0x8200); | 1893 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, 0x8200); |
1894 | tg3_writephy(tp, 0x16, 0x0000); | 1894 | tg3_writephy(tp, MII_TG3_DSP_CONTROL, 0x0000); |
1895 | 1895 | ||
1896 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5703 || | 1896 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5703 || |
1897 | GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5704) { | 1897 | GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5704) { |
@@ -2002,8 +2002,8 @@ out: | |||
2002 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x0400); | 2002 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x0400); |
2003 | } | 2003 | } |
2004 | if (tp->tg3_flags2 & TG3_FLG2_PHY_5704_A0_BUG) { | 2004 | if (tp->tg3_flags2 & TG3_FLG2_PHY_5704_A0_BUG) { |
2005 | tg3_writephy(tp, 0x1c, 0x8d68); | 2005 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x8d68); |
2006 | tg3_writephy(tp, 0x1c, 0x8d68); | 2006 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x8d68); |
2007 | } | 2007 | } |
2008 | if (tp->tg3_flags2 & TG3_FLG2_PHY_BER_BUG) { | 2008 | if (tp->tg3_flags2 & TG3_FLG2_PHY_BER_BUG) { |
2009 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x0c00); | 2009 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x0c00); |
@@ -3134,9 +3134,9 @@ static int tg3_setup_copper_phy(struct tg3 *tp, int force_reset) | |||
3134 | tp->pci_chip_rev_id == CHIPREV_ID_5701_B0) { | 3134 | tp->pci_chip_rev_id == CHIPREV_ID_5701_B0) { |
3135 | /* 5701 {A0,B0} CRC bug workaround */ | 3135 | /* 5701 {A0,B0} CRC bug workaround */ |
3136 | tg3_writephy(tp, 0x15, 0x0a75); | 3136 | tg3_writephy(tp, 0x15, 0x0a75); |
3137 | tg3_writephy(tp, 0x1c, 0x8c68); | 3137 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x8c68); |
3138 | tg3_writephy(tp, 0x1c, 0x8d68); | 3138 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x8d68); |
3139 | tg3_writephy(tp, 0x1c, 0x8c68); | 3139 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x8c68); |
3140 | } | 3140 | } |
3141 | 3141 | ||
3142 | /* Clear pending interrupts... */ | 3142 | /* Clear pending interrupts... */ |
@@ -4249,13 +4249,14 @@ static void tg3_serdes_parallel_detect(struct tg3 *tp) | |||
4249 | u32 phy1, phy2; | 4249 | u32 phy1, phy2; |
4250 | 4250 | ||
4251 | /* Select shadow register 0x1f */ | 4251 | /* Select shadow register 0x1f */ |
4252 | tg3_writephy(tp, 0x1c, 0x7c00); | 4252 | tg3_writephy(tp, MII_TG3_MISC_SHDW, 0x7c00); |
4253 | tg3_readphy(tp, 0x1c, &phy1); | 4253 | tg3_readphy(tp, MII_TG3_MISC_SHDW, &phy1); |
4254 | 4254 | ||
4255 | /* Select expansion interrupt status register */ | 4255 | /* Select expansion interrupt status register */ |
4256 | tg3_writephy(tp, 0x17, 0x0f01); | 4256 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, |
4257 | tg3_readphy(tp, 0x15, &phy2); | 4257 | MII_TG3_DSP_EXP1_INT_STAT); |
4258 | tg3_readphy(tp, 0x15, &phy2); | 4258 | tg3_readphy(tp, MII_TG3_DSP_RW_PORT, &phy2); |
4259 | tg3_readphy(tp, MII_TG3_DSP_RW_PORT, &phy2); | ||
4259 | 4260 | ||
4260 | if ((phy1 & 0x10) && !(phy2 & 0x20)) { | 4261 | if ((phy1 & 0x10) && !(phy2 & 0x20)) { |
4261 | /* We have signal detect and not receiving | 4262 | /* We have signal detect and not receiving |
@@ -4275,8 +4276,9 @@ static void tg3_serdes_parallel_detect(struct tg3 *tp) | |||
4275 | u32 phy2; | 4276 | u32 phy2; |
4276 | 4277 | ||
4277 | /* Select expansion interrupt status register */ | 4278 | /* Select expansion interrupt status register */ |
4278 | tg3_writephy(tp, 0x17, 0x0f01); | 4279 | tg3_writephy(tp, MII_TG3_DSP_ADDRESS, |
4279 | tg3_readphy(tp, 0x15, &phy2); | 4280 | MII_TG3_DSP_EXP1_INT_STAT); |
4281 | tg3_readphy(tp, MII_TG3_DSP_RW_PORT, &phy2); | ||
4280 | if (phy2 & 0x20) { | 4282 | if (phy2 & 0x20) { |
4281 | u32 bmcr; | 4283 | u32 bmcr; |
4282 | 4284 | ||
@@ -8337,7 +8339,7 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy) | |||
8337 | if (!tg3_readphy(tp, MII_TG3_TEST1, &tmp)) { | 8339 | if (!tg3_readphy(tp, MII_TG3_TEST1, &tmp)) { |
8338 | tg3_writephy(tp, MII_TG3_TEST1, | 8340 | tg3_writephy(tp, MII_TG3_TEST1, |
8339 | tmp | MII_TG3_TEST1_CRC_EN); | 8341 | tmp | MII_TG3_TEST1_CRC_EN); |
8340 | tg3_readphy(tp, 0x14, &tmp); | 8342 | tg3_readphy(tp, MII_TG3_RXR_COUNTERS, &tmp); |
8341 | } | 8343 | } |
8342 | } | 8344 | } |
8343 | } | 8345 | } |
@@ -9076,7 +9078,7 @@ static u64 calc_crc_errors(struct tg3 *tp) | |||
9076 | if (!tg3_readphy(tp, MII_TG3_TEST1, &val)) { | 9078 | if (!tg3_readphy(tp, MII_TG3_TEST1, &val)) { |
9077 | tg3_writephy(tp, MII_TG3_TEST1, | 9079 | tg3_writephy(tp, MII_TG3_TEST1, |
9078 | val | MII_TG3_TEST1_CRC_EN); | 9080 | val | MII_TG3_TEST1_CRC_EN); |
9079 | tg3_readphy(tp, 0x14, &val); | 9081 | tg3_readphy(tp, MII_TG3_RXR_COUNTERS, &val); |
9080 | } else | 9082 | } else |
9081 | val = 0; | 9083 | val = 0; |
9082 | spin_unlock_bh(&tp->lock); | 9084 | spin_unlock_bh(&tp->lock); |
diff --git a/drivers/net/tg3.h b/drivers/net/tg3.h index 53b6def942bc..d40c380802b0 100644 --- a/drivers/net/tg3.h +++ b/drivers/net/tg3.h | |||
@@ -2057,8 +2057,9 @@ | |||
2057 | #define MII_TG3_EXT_STAT 0x11 /* Extended status register */ | 2057 | #define MII_TG3_EXT_STAT 0x11 /* Extended status register */ |
2058 | #define MII_TG3_EXT_STAT_LPASS 0x0100 | 2058 | #define MII_TG3_EXT_STAT_LPASS 0x0100 |
2059 | 2059 | ||
2060 | #define MII_TG3_RXR_COUNTERS 0x14 /* Local/Remote Receiver Counts */ | ||
2060 | #define MII_TG3_DSP_RW_PORT 0x15 /* DSP coefficient read/write port */ | 2061 | #define MII_TG3_DSP_RW_PORT 0x15 /* DSP coefficient read/write port */ |
2061 | 2062 | #define MII_TG3_DSP_CONTROL 0x16 /* DSP control register */ | |
2062 | #define MII_TG3_DSP_ADDRESS 0x17 /* DSP address register */ | 2063 | #define MII_TG3_DSP_ADDRESS 0x17 /* DSP address register */ |
2063 | 2064 | ||
2064 | #define MII_TG3_DSP_TAP1 0x0001 | 2065 | #define MII_TG3_DSP_TAP1 0x0001 |
@@ -2066,6 +2067,7 @@ | |||
2066 | #define MII_TG3_DSP_AADJ1CH0 0x001f | 2067 | #define MII_TG3_DSP_AADJ1CH0 0x001f |
2067 | #define MII_TG3_DSP_AADJ1CH3 0x601f | 2068 | #define MII_TG3_DSP_AADJ1CH3 0x601f |
2068 | #define MII_TG3_DSP_AADJ1CH3_ADCCKADJ 0x0002 | 2069 | #define MII_TG3_DSP_AADJ1CH3_ADCCKADJ 0x0002 |
2070 | #define MII_TG3_DSP_EXP1_INT_STAT 0x0f01 | ||
2069 | #define MII_TG3_DSP_EXP8 0x0f08 | 2071 | #define MII_TG3_DSP_EXP8 0x0f08 |
2070 | #define MII_TG3_DSP_EXP8_REJ2MHz 0x0001 | 2072 | #define MII_TG3_DSP_EXP8_REJ2MHz 0x0001 |
2071 | #define MII_TG3_DSP_EXP8_AEDW 0x0200 | 2073 | #define MII_TG3_DSP_EXP8_AEDW 0x0200 |