这两天改动网卡驱动以实现10/100/1000M自适应,因此研究了下phy芯片和emac驱动怎样兼容10/100/1000M网络环境,记录在此。

网络中设备端数据链路层由mac芯片和phy芯片组成。phy芯片依据外部网络环境完毕自己主动协商以及配置。驱动中依据phy状态来配置mac。以达到phy与mac的相互配合工作。
如今主流的网卡phy芯片为100M和1000M,都是向下兼容。100M phy支持10/100M环境,1000M phy支持10/100/1000M环境。

首先说10/100/1000M都是指的数据收发速率,单位是bps。所以这里要从mac以及phy的数据收发接口下手。

mac与phy主流数据接口有GMII MII RMII等。接口规范中定义了数据收发信号线个数。

接口定义能够看这篇文章:
http://blog.csdn.net/skyflying2012/article/details/8252843

以GMII/MII为例来研究。GMII是有8根rx/tx线,MII有4根rx/tx线。
首先以外接100Mphy芯片来研究。

phy与外界网络环境完毕自己主动协商来确定其本身的速度。100M phy都支持MII接口。因此mac端就须要以MII接口定义与phy相连。
数据收发最重要的是提供正确的数据时钟。来保证数据正确的採样与发送。
对于100M phy,这个问题好解决,由于MII接口支持10/100M。4根数据线,仅仅须要mac给phy提供2.5/25MHZ数据时钟就可以。

最值得研究的是外接1000M phy时怎样适应10/100/1000M网络环境。

首先说,这是一个倒推的过程,首先来看phy是怎样处理10/100M和1000M环境的。mac的接口模式以及时钟再依据phy的配置进行配置。

随便找了一个1000M phy芯片的datasheet。RTL88E1111,对于GMII/MII接口的描写叙述例如以下:

依据这段描写叙述看出,GMII接口模式支持1000M环境,可是在10/100M环境下phy完毕自己主动协商确定为10/100BASE-TX后就切换为MII模式。GMII引脚都是与MII兼容的(MII下8根数据线有4根不用)。GMII接口定义中有2个clk线,GTX_CLK TX_CLK(GMII/MII下rx clk由phy提供),GTX_CLK在GMII模式下提供125MHZ,TX_CLK在MII模式下提供2.5/25MHZ。

以下给出一个mac与1000M phy硬件电路连接图。

能够看出对于1000M phy,GTX_CLK TX_CLK都须要与mac相连,在10/100/1000M环境下我分别用示波器測量clk的确如上所说。

综上,

对于100M phy。外部网络10/100M切换,仅须要改变mac提供的数据时钟就可以,mac接口模式不变,由于MII兼容10/100M。

对于1000M phy,外部网络10/100/1000M切换,首先须要改变mac的接口模式(使用的数据线个数不同了),由于10/100M下phy会切换为MII模式,依据接口模式在改变其数据时钟。

当然phy在自己主动协商完毕后是其硬件逻辑会完毕模式GMII/MII的转换,而对于mac,则要由驱动依据phy的工作状态来确定mac的接口模式以及须要提供的clk。
这也是我们软件开发者最须要关注的地方,依据phy的状态。怎样配置mac(接口模式 数据时钟)来保证与phy一致。

