如何减少OSERDES的CLK-CLKDIV与IDDR的CLK及CLK-CLK_B之间的歪斜

如果您已经在使用全新速度文件运行时序,而且 oserdes clk 和 clkdiv 或者 iddr clk 和 clk_b 之间有歪斜违规,接下来帮助解决歪斜违规问题的步骤已在本答复记录中归档。
提供几个解决方案:
推荐的解决方案:将您的项目迁移至 vivado 2016.4,将时钟拓扑更新至本答复记录所描述的推荐拓扑并运行正常综合及实现流程。
vivado 2016.4 可在时序分析中自动报告 oserdes 和 iddr 的歪斜检查情况。
第二种解决方案:更新时钟拓扑后为您的项目继续使用较早的 vivado 版本,包括运行综合及实现方案。 使用本答复记录附带的 tcl 脚本 (reportioserdes.tcl) 报告有关 oserdes 及 iddr 的歪斜检查。 使用 vivado 2016.4 在已布线的 dcp 上运行时序签收 (report_timing_summary),并修复剩余的歪斜违规问题(查看 (68266))。
第三种解决方案:升级时钟拓扑后,继续使用带有相应速度文件补丁的较早 vivado 版本(仅限于某些 vivado 版本,按需提供),包括运行综合及实现方案。 使用本答复记录附带的 tcl 脚本 (reportioserdes.tcl) 报告有关 oserdes 及 iddr 的歪斜检查。
oserdes clk 至 clkdiv 歪斜
oserdese3 的最佳时钟拓扑如下图所示。
mmcme3 的 clkout 应并行驱动两个 bufgce_div,这可使用一个 bufgce_div 的分频功能创建较慢的 clkdiv。
注意,也不一定就需要驱动高速时钟 (clk) 的全局缓冲器为 bufgce_div 单元。如果缺乏 bufgce_div,它也可以是 bufgce。
使用 mmcme3 的多组输出创建 clk 和 clkdiv 时,请查看确保符合歪斜要求。
图:推荐的时钟拓扑
请注意:因为 bufgce_div 正在使用被下分频的较高频率时钟。
因此,架构逻辑必须使用图(支持 bufgce_div 的架构时钟)中所示的 bufgce_div 驱动。
图:支持 bufgce_div 的架构时钟
如图所示:bufgce_div 对齐,bufgce_divide = 2 或者 4 个计数器可以在不同的时间启动。
clk_div2 a 和 clk_div2 b 进行 2 分频时出现了两个对齐。同样,进行 4 分频时,clk_div4 a/b/c/d 出现了 4 个可能的对齐。
计数器可通过使用 clr 和 ce 输入与既定的时钟边缘对齐。
图:bufgce_div 对齐
此外,如果您需要 mmcm 输出为相位对齐(就是 clkoutx_phase)而且无法应用 correctcontrols 控制图(bufgce_div 对齐)的时序,您可以使用 aseparate bufg 时钟缓冲器进行架构连接。
在支持 mmcm 时钟输出的架构时钟使用 3 个 mmcm 输出的图中。clkout0 可驱动架构逻辑(另外一个 mmcm clkout1)来驱动 oserdes clkdiv 并驱动另外一个 mmcm clkout2 来驱动 oserdes clk。
oserdes 的 clk 及 clkdiv 端口由只连接至 erdes 的 bufg 驱动,将具有类似的加载/布线。此外,只要布线终点类似,clkout1 和 clkout2 也可用于其它组件原语(iserdes、idelay、odelay、idelayctrl)。
图:支持 mmcm 时钟输出的架构时钟
在 支持 mmcm 时钟输出的架构时钟图中, 时钟输出分频设置将是 data_width 的比率,这样:
clkout0_divide_f = clkout2_divide * data_width / 2
clkout1_divide = clkout2_divide * data_width / 2
输出来自 mmcm,因此实现既定相移时,mmcm 只会锁死,在这种情况下可以由 clkout__phase 定义。
clock_delay_group
如果设计仍然无法满足要求,下一步就得尝试减少 clk 与 clkdiv 引脚之间的歪斜,将一个 clock_delay_group 分配给网络。
这可让 vivado 实现工具平衡两个时钟网络。下面是 clock_delay_group 的一个示例:
set_property clock_delay_group serdes_x2y2 [get_nets of [get_pins bufgce_div_clk_inst/o]]
set_property clock_delay_group serdes_x2y2 [get_nets of [get_pins bufgce_div_clkdiv_inst/o]]
user_clock_root
除了 clock_delay_group 属性外,您还可使用 user_clock_root 属性强制对时钟缓冲器驱动的时钟进行时钟根定位。查看以下 user_clock_root 示例:
set_property user_clock_root x2y3 [get_nets of [get_pins bufgce_div_clk_inst/o]]
set_property user_clock_root x2y3 [get_nets of [get_pins bufgce_div_clkdiv_inst/o]]
iserdes clk 至 clkdiv 歪斜:
对 iserdes clk 和 clkdiv 没有歪斜要求,但就 oserdes 而言,所推荐的时钟拓扑将是相同的。
使用一个并列驱动两个 bufgce_div 的 mmcm clkout,这可使用一个 bufgce_div 的分频功能创建更慢的 clkdiv。
iddre1 c 至 cb 以及 iserdes clk 至 clk_b 歪斜
iddr(和 iserdes)clk 和 clk_b 的最佳时钟拓扑就是使用相同的网络驱动两个引脚并使用局部求逆创建反相时钟。查看下图示例。
查看(68331),了解有关 vivado 时序歪斜检查的详细信息,解决有关专属时钟组约束的歪斜检查问题。


2017年值得关注的七大技术创业趋势
功率达林顿晶体管电路设计特征参数
润和软件成为瑞萨电子中国区的独家战略合作伙伴
离心泵构造、种类及工作原理
华星光电预计今年3月份实现单月生产各尺寸液晶面板300万片目标
如何减少OSERDES的CLK-CLKDIV与IDDR的CLK及CLK-CLK_B之间的歪斜
Uber最新股权结构:软银成优步“大东家” 卡兰尼克和基准资本靠边
安防产品技术的发展及在车辆网中的典型应用分析
欧洲电动汽车市场加速增长 在欧洲的发展势头更加积极
镇江市开启“白+黑”模式打造金山文化旅游节“云”上盛会
傅里叶变换基本性质 傅里叶变换本质 傅里叶变换的应用
一文知道Imagination Technologies对2018年的五大预测
昕诺飞正加速新型UV-C紫外线消毒产品在中国市场的推广与应用
VR日报:英国仅有16%女性接受VR*** 男性仍然对它痴迷
基于MCS8051数据采集监测系统的设计
蔚来汽车股价涨幅过快 创下近半年来的新高
智能断路器优点
光纤接口适配器有效解决高数据传输的研究与实现
捷杰传感分体式无线振动传感器成功解决风机振动监测难题
加紧研发​加密货币的目的是什么