为什么要做跨时钟域的处理?
打一个不太恰当的例子,时钟相当于我们人体的“心脏”,伴随时钟产生的数据流就是相当于血液。假设人体中有多个小心脏,当心脏A的血液进入心脏B支撑的系统时就会产生混乱。为了防止这种情况的产生,需要对“跨心脏”的数据做处理。这个处理就是跨时钟域处理。
跨时钟域处理的两种方式
1. 两级触发器级联(打两拍)
对于单bit数据,常用的处理跨时钟域方式为两级触发器级联方式。
Clock1的输出直接连接Clock2第一级寄存器的输入,不用经过任何组合逻辑电路,一级寄存器与二级寄存器级联,得到Clock2时钟域的OUTPUT。
参考代码:
应用场景:1. 注意全局复位信号在各个模