diff options
-rw-r--r-- | drivers/net/tg3.c | 86 | ||||
-rw-r--r-- | drivers/net/tg3.h | 1 |
2 files changed, 53 insertions, 34 deletions
diff --git a/drivers/net/tg3.c b/drivers/net/tg3.c index e402f162eb81..538232586ee5 100644 --- a/drivers/net/tg3.c +++ b/drivers/net/tg3.c | |||
@@ -1605,7 +1605,7 @@ static void tg3_power_down_phy(struct tg3 *tp) | |||
1605 | tw32_f(GRC_MISC_CFG, val | GRC_MISC_CFG_EPHY_IDDQ); | 1605 | tw32_f(GRC_MISC_CFG, val | GRC_MISC_CFG_EPHY_IDDQ); |
1606 | udelay(40); | 1606 | udelay(40); |
1607 | return; | 1607 | return; |
1608 | } else { | 1608 | } else if (!(tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB)) { |
1609 | tg3_writephy(tp, MII_TG3_EXT_CTRL, | 1609 | tg3_writephy(tp, MII_TG3_EXT_CTRL, |
1610 | MII_TG3_EXT_CTRL_FORCE_LED_OFF); | 1610 | MII_TG3_EXT_CTRL_FORCE_LED_OFF); |
1611 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x01b2); | 1611 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x01b2); |
@@ -1687,18 +1687,22 @@ static int tg3_set_power_state(struct tg3 *tp, pci_power_t state) | |||
1687 | tw32(TG3PCI_MISC_HOST_CTRL, | 1687 | tw32(TG3PCI_MISC_HOST_CTRL, |
1688 | misc_host_ctrl | MISC_HOST_CTRL_MASK_PCI_INT); | 1688 | misc_host_ctrl | MISC_HOST_CTRL_MASK_PCI_INT); |
1689 | 1689 | ||
1690 | if (tp->link_config.phy_is_low_power == 0) { | 1690 | if (tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB) { |
1691 | tp->link_config.phy_is_low_power = 1; | 1691 | tp->link_config.phy_is_low_power = 1; |
1692 | tp->link_config.orig_speed = tp->link_config.speed; | 1692 | } else { |
1693 | tp->link_config.orig_duplex = tp->link_config.duplex; | 1693 | if (tp->link_config.phy_is_low_power == 0) { |
1694 | tp->link_config.orig_autoneg = tp->link_config.autoneg; | 1694 | tp->link_config.phy_is_low_power = 1; |
1695 | } | 1695 | tp->link_config.orig_speed = tp->link_config.speed; |
1696 | tp->link_config.orig_duplex = tp->link_config.duplex; | ||
1697 | tp->link_config.orig_autoneg = tp->link_config.autoneg; | ||
1698 | } | ||
1696 | 1699 | ||
1697 | if (!(tp->tg3_flags2 & TG3_FLG2_ANY_SERDES)) { | 1700 | if (!(tp->tg3_flags2 & TG3_FLG2_ANY_SERDES)) { |
1698 | tp->link_config.speed = SPEED_10; | 1701 | tp->link_config.speed = SPEED_10; |
1699 | tp->link_config.duplex = DUPLEX_HALF; | 1702 | tp->link_config.duplex = DUPLEX_HALF; |
1700 | tp->link_config.autoneg = AUTONEG_ENABLE; | 1703 | tp->link_config.autoneg = AUTONEG_ENABLE; |
1701 | tg3_setup_phy(tp, 0); | 1704 | tg3_setup_phy(tp, 0); |
1705 | } | ||
1702 | } | 1706 | } |
1703 | 1707 | ||
1704 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5906) { | 1708 | if (GET_ASIC_REV(tp->pci_chip_rev_id) == ASIC_REV_5906) { |
@@ -1729,8 +1733,10 @@ static int tg3_set_power_state(struct tg3 *tp, pci_power_t state) | |||
1729 | u32 mac_mode; | 1733 | u32 mac_mode; |
1730 | 1734 | ||
1731 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES)) { | 1735 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES)) { |
1732 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x5a); | 1736 | if (!(tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB)) { |
1733 | udelay(40); | 1737 | tg3_writephy(tp, MII_TG3_AUX_CTRL, 0x5a); |
1738 | udelay(40); | ||
1739 | } | ||
1734 | 1740 | ||
1735 | if (tp->tg3_flags2 & TG3_FLG2_MII_SERDES) | 1741 | if (tp->tg3_flags2 & TG3_FLG2_MII_SERDES) |
1736 | mac_mode = MAC_MODE_PORT_MODE_GMII; | 1742 | mac_mode = MAC_MODE_PORT_MODE_GMII; |
@@ -3821,7 +3827,15 @@ static int tg3_poll_work(struct tg3 *tp, int work_done, int budget) | |||
3821 | sblk->status = SD_STATUS_UPDATED | | 3827 | sblk->status = SD_STATUS_UPDATED | |
3822 | (sblk->status & ~SD_STATUS_LINK_CHG); | 3828 | (sblk->status & ~SD_STATUS_LINK_CHG); |
3823 | spin_lock(&tp->lock); | 3829 | spin_lock(&tp->lock); |
3824 | tg3_setup_phy(tp, 0); | 3830 | if (tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB) { |
3831 | tw32_f(MAC_STATUS, | ||
3832 | (MAC_STATUS_SYNC_CHANGED | | ||
3833 | MAC_STATUS_CFG_CHANGED | | ||
3834 | MAC_STATUS_MI_COMPLETION | | ||
3835 | MAC_STATUS_LNKSTATE_CHANGED)); | ||
3836 | udelay(40); | ||
3837 | } else | ||
3838 | tg3_setup_phy(tp, 0); | ||
3825 | spin_unlock(&tp->lock); | 3839 | spin_unlock(&tp->lock); |
3826 | } | 3840 | } |
3827 | } | 3841 | } |
@@ -6602,7 +6616,8 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy) | |||
6602 | tg3_abort_hw(tp, 1); | 6616 | tg3_abort_hw(tp, 1); |
6603 | } | 6617 | } |
6604 | 6618 | ||
6605 | if (reset_phy) | 6619 | if (reset_phy && |
6620 | !(tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB)) | ||
6606 | tg3_phy_reset(tp); | 6621 | tg3_phy_reset(tp); |
6607 | 6622 | ||
6608 | err = tg3_chip_reset(tp); | 6623 | err = tg3_chip_reset(tp); |
@@ -7153,13 +7168,6 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy) | |||
7153 | tw32_f(MAC_RX_MODE, tp->rx_mode); | 7168 | tw32_f(MAC_RX_MODE, tp->rx_mode); |
7154 | udelay(10); | 7169 | udelay(10); |
7155 | 7170 | ||
7156 | if (tp->link_config.phy_is_low_power) { | ||
7157 | tp->link_config.phy_is_low_power = 0; | ||
7158 | tp->link_config.speed = tp->link_config.orig_speed; | ||
7159 | tp->link_config.duplex = tp->link_config.orig_duplex; | ||
7160 | tp->link_config.autoneg = tp->link_config.orig_autoneg; | ||
7161 | } | ||
7162 | |||
7163 | tp->mi_mode &= ~MAC_MI_MODE_AUTO_POLL; | 7171 | tp->mi_mode &= ~MAC_MI_MODE_AUTO_POLL; |
7164 | tw32_f(MAC_MI_MODE, tp->mi_mode); | 7172 | tw32_f(MAC_MI_MODE, tp->mi_mode); |
7165 | udelay(80); | 7173 | udelay(80); |
@@ -7210,19 +7218,28 @@ static int tg3_reset_hw(struct tg3 *tp, int reset_phy) | |||
7210 | tw32(GRC_LOCAL_CTRL, tp->grc_local_ctrl); | 7218 | tw32(GRC_LOCAL_CTRL, tp->grc_local_ctrl); |
7211 | } | 7219 | } |
7212 | 7220 | ||
7213 | err = tg3_setup_phy(tp, 0); | 7221 | if (!(tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB)) { |
7214 | if (err) | 7222 | if (tp->link_config.phy_is_low_power) { |
7215 | return err; | 7223 | tp->link_config.phy_is_low_power = 0; |
7224 | tp->link_config.speed = tp->link_config.orig_speed; | ||
7225 | tp->link_config.duplex = tp->link_config.orig_duplex; | ||
7226 | tp->link_config.autoneg = tp->link_config.orig_autoneg; | ||
7227 | } | ||
7216 | 7228 | ||
7217 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES) && | 7229 | err = tg3_setup_phy(tp, 0); |
7218 | GET_ASIC_REV(tp->pci_chip_rev_id) != ASIC_REV_5906) { | 7230 | if (err) |
7219 | u32 tmp; | 7231 | return err; |
7220 | 7232 | ||
7221 | /* Clear CRC stats. */ | 7233 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES) && |
7222 | if (!tg3_readphy(tp, MII_TG3_TEST1, &tmp)) { | 7234 | GET_ASIC_REV(tp->pci_chip_rev_id) != ASIC_REV_5906) { |
7223 | tg3_writephy(tp, MII_TG3_TEST1, | 7235 | u32 tmp; |
7224 | tmp | MII_TG3_TEST1_CRC_EN); | 7236 | |
7225 | tg3_readphy(tp, 0x14, &tmp); | 7237 | /* Clear CRC stats. */ |
7238 | if (!tg3_readphy(tp, MII_TG3_TEST1, &tmp)) { | ||
7239 | tg3_writephy(tp, MII_TG3_TEST1, | ||
7240 | tmp | MII_TG3_TEST1_CRC_EN); | ||
7241 | tg3_readphy(tp, 0x14, &tmp); | ||
7242 | } | ||
7226 | } | 7243 | } |
7227 | } | 7244 | } |
7228 | 7245 | ||
@@ -9644,7 +9661,8 @@ static int tg3_test_loopback(struct tg3 *tp) | |||
9644 | tw32(TG3_CPMU_MUTEX_GNT, CPMU_MUTEX_GNT_DRIVER); | 9661 | tw32(TG3_CPMU_MUTEX_GNT, CPMU_MUTEX_GNT_DRIVER); |
9645 | } | 9662 | } |
9646 | 9663 | ||
9647 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES)) { | 9664 | if (!(tp->tg3_flags2 & TG3_FLG2_PHY_SERDES) && |
9665 | !(tp->tg3_flags3 & TG3_FLG3_USE_PHYLIB)) { | ||
9648 | if (tg3_run_loopback(tp, TG3_PHY_LOOPBACK)) | 9666 | if (tg3_run_loopback(tp, TG3_PHY_LOOPBACK)) |
9649 | err |= TG3_PHY_LOOPBACK_FAILED; | 9667 | err |= TG3_PHY_LOOPBACK_FAILED; |
9650 | } | 9668 | } |
diff --git a/drivers/net/tg3.h b/drivers/net/tg3.h index 5643be55c1d1..a3598ed9f5fc 100644 --- a/drivers/net/tg3.h +++ b/drivers/net/tg3.h | |||
@@ -2480,6 +2480,7 @@ struct tg3 { | |||
2480 | #define TG3_FLG3_ENABLE_APE 0x00000002 | 2480 | #define TG3_FLG3_ENABLE_APE 0x00000002 |
2481 | #define TG3_FLG3_5761_5784_AX_FIXES 0x00000004 | 2481 | #define TG3_FLG3_5761_5784_AX_FIXES 0x00000004 |
2482 | #define TG3_FLG3_5701_DMA_BUG 0x00000008 | 2482 | #define TG3_FLG3_5701_DMA_BUG 0x00000008 |
2483 | #define TG3_FLG3_USE_PHYLIB 0x00000010 | ||
2483 | 2484 | ||
2484 | struct timer_list timer; | 2485 | struct timer_list timer; |
2485 | u16 timer_counter; | 2486 | u16 timer_counter; |