mac与phy怎样实现网络自适应的更多相关文章

  1. 转!!MAC和PHY的区别

    一块以太网网卡包括OSI(开方系统互联)模型的两个层,物理层和数据链路层.物理层定义了数据传送与接收所需要的电与光信号.线路状态.时钟基准.数据编码和电路等,并向数据链路层设备提供标准接口.数据链路层 ...

  2. 网卡及MAC和PHY的区别

    转载:http://blog.sina.com.cn/s/blog_53d7350f0100mudb.html 一块以太网网卡包括OSI(开方系统互联)模型的两个层.物理层和数据链路层.物理层定义了数 ...

  3. 网口扫盲三:以太网芯片MAC和PHY的关系

    转载:http://www.cnblogs.com/jason-lu/articles/3195473.html   问:如何实现单片以太网微控制器? 答:诀窍是将微控制器.以太网媒体接入控制器(MA ...

  4. 网口扫盲三:以太网芯片MAC和PHY的关系(转)

      问:如何实现单片以太网微控制器? 答:诀窍是将微控制器.以太网媒体接入控制器(MAC)和物理接口收发器(PHY)整合进同一芯片,这样能去掉许多外接元器件.这种方案可使MAC和PHY实现很好的匹配, ...

  5. MAC和PHY的区别 (转自http://www.cnblogs.com/feitian629/archive/2013/01/25/2876857.html)

    一块以太网网卡包括OSI(开方系统互联)模型的两个层.物理层和数据链路层.物理层定义了数据传送与接收所需要的电与光信号.线路状态.时钟基准.数据编码和电路等,并向数据链路层设备提供标准接口.数据链路层 ...

  6. MAC和PHY的区别

    一块以太网网卡包括OSI(开方系统互联)模型的两个层.物理层和数据链路层.物理层定义了数据传送与接收所需要的电与光信号.线路状态.时钟基准.数据编码和电路等,并向数据链路层设备提供标准接口.数据链路层 ...

  7. 有关MAC、PHY和MII

    这是一篇转载,原文链接:http://www.cppblog.com/totti1006/archive/2008/04/22/47829.html 以太网(Ethernet)是一种计算机局域网组网技 ...

  8. MAC和PHY的区别(网线上传递的是模拟信号)

    一块以太网网卡包括OSI(开方系统互联)模型的两个层.物理层和数据链路层.物理层定义了数据传送与接收所需要的电与光信号.线路状态.时钟基准.数据编码和电路等,并向数据链路层设备提供标准接口.数据链路层 ...

  9. Mac与Phy组成原理的简单分析

    1. general 下图是网口结构简图.网口由CPU.MAC和PHY三部分组成.DMA控制器通常属于CPU的一部分,用虚线放在这里是为了表示DMA控制器可能会参与到网口数据传输中. 对于上述的三部分 ...

随机推荐

  1. linux后台启动命令-的原因

    linux后台启动命令-的原因 学习了:https://blog.csdn.net/saife/article/details/78276014 学习了:https://www.ibm.com/dev ...

  2. Web应用——驾培管理系统之个人管理(作者:小圣)

    Web应用--驾培管理系统之个人管理(作者:小圣) 本节博文旨在实现本次Web应用的个人管理功能.能够在登陆后 查看并改动个人信息或者进行password改动.同一时候,在输入的时候进行表单验证,验证 ...

  3. Win7如何改变用户文件夹位置

    现在装WIN7后第一件就是改变用户账户文件夹位置..因为里面存着一些软件的设定和信息等..不必要每次装后都手动改一次.. 已前用优化大师改.太麻烦.也不稳定有时有些目录不能完全改过来.. 通过命令mk ...

  4. 怎样实现广度优先遍历(BFS)

    BFS过程: 一:訪问顶点V,并标记V为已经訪问 二:顶点V入队列 三:假设队列非空.进行运行,否则算法结束 四:出队列取得对头顶点u,假设顶点未被訪问,就訪问该顶点,并标记该顶点为已经訪问 五:查找 ...

  5. C++11 Lambda表达式简单解析

    C++11 新增了非常多特性,lambda 表达式是当中之中的一个.假设你想了解的 C++11 完整特性, 建议去http://www.open-std.org/看看新标准! 非常多语言都提供了 la ...

  6. 聚合数据全国天气预报API--ajax 通过城市名取数据

    聚合数据天气预报API:https://www.juhe.cn/docs/api/id/39 接口地址:http://v.juhe.cn/weather/index 支持格式:json/xml 请求方 ...

  7. How to get the url of a page in OpenERP?

    How to get the url of a page in OpenERP? User is using OpenERP. I have a button on one web page. The ...

  8. hadoop native本地库问题总结

    近期,打算hbase建表用snappy压缩时,碰到一些hadoop本地库的问题. 事实上这些问题是一直存在的,仅仅是不影响正常使用,就没有引起重视. 这次希望彻底解决下面问题: 问题一:运行start ...

  9. 基于Jekyll的博客模板

    代码地址如下:http://www.demodashi.com/demo/13147.html 效果 环境配置 环境 Windows 10 Git Bash 安装ruby 下载rubyinstalle ...

  10. iOS 自定义转场动画浅谈

    代码地址如下:http://www.demodashi.com/demo/11612.html 路漫漫其修远兮,吾将上下而求索 前记 想研究自定义转场动画很久了,时间就像海绵,挤一挤还是有的,花了差不 ...