1.为什么要分析跨时钟域数据传输问题?
-
正常来讲同步时钟域下的数据传输,只要建立和保持时间满足,外部环境(核心电压/温度)没有剧烈变化,一般情况下可以保证数据可靠传输。而异步时钟域在时序约束的时候已经设置了不同的clock group,相互之间的数据是不会进行时序分析的,因此即便是静态时序分析没有报告时序问题也不意味着异步数据传输可以可靠进行。因此说,跨时钟域的数据传输是设计出来的,而不是约束出来的。
-
需要明确的是只要是异步数据传输就必然会有亚稳态的问题,通过一些特殊设计,比如打两拍同步等只能减低亚稳态概率而不能完全消除。因此在设计中应该尽量选择同步设计的方式。若一定要用到异步设计,那也应当处理好跨时钟域数据传输的问题,尽量使得系统对亚稳态错误不敏感。
-
亚稳态其实就是数据没有满足寄存器的建立和保持时间而引发的现象,说白了就是数据到来的时机和采样沿挨得太近,导致寄存器不知道这次数据到底是0还是1,在经历了一段决断时间之后,随机地输出了一个值,该值与数据毫无关联。因此系统功能就会出错。
2.减少亚稳态的方法:
- 降低时钟频率,为数据到来提供足够的准备时间
- 选用高端器件,建立保持时间很短,也是为数据传输尽可能地留时间
- 采用特殊设计,处理好异步数据传输
3.跨时钟域数据传输分类:
- 按照传输数据位数分
(1)单bit数据传输,比如使能信号、FIFO读写命