[PATCH] sky2: speed setting fix
Users report problems w/ auto-negotiation disabled and the link set to 100/Half or 10/Half. Problems range from poor performance to no link at all. The current sky2 code does not set things properly on link up if autonegotiation is disabled. Plus it does not contemplate a 10Mbit setting at all. This patch corrects that. Signed-off-by: John W. Linville <linville@tuxdriver.com> Signed-off-by: Stephen Hemminger <shemminger@osdl.org> Signed-off-by: Jeff Garzik <jgarzik@pobox.com>
This commit is contained in:
Родитель
564f9abb34
Коммит
6f4c56b2ae
|
@ -520,10 +520,16 @@ static void sky2_mac_init(struct sky2_hw *hw, unsigned port)
|
||||||
|
|
||||||
switch (sky2->speed) {
|
switch (sky2->speed) {
|
||||||
case SPEED_1000:
|
case SPEED_1000:
|
||||||
|
reg &= ~GM_GPCR_SPEED_100;
|
||||||
reg |= GM_GPCR_SPEED_1000;
|
reg |= GM_GPCR_SPEED_1000;
|
||||||
/* fallthru */
|
break;
|
||||||
case SPEED_100:
|
case SPEED_100:
|
||||||
|
reg &= ~GM_GPCR_SPEED_1000;
|
||||||
reg |= GM_GPCR_SPEED_100;
|
reg |= GM_GPCR_SPEED_100;
|
||||||
|
break;
|
||||||
|
case SPEED_10:
|
||||||
|
reg &= ~(GM_GPCR_SPEED_1000 | GM_GPCR_SPEED_100);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sky2->duplex == DUPLEX_FULL)
|
if (sky2->duplex == DUPLEX_FULL)
|
||||||
|
@ -1446,6 +1452,29 @@ static void sky2_link_up(struct sky2_port *sky2)
|
||||||
sky2_write8(hw, SK_REG(port, GMAC_IRQ_MSK), GMAC_DEF_MSK);
|
sky2_write8(hw, SK_REG(port, GMAC_IRQ_MSK), GMAC_DEF_MSK);
|
||||||
|
|
||||||
reg = gma_read16(hw, port, GM_GP_CTRL);
|
reg = gma_read16(hw, port, GM_GP_CTRL);
|
||||||
|
if (sky2->autoneg == AUTONEG_DISABLE) {
|
||||||
|
reg |= GM_GPCR_AU_ALL_DIS;
|
||||||
|
|
||||||
|
/* Is write/read necessary? Copied from sky2_mac_init */
|
||||||
|
gma_write16(hw, port, GM_GP_CTRL, reg);
|
||||||
|
gma_read16(hw, port, GM_GP_CTRL);
|
||||||
|
|
||||||
|
switch (sky2->speed) {
|
||||||
|
case SPEED_1000:
|
||||||
|
reg &= ~GM_GPCR_SPEED_100;
|
||||||
|
reg |= GM_GPCR_SPEED_1000;
|
||||||
|
break;
|
||||||
|
case SPEED_100:
|
||||||
|
reg &= ~GM_GPCR_SPEED_1000;
|
||||||
|
reg |= GM_GPCR_SPEED_100;
|
||||||
|
break;
|
||||||
|
case SPEED_10:
|
||||||
|
reg &= ~(GM_GPCR_SPEED_1000 | GM_GPCR_SPEED_100);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
reg &= ~GM_GPCR_AU_ALL_DIS;
|
||||||
|
|
||||||
if (sky2->duplex == DUPLEX_FULL || sky2->autoneg == AUTONEG_ENABLE)
|
if (sky2->duplex == DUPLEX_FULL || sky2->autoneg == AUTONEG_ENABLE)
|
||||||
reg |= GM_GPCR_DUP_FULL;
|
reg |= GM_GPCR_DUP_FULL;
|
||||||
|
|
||||||
|
|
Загрузка…
Ссылка в новой задаче