SDC学习之跨时钟域异步FIFO格雷码的sdc约束

以SNPS家的IP为例分析下SNPS对IP内部跨时钟域graycode的约束。

通常对异步FIFO的格雷码下约束有两个原因,一个是保证异步FIFO的性能,如果格雷码跨异步的delay太长,FIFO传输数据的效率会下降,另一个是保证多比特格雷码在跨时钟域时不会采错,如果不同bit之间的delay不一致,就可能导致在同一个时钟上升沿时,某一bit已经走到第四个数据了,另一bit还在第三数据,造成采样错误。

SNPS对格雷码的约束有两条,一条读到写,约的是1.5倍读时钟,对应图中黄色线,一条写到读,约的是1.5倍写时钟,对应图中蓝色线。

set_max_delay $clkPushPeriod -from \[get_clocks {$clk_push_name}\] -to {$data_d_pins_name} $ignore_clock_latency_option $reset_path_option
set_max_delay $clkPopPeriod -from \[get_clocks {$clk_pop_name}\] -to {$data_d_pins_name} $ignore_clock_latency_option $reset_path_option
  • 为什么不管写到读还是读到写约的都是source clock period?

对于格雷码传输来说,格雷码从clk_a时钟域到clk_b时钟域,如果用clk_b时钟域的period做约束,若clk_b的周期远大于clk_a,格雷码在clk_a时钟域传播时各比特之间latency超过1T,就会造成采样错误。 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值