aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKen Kawasaki <ken_kawasaki@spring.nifty.jp>2009-04-04 10:49:07 -0400
committerDavid S. Miller <davem@davemloft.net>2009-04-06 20:07:54 -0400
commitad3620a072bc1ba93b0146f6f5467ae928b449a6 (patch)
tree4fcde271fe0a8c55d31ca2eacff822bfd88c3e7c
parent57579f7629a3d46c307405fbd2ea6bdb650d692f (diff)
axnet_cs: fix phy_id detection for bogus Asix chip.
axnet_cs: (1) Some Asix phy return bogus value except 0 or 0xffff. Skip this phy_id. (2) Some Asix chip need to set "select Internal PHY" bit at AX88190_init. Signed-off-by: Ken Kawasaki <ken_kawasaki@spring.nifty.jp> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--drivers/net/pcmcia/axnet_cs.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/net/pcmcia/axnet_cs.c b/drivers/net/pcmcia/axnet_cs.c
index 501a8d7ac2be..15b8fe61695b 100644
--- a/drivers/net/pcmcia/axnet_cs.c
+++ b/drivers/net/pcmcia/axnet_cs.c
@@ -339,7 +339,7 @@ static int axnet_config(struct pcmcia_device *link)
339{ 339{
340 struct net_device *dev = link->priv; 340 struct net_device *dev = link->priv;
341 axnet_dev_t *info = PRIV(dev); 341 axnet_dev_t *info = PRIV(dev);
342 int i, j, last_ret, last_fn; 342 int i, j, j2, last_ret, last_fn;
343 343
344 DEBUG(0, "axnet_config(0x%p)\n", link); 344 DEBUG(0, "axnet_config(0x%p)\n", link);
345 345
@@ -388,6 +388,8 @@ static int axnet_config(struct pcmcia_device *link)
388 388
389 for (i = 0; i < 32; i++) { 389 for (i = 0; i < 32; i++) {
390 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1); 390 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1);
391 j2 = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 2);
392 if (j == j2) continue;
391 if ((j != 0) && (j != 0xffff)) break; 393 if ((j != 0) && (j != 0xffff)) break;
392 } 394 }
393 395
@@ -398,6 +400,8 @@ static int axnet_config(struct pcmcia_device *link)
398 pcmcia_access_configuration_register(link, &reg); 400 pcmcia_access_configuration_register(link, &reg);
399 for (i = 0; i < 32; i++) { 401 for (i = 0; i < 32; i++) {
400 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1); 402 j = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 1);
403 j2 = mdio_read(dev->base_addr + AXNET_MII_EEP, i, 2);
404 if (j == j2) continue;
401 if ((j != 0) && (j != 0xffff)) break; 405 if ((j != 0) && (j != 0xffff)) break;
402 } 406 }
403 } 407 }
@@ -1767,6 +1771,9 @@ static void AX88190_init(struct net_device *dev, int startp)
1767 ei_local->tx1 = ei_local->tx2 = 0; 1771 ei_local->tx1 = ei_local->tx2 = 0;
1768 ei_local->txing = 0; 1772 ei_local->txing = 0;
1769 1773
1774 if (info->flags & IS_AX88790) /* select Internal PHY */
1775 outb(0x10, e8390_base + AXNET_GPIO);
1776
1770 if (startp) 1777 if (startp)
1771 { 1778 {
1772 outb_p(0xff, e8390_base + EN0_ISR); 1779 outb_p(0xff, e8390_base + EN0_ISR);