免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 8486 | 回复: 2
打印 上一主题 下一主题

在uboot中通过MDIO/MDC读写PHY的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-23 18:53 |只看该作者 |倒序浏览
本帖最后由 珍源之家 于 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)

论坛徽章:
0
2 [报告]
发表于 2013-05-23 19:31 |只看该作者
自己先顶起

论坛徽章:
0
3 [报告]
发表于 2013-05-23 23:18 |只看该作者
没人做过类似的吗?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP