FPGA rgmii/gmii

GMII是千兆以太网接口,它使用8位数据总线,在125MHz时钟下工作,每个时钟周期传输一个字节,因此数据速率是1000Mbps。GMII有独立的发送和接收数据线,还有相关的控制信号,比如TX_EN、RX_DV,以及错误信号等。GMII的时序应该是在时钟的上升沿采样数据,控制信号如TX_EN。也需要在时钟边沿有效。

RGMII,它为了减少引脚数量,将数据总线从8位减少到4位,同时使用双倍数据速率(DDR),在时钟的上升沿和下降沿都传输数据。因此,RGMII的工作时钟是125MHz,但因为DDR,每个时钟周期传

输两个半字节(4位),所以总的数据速率也是1000Mbps。

GMII到RGMII的转换器需要将8位的数据在125MHz下转换为4位的数据在双沿传输,同时将TX_EN和TX_ERR编码到TX_CTL的两个边沿。

RGMII到GMII需要将双沿的4位数据组合成8位,并在每个时钟周期输出,同时从TX_CTL中提取控制信号。

FPGA内部处理的数据都是单沿数据,双沿数据的变换只能发生在FPGA的IOB上面;

RGMII TX : FPGA(cpri) -> ARM

RGMII RX : ARM -> FPGA(cpri)

GMII > RGMII : GMII_TXD[7:0] = {RGMII_TXD下降沿,RGMII_TXD上升沿};

RGMII > GMII : GMII_RXD[7:0] = {RGMII_RXD下降沿,RGMII_RXD上升沿};

RGMII_RXD[3:0]上升沿传输,RGMII_RXD[7:4]下降沿传输;

IDELAYE3(输入信号延迟模块,作用是将信号延迟一段时间)

ODELAYE3(输出信号延迟模块)

因单个IDELAYE3或者ODELAYE3有固定的延迟,如果所需要的延迟超过固定延迟,则需要进行级联;

上图中可以看到,IDELAYE3的级联操作需要ODELAYE3一起穿插使用,第一级CASCADE参数设置为MASTER,中间级设置为SLAVE_MIDDLE,最后一级设置为SLAVE_END,级联组件之间的布线是专用高速布线,IDELAYE3 或 ODELAYE3 级联的固定内部插入延迟总量是初始插入延迟与级联插入延迟的总和。此延迟按 IDELAYE3 和 ODELAYE3 级联次数而成倍增加。

在TIME模式下级联时,同一site下两者延迟要相同,如把IDELAYE3延时0.75ns,级联的ODELAYE3延时0.75ns,那么就延时了1.5ns,在FIXED模式下DELAY_VALUE设置两者相同,VAR_LOAD模式下两者CNTVALUEIN输入相同值;

IDELAYCTRL(辅助模块,使用了IDELAY或者ODELAY就必须使用该模块)

IDDRE1(输入信号为单沿,输出信号为双沿)

ODDRE1(输入为双沿信号,输出为单沿信号)

RGMII发送设计逻辑框图

PHY通过RGMII发送至FPGA(FPGA只处理单沿数据)

源语:ODDR;双输入单输出

支持RGMII的PHY芯片在时钟上升沿发送数据低4位,时钟下降沿发送数据高4位;

PHY通过RGMII接收FPGA的数据

源语:IDDR;单输入双输出

对时钟或数据信号进行延时使用以下源语(适用于U+系列):

IDELAYCTRL、ODELAYE3、IDELAYE3

如果使用了IDELAYE3或ODELAYE3的TIME模式,就必须例化IDELAYCTRL组件,如果使用

COUNT模式,就不使用IDELAYCTRL组件;

REFCLK:参考时钟,使用时参考时钟与其联合使用的IDELAYE3和ODELAYE3设置相同值;

相关推荐
GateWorld4 小时前
FPGA 实现无毛刺时钟切换
fpga开发·实战·无毛刺时钟
Seraphina_Lily6 小时前
从接口选型到体系结构认知——谈 CPU–FPGA–DSP 异构处理系统与同构冗余设计
fpga开发
Seraphina_Lily8 小时前
CPU–FPGA–DSP 异构系统中的总线接口选型——为什么 CPU 用 eLBC,而 DSP 用 XINTF?
fpga开发
GateWorld8 小时前
FPGA开发十年心路
fpga开发
ALINX技术博客1 天前
【ALINX 教程】FPGA Multiboot 功能实现——基于 ALINX Artix US+ AXAU25 开发板
fpga开发·fpga
Genevieve_xiao1 天前
【verilog】如何一小时成为verilog高手(并非
fpga开发
从此不归路1 天前
FPGA 结构与 CAD 设计(第3章)上
ide·fpga开发
Aaron15881 天前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
碎碎思1 天前
在 FPGA 上实现并行脉冲神经网络(Spiking Neural Net)
人工智能·深度学习·神经网络·机器学习·fpga开发
集芯微电科技有限公司1 天前
替代HT6310/KP3310离线式AC-DC无感线性稳压器
数据结构·人工智能·单片机·嵌入式硬件·fpga开发