ISERDESE2原语

ISERDESE2主要是串行输入,两个器件进行通讯时,至少都需要一个数据线来传输数据,并且还需要满足一定的时序才能保证数据准确的传输。

在低速协议中,布线的传输延时可忽略不计,只要满足相应的协议就可实现数据的传输,当然这种情况只限外部干扰较小的情况,如果要确保传输的准确性,还需要进行校验。

但在高速传输时,在硬件上通过差分传输来降低外界的干扰信号,但数据线的长短会影响传输的时长。如通过clk和data两对差分线进行传输,由于clk的布线与dara的布线存在长短上的差异,主机传输到从机后clk和data的延时各不相同。如果我们希望在时钟上升沿上采集数据,但由于线的延时,可能在时钟上升沿时数据处于变化状态,这将会导致采集的数据错误。通过IDELAYE2原语可将某根信号线进行延时操作,以达到在时钟上升沿数据处于稳定的操作。

本文章主要参考Xilinx官方UG471和PG070数据手册。

下图为IDELAYE2例化框图。

 上图为IDELAYE2模块例化接口框图,IDELAY被称为信号延迟模块,它的作用就是把信号延迟一段时间。对于一些需要对齐的输入信号来说,这至关重要。在7系列FPGA中,它被称为IDELAYE2。IDELAYE2可以将信号延迟0~31节,在这区间任意可调,并且在参考时钟为200M时,每节的延迟精度为78ps(1/(32×2×FREF),FREF为IDELAYCTRL的参考时钟)。

IDELAYE2可以一共有四个工作模式:固定延迟模式(FIXED), 可变延迟模式(VARIABLE), 可加载可变延迟模式(VAR_LOAD或VAR_LOAD_PIPE),VAR_LOAD与VAR_LOAD_PIPE模式相识,只是加载的位置不同,下文会进行阐述。

1.IDELAYE2端口说明

端口IOwidth描述
Cinput1时钟输入,用于VARIABLE, VAR_LOAD, VAR_LOAD_PIPE模式
REGRSTinput1Pipeline寄存器的复位,只用于VAR_LOAD_PIPE 模式。
LDinput1在VARIABLE 模式,加在IDELAYE2延时的值;LD,CD,INC配合使用
CEinput1使能增加/减少的功能
INCinput1增加或减少tap delays数量
CINVCTRLinput1动态转换时钟极性
CNTVALUEINinput5对动态加载tap值的计数,用于VAR_LOAD模式
IDATAINinput1输入数据来自IBUF
DATAINinput1输入数据来自FPGA逻辑
LDPIPEENinput1使能pipeline寄存器来加载数据
DATAOUToutput1延迟后的数据输出
CNTVALUEOUToutput5tap值的监控输出

2.IDELAYE2属性说明

属性默认值描述
IDELAY_TYPE

String:FIXED,VARIABLE,

VAR_LOAD, orVAR_LOAD_PIPE

FIXEDFIXED:固定的延迟值
VAR_LOAD:动态加载tap值VARIABLE:动态调节延时值
VAR_LOAD_PIPE:与VAR_LOAD模式类似,并CNTVALUEIN值
DELAY_SRCString: IDATAIN,
DATAIN
IDATAINIDATAIN:输入数据来自IBUFDATAIN:输入数据来自FPGA逻辑
IDELAY_VALUEInteger: 0 to 310在IIXED模式,指定延时taps;
在VARIABLE模式,加载的tap初始值;另外两种模式,不使用,并置0

HIGH_PERFORMANCE_MOD

Boolean: FALSE or TRUETRUETRUE:减少输出抖动
SIGNAL_PATTERNString: DATA, CLOCKDATA数据或者时钟
REFCLK_FREQUENCYReal: 190 to 210,
290 to 310, or 390 to 410
200参考时钟,确定每个延时tap的精度;200M时,1个tap=78ps 参考时钟,确定每个延时TAP的精度;200米时,1个TAP=78 ps
CINVCTRL_SELBoolean: FALSE or TRUEFALSE使能CINVCTRL_SEL管脚来动态切换输入时钟的极性。
PIPE_SELBoolean: FALSE or TRUEFALSE选择pipeline模式,只用于VAR_LOAD PIPE模式。

3.IDELAYE2的延时计算

        IDELAY2是一个可编程的31阶延迟原语,通过改变tap的值可以改变数据线的延时大小,其延时的分辨率与参考时钟频率f有关,延时的分辨率delay_resolution计算公式如下:
                         delay_resolution = 1/(32 * 2 * f)*1000000(ps)

其中f单位为Mhz。
  当f=200Mhz时,delay_resolution=78ps(注:计算出来为78.125ps,但会取整,为78ps);
  同样,当f=300Mhz时,delay_resolution=52ps。
只要通过了 IDELAY2这个原语,都会先增加一个0.6ns的延时,延时的具体大小计算如下:
  1.当tap=0时,我们要弄清一个误区,tap=0时并不是延时就是0,此时delay_time=600ps;
  2.当tap!=0时,delay_time=600ps + tap * delay_resolution。

4.IDELAYE2模式

1.固定延迟模式(IDELAY_TPYE=FIXED)

  在该模式下数据延迟由属性IDELAY_VALUE设置,且延迟固定,不可更改。在该模式下,IDELAYCTRL原语必须例化。

2.可变延迟模式(IDELAY_TPYE=VARIABLE)

        在该模式下,延迟值可以在配置后通过CE和INC端口进行动态配置。同样,在该模式下,IDELAYCTRL原语也必须例化。该模式下的逻辑控制对应关系如下表所示。         

