在uboot中通过MDIO/MDC读写PHY的问题
本帖最后由 珍源之家 于 2013-05-23 18:56 编辑我在uboot中想通过MDC/MDIO方式来读写PHY,网卡型号是AX88172A。如下图:
在写代码的时候参考了uboot中原有的MPC8270的做法,其中在操作MDC或者MDIO的时候,用到了以下的宏(我的疑问都在对应代码的//注释后面,向大家请教一下,在这里先谢谢了!我的MDC和MDIO分别用pin44和pin43):
#define CONFIG_SYS_BCSR 0xFA000000//这个值不知道是如何得到的???
/*
* GPIO pins used for bit-banged MII communications
*/
#define MDIO_PORT 0 /* Not used - implemented in BCSR */
#define MDIO_ACTIVE (*(vu_char *)(CONFIG_SYS_BCSR + 8 ) &= 0xFB) //对MDIO线做激活的时候原理是怎样的???
#define MDIO_TRISTATE (*(vu_char *)(CONFIG_SYS_BCSR + 8 ) |= 0x04)//对MDIO线做三态的时候原理又是如何的???
#define MDIO_READ (*(vu_char *)(CONFIG_SYS_BCSR + 8 ) & 1) //通过MDIO来读数据的时候原理又是怎样的???
#define MDIO(bit) if(bit) *(vu_char *)(CONFIG_SYS_BCSR + 8 ) |= 0x01; \ //这里是对MDIO线做拉高?
else *(vu_char *)(CONFIG_SYS_BCSR + 8 ) &= 0xFE//这里是对MDIO线做拉低?
#define MDC(bit) if(bit) *(vu_char *)(CONFIG_SYS_BCSR + 8 ) |= 0x02; \ //这里是对MDC做拉高?
else *(vu_char *)(CONFIG_SYS_BCSR + 8 ) &= 0xFD //这里是对MDC做拉低?
#define MIIDELAY udelay(1)
自己先顶起 没人做过类似的吗?
页:
[1]