Xilinx 千兆以太网TEMAC IP核 MDIO 配置及物理接口

2024-05-12 11:44

本文主要是介绍Xilinx 千兆以太网TEMAC IP核 MDIO 配置及物理接口,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于AXI4-Lite接口可以访问MDIO(Management Data Input/Output)接口,而MDIO接口连接MAC外部的PHY芯片,用户可通过AXI4-Lite接口实现对PHY芯片的配置。

1 MDIO接口简介

开放系统互连模型OSI的最低两层分别是数据链路层和物理层,数据链路层的主要功能包括数据帧的构建、数据差错检查、发送控制和向网络层提供标准的数据接口等;物理层定义了数据发送与接收所需要的电与光信号、线路状态、时钟基准、数据编码和电路等,支持向数据链路层设备提供标准接口。以太网的PHY(物理层)提供传输介质并与MAC层进行连接,将数据转换为光或电信号,而MAC需要配置PHY器件寄存器信息,以保证PHY器件按照使用需求收发数据。

MAC对PHY器件工作状态的确定和对PHY器件的控制是使用MDIO接口读/写 PHY器件的寄存器来完成的。PHY器件的寄存器的地址空间为5位,地址从0到31最多可以定义32个寄存器。IEEE802.3定义了地址为0~15这16个寄存器的功能,地址为16~31的寄存器留给芯片制造商自由定义。PHY器件的状态反映在寄存器内,MAC通过MDIO总线不断读取PHY器件的状态寄存器以得知PHY器件当前的状态,如连接速度、双工能力等。

MAC对PHY器件设定的控制管理内容包括:工作速率,10/100/1000Mbps固定速率或自动协商速率;传输介质,光纤或铜线连接物理层设备;工作模式,光纤连接的TBI模式,铜线连接的MII、GMII等模式。MDIO接口正是用于传输MAC对PHY器件控制管理信息的模块,其应用环境如图1所示。

479e9d8c6ab546a58fe972e7f5944e8a.png

图1 MDIO接口的应用环境

2 MDIO接口信号定义

MDIO接口的应用协议由IEEE802.3标准定义,接口信号包括管理数据时钟(MDC)和MDIO管理数据。

(1)管理数据时钟(MDC)

MDC由MAC驱动,作为MDIO信号线上的时序参考输出到PHY器件。协议定义了MDC的最高工作频率不超过2.5MHz。

(2)MDIO 管理数据

MDIO管理数据是MAC与PHY器件之间的双向串行数据,它被用于传输两者间的状态信息和控制信息。其中,控制信息由MAC产生并与MDC同步,以供PHY器件采样;状态信息由PHY器件驱动,以供MAC读取。

(3)数据帧定义

MDIO接口上的信息是以数据帧的形式进行传输的,MDIO接口数据帧格式如表1所示。

表1 MDIO 接口数据帧格式

2a0f1353b67a4d4faa802d304d0a5e9b.png

● PRE 为帧同步码,MAC向PHY器件发送32个连续的“1”用于器件的同步通信(需要注意的是,该域不是必需的,部分PHY器件的MDIO操作没有PRE)。

● ST 为帧开始标志,MAC输出“01”通知PHY器件帧传输开始。

● OP为帧操作码,“01”表示该帧为1次写操作请求,“10”表示该帧为1次读操作请求。

● PHYAD为PHY器件地址,5bit宽,即一个MDIO总线最多可以外加32(25)个PHY器件。每个PHY器件都把自己的地址与PHYAD进行比较,若匹配则响应后续操作,若不匹配则忽略后续操作。

● REGAD为PHY器件寄存器地址,5bit宽,用于选择PHY器件内部的32个寄存器中的某一个寄存器的地址。

● TA 为状态转换域,2比特。读操作时,第1比特由MDIO模块送出的高阻态来进行设置,第2比特由PHY芯片置为“0”,即“Z0”。写操作时,MDIO信号由MDIO模块控制,输出“10”。

● DATA 为帧寄存器数据域,16比特。读操作时为PHY器件送到MDIO模块的串行数据,写操作时为MDIO模块送到PHY器件的串行数据。