显示了IDELAY(IDELAY_TYPE=VARIABLE,IDELAY_VALUE=0,DELAY_SRC=IDATAIN)时序图:

        参考前文可变延迟模式下的逻辑表,可见1时刻C=1,LD=1,则会加载IDELAY_VALUE的值到tap,即此时tap0=IDELAY_VALUE;在时刻2时,C=1,LD=0,CE=1,INC=1,tap的值会自动累加1,即tap1=IDELAY_VALUE + 1;在时刻3时,C=1,LD=0,CE=0,INC=0,tap的值不变,即tap1=IDELAY_VALUE + 1;

3.可加载可变延迟模式(IDELAY_TYPE=VAR_LOAD)

  该模式下功能与VARIABLE模式下类似,只不过可以通过CNTVALUEIN加载延迟节拍数。多了一种延迟加载方法。当LD端口有效时可以加载新的延迟CNTVALUE值到控制模块。该模式下逻辑功能关系如下表所示。

 下图为可加载可变延迟模式时序图:

         对照表格,我们看一下时序图,当时刻0时,当C=1,LD=0,INC=0,CE=0,CNTVALUEIN = 5’b00010,CNTVALUEOUT、DATAOUT保持状态;1时刻C=1,LD=1,INC=0,CE=0,CNTVALUEIN=5’b00010,则会加载CNTVALUEIN的值到tap上,即tap=5‘b00010;在2时刻C=1,LD=0,INC=1,CE=1,CNTVALUEIN=5’b01010,则此时tap的值会自动加1,即tap=5‘b00010 + 1’b1 = 5‘b00011;在3时刻,C=1,LD=1,INC=0,CE=0,CNTVALUEIN=5’b01010,则会加载CNTVALUEIN的值到tap上,即tap=5‘b01010;

5、IDELAYCTRL原语

IDELAYCTRL其实是个辅助模块,这么说吧,只要咱们使用了IDELAY或者ODELAY,IDELAYCTRL必须被使用,要不然就无法正常工作。因为IDELAY或者ODELAY的延迟精度是由IDELAYCTRL的输入时钟决定的,一般为200MHz。下图为IDELAYCTRL例化框图。

1.IDELAYCTRL端口说明

符号描述
RST - Reset异步复位信号,高有效。
REFCLK - Reference Clock参考时钟(REFCLK)为IDELAYCTRL提供时间参考,以校准同一区域中的所有IDELAY和ODELAY模块。该时钟必须由全局或水平时钟缓冲器(BUFG或BUFH)驱动。
RDY - Ready就绪(RDY)信号指示特定区域中的IDELAY和ODELAY模块何时校准。如果REFCLK保持高电平或低电平超过一个时钟周期,则RDY信号被取消断言。如果RDY被取消断言为低,则必须重置IDELAYCTRL模块。

2.IDELAYCTRL时序

         从时序图中可以看出,在IDELAYCTRL原语复位后要经过TIDELAYCTRLCO_RDY时间后RDY才被拉高,但若参考时钟在多个时钟周期内保持了不变,RDY就会拉低,此时IDELAYCTRL需要重新复位。

6、IDELAY仿真波形

1.FIXED模式

  当IDELAY_TYPE = FIXED为FIXED模式,线的延时时间由IDELAY_VALUE来确定。首先当IDELAY_VALUE = 0时,仿真结果如下:
可见,线延时了600ps。

 当IDELAY_TYPE = FIXED为FIXED模式,线的延时时间由IDELAY_VALUE来确定。首先当IDELAY_VALUE = 1时,仿真结果如下:
可见,线延时了678ps。

 同理,按照公式31阶应该为600+78*31=3018

 2.VARIABLE模式

当top=13时,延迟等于600+13*78=1614

当top=15时,延迟等于600+15*78=1770

根据对IDELAYE2的FIXED模式进行的仿真可以看出,结果与UG471一致。

  • 1
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ISERDESE3是Xilinx FPGA的一种原语,用于实现高速串行输入数据的解串和时钟恢复。它是SERDESE2的升级版,具有更高的性能和更多的功能。ISERDESE3可以用于将串行数据信号转换为并行数据信号,并通过提供的时钟信号对其进行重新同步。 ISERDESE3具有多个参数和属性,可以根据应用的需求进行配置。其中,一些重要的参数包括数据宽度、输入数据时钟的相位、时钟边沿对齐方式等。它还提供了一些附加功能,如数据对齐、极性反转和时钟使能等。这些功能可以根据具体的设计需求进行配置。 通过使用ISERDESE3原语,可以实现高速串行数据的可靠传输和处理。它在摄像头数据等高速源同步应用中具有广泛的应用。 在给定的代码示例中,ISERDESE3可能用于解串行输入数据,并将其转换为并行数据,以供后续的逻辑电路处理。在该示例中,sys_clk_i和ext_rst_n信号用于控制ISERDESE3的操作,并且tx_clk_out信号可能是ISERDESE3输出的时钟信号。 综上所述,ISERDESE3是Xilinx FPGA中用于高速串行数据解串和时钟恢复的原语,具有广泛的应用和可配置的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [xilinx fpga 原语 OSERDESE2 使用 方法](https://blog.csdn.net/zyf0806/article/details/108518282)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [《Xilinx - UG471中文翻译》(2)ISERDESE2原语介绍](https://blog.csdn.net/m0_52840978/article/details/120982593)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

伊藤诚诚诚诚

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

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

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

打赏作者

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

抵扣说明:

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

余额充值