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 的寄存器应该如何设置。