Intel82541 Phy和MAC的初始化.rtf

       82541上电复位时候,82541会根据默认的寄存器配置初始化自己。如果有 EEPROM ,会根据 EEPROM 的配置字来初始化自己并立即进行自适应。

       可以通过 GMII MII 接口来控制 PHY 进行 link 配置。

        当不能自适应 link 的时候,必需使用软件去配置 link

        下面将研究内部对 PHY link 设置问题:

 

自协商:

        自协商是两个接口间相互交换信息。来达到接口通信速率,全双工/半双工,流控的对应。

        当在 MAC 上设置了流控,那么必需重启 phy 来重新完成自协商。

        当自协商完成之后,软件必需读取 PHY 中的 MII 寄存器来获取流控的协商情况,并将这些情况设置到 MAC CTRL 寄存器的

TFCE 和 RFCE 字段上。当自适应完成,软件必需设置 CTRL . SLU “ set link up 。设置这个位来使 MAC 正确判断 PHY 发过来的

LINK 信号。这样表明 phy 可以接受和发送数据了。

 

link Speed

        可以使用软件强制配置 link speed

        软件可以通过 CTRL . FRCSPD 位来强制设置 link speed ,强制的速度在 CTRL.SPEED 位进行设置。

       

       

        MAC 强制设置了一个速度之后,软件还必需确保 PHY 中配置的速度也要相同。

        设置完 CTRL.SPEED 之后,还要设置 CTRL_EXT.SPD_BYPS ,使得网卡设置为这个速度( MAC PHY 都同步速度了?? )。

       

      

       

        自动探测来自 PHY 自协商的来的 speed

        可以通过设置 CTRL.ASDE 来自动获得 phy link 的 speed ,并且根据这个速度自动设置控制和状态寄存器。

                STATUS.ASDV[9:8]会获得取得的speed(通过CTRL_EXT.ASDCHK 来激活这个 STATUS.ASDV 功能)。

      

       软件还必需设置 CTRL.SLU 位来使以上的工作生效

      

 

       

        当 CTRL.FRCSPD= 0 的时候, speed 会随时被一次新的 link 来更新。当被设置为自协商的时候,强烈推荐清0这个位

      

       全双工/半双工的设置:

            这个可以通过自协商来获得,当 CTRL.FRCDPLX 被设置时,软件可以通过 CTRL.FD 来改变协商的来的状态。

 

       

        关于强制 link 的说明:

                当初始化的时候。先设置 MAC 的值( speed , Duplex ,和流控),之后访问 Phy 的寄存器,并配置和 MAC 的一样。

                采用内部 phy 时,设置 CTRL.SLU 位在 MAC 层产生一次 link up 。 Duplex 也在这时使用 CTRL.FD 位来设置。

             

 

下面的图指出了使用内部Phy 并且设置了自协商时, MAC 的寄存器应该如何设置。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

goodlinux

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值