● IDLE为帧结束后的空闲状态,此时是高阻态。由于主从双方共享双向总线,所以一方在控制帧发送完成以后,需迅速将信号置于高阻态,便于其他方占用。

3 TEMAC核中的MDIO控制

TEMAC核的MDIO总线系统为主从结构,如图2所示。TEMAC核作为主机, PHY器件作为从设备,主机通过MDIO总线发出修改寄存器配置和访问状态寄存器的请求,从设备必须对主机的请求做出响应。

a9cf365e44cb47cdb2281ea9c9da0f10.png

图2 MDIO总线系统示例

(1)MDIO 接口的读/写时序

读/写过程由MDIO管理数据帧实现,且由工作在主模式的MDIO初始化,所有工作在从模式的MDIO只要被选中就必须做出应答。MDIO详细说明请参考IEEE802.3标准。如图3所示为MDIO写时序,是MAC核驱动MDIO的过程,操作码OP为“01”,通过匹配PHYAD选中PHY器件,并将16比特的数据域(WRITE DATA)写入PHY器件中匹配REGAD的寄存器。MDIO读时序如图4所示,分为MAC驱动MDIO和PHY驱动MDIO两个阶段,操作码OP为“10”,PHYAD匹配的PHY器件将被REGAD选中的寄存器信息返回给 MDIO模块。

cb5ba9b5e19e46d0b3b5d38806344919.png

图3 MDIO时序

582cef54e92c4a758e1135c9aa1f0a8d.png

图4 MDIO读时序

(2)基于 MDIO 的PHY配置与控制

通过管理接口访问MDIO接口是寄存器映射过程,进而实现对PHY寄存器的配置。 MDIO配置寄存器地址如表2所示,各寄存器的比特位详细定义请参考UG800。

表2 MDIO配置寄存器地址

89e44e39145b490894ebfa754cdde914.png

通过AXI4-Lite接口实现1次MDIO写操作:首先将要写入的数据置于MDIO写数据寄存器(WRITEDATA)中,写操作初始化由AXI4-Lite接口设定MDIO配置字1(MDIO Configuration Word1)寄存器实现,OP置为“01”,将要访问的PHY器件地址及其寄存器地址分别写入PHYAD和REGAD。MDIO配置字1寄存器中的第7比特为MDIO READY信号,用于表示MDIO读/写操作是否可用。当写操作配置完成时,MDIO READY信号会被置于无效状态,且MDIOREADY在这次写操作完成后才结束无效状态。

通过AXI4-Lite接口实现1次MDIO读操作:同样由AXI4-Lite接口设定MDIO的配置字1寄存器实现初始化,OP置为“10”,将要访问的PHY器件地址及其寄存器地址分别写入PHYAD和REGAD。当读操作配置完成时,MDIO READY信号会被置于无效状态,直到这次读操作完成;当MDIO READY再次有效时,表示请求读取的数据在MDIO的READ DATA寄存器中,可以被AXI4-Lite接口读出。

4 MII接口分析

MII即媒体独立接口,也叫介质无关接口,它是IEEE-802.3定义的以太网行业标准。它包括一个数据接口和管理接口:数据接口支持10/100Mbps数据速率,包括16个信号,分为2个独立的发送和接收通道,收发通道都有自己的数据、时钟和控制信号,数据位宽为4比特:管理接口是一个双信号接口,一个是时钟信号,另一个是数据信号。通过管理接口,上层能监视和控制PHY器件。MII接口速率为10Mbps时,时钟频率为2.5MHz:MII接口速率为100Mbps时,时钟频率为25MHz。TEMAC核的MII接口信号简要说明如表3所示。

表3 MII 接口信号简要说明

0463c8f4d6384b17bfdfe57815318645.png

MII接口使用灵活,但其由2根时钟信号线和14根数据状态信号线组成,接口信号线过多;以MII接口作为交换机接口,将造成引脚数目较多,给芯片和PCB设计带来了一定的难度。通过信号复用、调整数据宽度,设计出了简化版的MII,将MII的16根数据线减少为8根,即RMII接口,数据位宽为2比特。由于TEMAC并不支持RMII,所以这里不再赘述。

