aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorStephen Hemminger <shemminger@osdl.org>2006-09-26 14:57:37 -0400
committerJeff Garzik <jeff@garzik.org>2006-09-27 17:56:31 -0400
commite0ed5459030a8c9ddde44ef49bcb63aa6db425e1 (patch)
tree891a90b0c112422800bac597fa269b07165eca1a /drivers/net
parent0ba8821b12231386c8c1d506c682061f7225ae49 (diff)
[PATCH] sky2: gigabit full duplex negotiation
Look at the registers correctly, when doing gigabit full duplex. Need to look for link partner result. Signed-off-by: Stephen Hemminger <shemminger@osdl.org> Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/sky2.c29
1 files changed, 20 insertions, 9 deletions
diff --git a/drivers/net/sky2.c b/drivers/net/sky2.c
index 7eeefa2d6c89..3ff2f426fd63 100644
--- a/drivers/net/sky2.c
+++ b/drivers/net/sky2.c
@@ -1624,22 +1624,33 @@ static int sky2_autoneg_done(struct sky2_port *sky2, u16 aux)
1624 return -1; 1624 return -1;
1625 } 1625 }
1626 1626
1627 if (hw->chip_id != CHIP_ID_YUKON_FE &&
1628 gm_phy_read(hw, port, PHY_MARV_1000T_STAT) & PHY_B_1000S_MSF) {
1629 printk(KERN_ERR PFX "%s: master/slave fault",
1630 sky2->netdev->name);
1631 return -1;
1632 }
1633
1634 if (!(aux & PHY_M_PS_SPDUP_RES)) { 1627 if (!(aux & PHY_M_PS_SPDUP_RES)) {
1635 printk(KERN_ERR PFX "%s: speed/duplex mismatch", 1628 printk(KERN_ERR PFX "%s: speed/duplex mismatch",
1636 sky2->netdev->name); 1629 sky2->netdev->name);
1637 return -1; 1630 return -1;
1638 } 1631 }
1639 1632
1640 sky2->duplex = (aux & PHY_M_PS_FULL_DUP) ? DUPLEX_FULL : DUPLEX_HALF;
1641
1642 sky2->speed = sky2_phy_speed(hw, aux); 1633 sky2->speed = sky2_phy_speed(hw, aux);
1634 if (sky2->speed == SPEED_1000) {
1635 u16 ctl2 = gm_phy_read(hw, port, PHY_MARV_1000T_CTRL);
1636 u16 lpa2 = gm_phy_read(hw, port, PHY_MARV_1000T_STAT);
1637 if (lpa2 & PHY_B_1000S_MSF) {
1638 printk(KERN_ERR PFX "%s: master/slave fault",
1639 sky2->netdev->name);
1640 return -1;
1641 }
1642
1643 if ((ctl2 & PHY_M_1000C_AFD) && (lpa2 & PHY_B_1000S_LP_FD))
1644 sky2->duplex = DUPLEX_FULL;
1645 else
1646 sky2->duplex = DUPLEX_HALF;
1647 } else {
1648 u16 adv = gm_phy_read(hw, port, PHY_MARV_AUNE_ADV);
1649 if ((aux & adv) & PHY_AN_FULL)
1650 sky2->duplex = DUPLEX_FULL;
1651 else
1652 sky2->duplex = DUPLEX_HALF;
1653 }
1643 1654
1644 /* Pause bits are offset (9..8) */ 1655 /* Pause bits are offset (9..8) */
1645 if (hw->chip_id == CHIP_ID_YUKON_XL || hw->chip_id == CHIP_ID_YUKON_EC_U) 1656 if (hw->chip_id == CHIP_ID_YUKON_XL || hw->chip_id == CHIP_ID_YUKON_EC_U)