跨时钟域数据传输(CDC,clock domain crossing)

1.为什么要分析跨时钟域数据传输问题?

  • 正常来讲同步时钟域下的数据传输,只要建立和保持时间满足,外部环境(核心电压/温度)没有剧烈变化,一般情况下可以保证数据可靠传输。而异步时钟域在时序约束的时候已经设置了不同的clock group,相互之间的数据是不会进行时序分析的,因此即便是静态时序分析没有报告时序问题也不意味着异步数据传输可以可靠进行。因此说,跨时钟域的数据传输是设计出来的,而不是约束出来的。

  • 需要明确的是只要是异步数据传输就必然会有亚稳态的问题,通过一些特殊设计,比如打两拍同步等只能减低亚稳态概率而不能完全消除。因此在设计中应该尽量选择同步设计的方式。若一定要用到异步设计,那也应当处理好跨时钟域数据传输的问题,尽量使得系统对亚稳态错误不敏感。

  • 亚稳态其实就是数据没有满足寄存器的建立和保持时间而引发的现象,说白了就是数据到来的时机和采样沿挨得太近,导致寄存器不知道这次数据到底是0还是1,在经历了一段决断时间之后,随机地输出了一个值&#

猜你喜欢

转载自blog.csdn.net/qq_43445577/article/details/105471869