当前位置: 首页 > article >正文

【网络 MAC 学习专栏 -- 如何理解 PHY 的 Link Up】


请阅读【嵌入式开发学习必备专栏 Cache | MMU | AMBA BUS | CoreSight | Trace32 | CoreLink | ARM GCC | CSH】


文章目录

  • Overview
    • Clause 22/Clause 45
      • Clause 22
      • Clause 45
    • PHY Link 状态的软件实现

转自: 开心果 Need Car 2022年10月20日 09:50 上海

Overview

PHY 的主要作用是数/模信号转换,功能等同于其他总线的 Transceiver。所以,uC 如果想发送/接收以太网数据,就需要依赖 PHY(确切说是PHY芯片)。如果想让PHY按照预期的状态工作,uC就需要通过接口告诉PHY如何工作,这个接口是指 MAC(Media Access Control)/PHY 接口。

MAC/PHY的接口关系如下所示:
在这里插入图片描述
MAC 通过接口可以访问 PHY的内部寄存器,进而设置 PHY 的工作模式,以此实现 PHY 的 Link UpMAC访问 PHY内部寄存器,主要通过MDC(Management Data Clock)和MDIO(Management Data Input Output)实现。

手册中描述:PHY内部寄存器的访问,通过 SMA(Station Management Agent)。而SMA中的操作信息来自MAC,所以,两种表达,本质是一个意思。

  • MDC 的最大配置时钟频率为 2.5MHz,用于驱动 MDIO。
  • MDIO 是双向控制线,操作MDIO时,需要基于(Clause 22或者Clause 45)。

Clause 22/Clause 45

Clause 22 或者 Clause 45是什么呢?
答: 一种访问PHY内部寄存器的报文协议。既然是协议,就会有格式要求,Clause 22或者Clause 45格式的各个位域如下所示:
在这里插入图片描述
使用 Clause 22 还是 Clause 45,需要配置 MAC_MDIO_ADDRESS 寄存器的C45E位域,默认情况下,使用 Clause 22,如下所示:
在这里插入图片描述

Clause 22

Clause 22 格式 的位域描述如下所示:
在这里插入图片描述
解释:

  • IDLE:空闲状态,此时MDIO没有时钟驱动;
  • PREAMBLE:前导码,由32个连续的"1"构成;
  • START:起始位域,2 Bit = 01B
  • OPCODE:操作码,2 Bit
    • 10B表述读取PHY寄存器操作,
    • 01B表示写PHY寄存器操作;
  • PHY ADDR:要访问的PHY地址,MAC 最多可以访问 32个PHY,编号0~31
  • REG ADDR:PHY 寄存器地址,最多可以访问 32个PHY寄存器,这里表示要访问哪个PHY寄存器;
  • TA:Turn Around,反转位(2 Bit):
    • 当 SMA读PHY寄存器时,在TA第一个Bit之前,由MAC(SMA)控制MDIO,请求目标PHY寄存器的信息;
    • 在TA第一个Bit之后,由PHY控制MDIO,输出对应PHY寄存器中的信息。这也是MDIO双向的原因,操作时序如下所示:
      在这里插入图片描述
  • DATA:PHY寄存器中的数据信息。
    当 MAC 写 PHY 寄存器时,MDIO 完全由 MAC 控制,操作时序如下所示:
    在这里插入图片描述

Clause 45

Clause45与Clause22的格式一样,只是个别位域信息有所不同,如下所示:
在这里插入图片描述
因此,基于Clause 22或者Clause 45协议,完成对PHY内部寄存器的配置,比如:通信速率(100Mbps/1000Mbps)配置、是否全双工、自协商使能与否(auto-negotiation)、指示灯等。PHY配置完成,且配置成功,意味着:Link Up

PHY Link 状态的软件实现

在软件层面,程序初始化或者Reset以后,需要重新初始化PHY,通过读取PHY寄存器的Link位域确定PHY的Link状态。
eg:RTL8211F(I) BMSR (Basic Mode Status Register, Address 0x01)寄存器,Bit2(Link Status)指示 PHY的Link状态。代码实现示意所示:


boolean PHY_link_Status(void)
{
    boolean linkEstablished = FALSE;
    uint32 value;
    do
    {
      IfxGeth_phy_Clause22_readMDIORegister(0, PH_BMSR, &value);
      linkEstablished = ((value & (1 << 2)) != 0) ? TRUE : FALSE;
    } while (!linkEstablished);

    return linkEstablished;
}

推荐阅读:
https://mp.weixin.qq.com/s/zGwm9DkUHuuuDBwK7hO6vg
https://mp.weixin.qq.com/s/qP6FJvPl5HOkdQWYCstCxw
https://mp.weixin.qq.com/s/HpomnJom2knRo7YACkslBg
https://mp.weixin.qq.com/s/k2cKPkC39jX7YUc7d6U1sw
https://mp.weixin.qq.com/s/dJtMBI9VgefimRZ0_l8GBA


http://www.kler.cn/a/505387.html

相关文章:

  • 升级 SpringBoot3 全项目讲解 — 为什么 SpringBoot3 应该抛弃 Maven,搭配 Gradle 来使用?
  • 【无标题】
  • 【DB-GPT】开启数据库交互新篇章的技术探索与实践
  • C++实现设计模式---抽象工厂模式 (Abstract Factory)
  • Linux内核的启动
  • Python线性混合效应回归LMER分析大鼠幼崽体重数据、假设检验可视化|数据分享...
  • 《数据思维》之数据可视化_读书笔记
  • Mysql 之 阻塞与死锁详解
  • 2025 年将是统一网络安全的一年
  • 港科夜闻 | 香港科大与微软亚洲研究院签署战略合作备忘录,推动医学健康教育及科研协作...
  • 解锁企业数据管理统一身份认证难题,EasyMR助力企业敏捷提效
  • Asp.net 如何使用任务调度
  • Elasticsearch搜索引擎(二)
  • 数据结构《MapSet哈希表》
  • 68_Redis数据结构-QuickList
  • 【make】makefile 函数全解
  • 迅为RK3568开发板篇OpenHarmony配置HDF驱动控制LED-新增 topeet子系统-编写 bundle.json文件
  • 初学stm32 --- SPI驱动25Q128 NOR Flash
  • day08_Kafka
  • C++实现设计模式---状态模式 (State)
  • MySQL程序之:指定程序选项
  • Kotlin 协程基础十 —— 协作、互斥锁与共享变量
  • python 爬虫学习
  • 学习第六十八行
  • 稳定144帧!云游戏体验,ToDesk搭载独立满血显卡
  • MyBatis-XML映射配置