5 GMII/RGMII接口分析

千兆媒体独立接口GMII是对MII的扩展,接口位宽为8比特,支持1000Mbps传输速率(工作时钟为125MHz),同时兼容MII 的10/100Mbps模式。TEMAC核的GMII接口信号简要说明如表4所示。

表4 GMII 接口信号简要说明

59b984aa9fa642cba96b31f460ca406e.png

RGMII 接口是简化的GMII接口,支持10/100/1000Mbps的传输速率。TX/RX数据宽度从8位变为4位,时钟频率仍为125MHz,为了保持1000Mbps的传输速率不变,在参考时钟的上升沿发送GMII接口中的TXD[3:0]/RXD[3:0],在参考时钟的下降沿发送 GMII 接口中的TXD[7:4]/RXD[7:4]。由于RGMII使用了双倍速率触发器,并将接口信号线数量从24根减少到14根,比GMII减少了近一半的引脚数,所以PCB设计者更加青睐使用RGMII。TEMAC核的RGMII接口信号简要说明如表5所示。

表5 RGMII 接口信号简要说明

669e5e0ac15f40d0abf47aed2cdd7480.png

6 SGMII/1000Base-X接口分析

串行吉比特媒体独立接口(Serial GMII, SGMII)和1000BASE-X都是串行接口,SGMII接口将并行的GMII/MII转换为串行信号,支持10/100/1000Mbps。SGMII收发端各采用一对差分信号线,时钟频率为625MHz,采用时钟双沿采样。基于节省引脚数量的考虑, SGMII接口受到了PCB设计者的青睐。1000Base-X即光纤千兆以太网,X表示单模或多模光纤。基于SGMII接口的互连系统如图5所示。

e109bcd266194d4cae12e083a83d4f30.png

图5 基于SGMII接口的互连系统

当以太网MAC的物理接口配置为1000BASE-XPCS/PMA或SGMII时,PCS/PMA子层模块将内部并行接口(MII、GMII或RGMII)转换为串行接口(1000BASE-X或 SGMII),串行接口通过串行收发器与外部的光收发器进行通信。当TEMAC配置为1000BASE-X PCS/PMA模式时,与串行收发器的连接如图6所示。

5b02525686cc457fa8cd438702f72d13.png

图6 TEMAC配置为1000BASE-XPCS/PMA模式时的连接示意

TEMAC核的SGMII/1000BASE-X接口信号简要说明如表6所示。

表6 SGMII/1000BASE-X接口信号简要描述

0fa9c109cde3425e939958b551781dc3.png

 

这篇关于Xilinx 千兆以太网TEMAC IP核 MDIO 配置及物理接口的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982531

相关文章

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

springboot security之前后端分离配置方式

《springbootsecurity之前后端分离配置方式》:本文主要介绍springbootsecurity之前后端分离配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的... 目录前言自定义配置认证失败自定义处理登录相关接口匿名访问前置文章总结前言spring boot secu

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Spring Boot结成MyBatis-Plus最全配置指南

《SpringBoot结成MyBatis-Plus最全配置指南》本文主要介绍了SpringBoot结成MyBatis-Plus最全配置指南,包括依赖引入、配置数据源、Mapper扫描、基本CRUD操... 目录前言详细操作一.创建项目并引入相关依赖二.配置数据源信息三.编写相关代码查zsRArly询数据库数

SpringBoot配置Ollama实现本地部署DeepSeek

《SpringBoot配置Ollama实现本地部署DeepSeek》本文主要介绍了在本地环境中使用Ollama配置DeepSeek模型,并在IntelliJIDEA中创建一个Sprin... 目录前言详细步骤一、本地配置DeepSeek二、SpringBoot项目调用本地DeepSeek前言随着人工智能技

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

使用Python实现网络设备配置备份与恢复

《使用Python实现网络设备配置备份与恢复》网络设备配置备份与恢复在网络安全管理中起着至关重要的作用,本文为大家介绍了如何通过Python实现网络设备配置备份与恢复,需要的可以参考下... 目录一、网络设备配置备份与恢复的概念与重要性二、网络设备配置备份与恢复的分类三、python网络设备配置备份与恢复实