移植Linux内核到s3c6410(板子u-boot网口link-down问题解决)

uImage/ramdisk准备好后,准备tftp到单板上小式一把,结果将单板停在uboot后,网口一直link down,ping host后还打印“could not establish link”。真是抑郁啊。

细想,板子回来后,在uImage起来后,我是验证过网口的,是OK的,所以硬件应该没啥问题,应该是u-boot的支持问题。研究一下ping的流程:

do_ping-->NetLoop(PING)-->eth_halt-->eth_init-->PingStart-->PingSend-->ArpRequest-->eth_rx-->NetReceive-->eth_send-->eth_rx-->NetReceive-->NETLOOP_SUCCESS-->eth_halt。

do_ping-->NetLoop(PING)-->eth_halt-->eth_init

初始化网口,准备发包,

PingStart-->PingSend-->ArpRequest-->eth_rx-->NetReceive

请求arp包,一直等待收arp响应包,并设置5S超时。

eth_send-->eth_rx-->NetReceive-->NETLOOP_SUCCESS-->eth_halt。

如果收到arp响应,发出ping包,等待收包,ping为10S超时,收包或者超时都调用eth_halt。

DM9000,eth_init-->dm9000_reset-->DM9000_iow(DM9000_GPR, 0);里面会power up DM9000 内置的phy,这个时候会linkup。

eth_halt-->DM9000_iow(DM9000_GPR, 0x01); /* Power-Down PHY */里面会power down DM9000 内置的phy,这个时候会linkdown。

也就是说当执行ping或者tftp是,才会触发eth_init,这个时候网口才会linkup,执行完成后会调用eth_halt,这个时候网口会link down。

但是我的板子是执行ping后,还是不能link-up,且打印could not establish link,查阅代码是:

 while (!(phy_read(1) & 0x20)) { /* autonegation complete bit */
  udelay(1000);
  i++;
  if (i == 10000) {
   printf("could not establish link\n");
   return 0;
  }
 }

也就是eth_init之后10S还没有自协商成功。后来我决定手动将其power up试一下,也就是在u-boot里执行:

nm.b 0x18000300 回车
1f回车
nm.b 0x18000304 回车
0 回车

phy link up 了,而且此时执行ping后,能够正常ping通,tftp也能正常进行了。

相关推荐