跨时钟域处理是fpga设计中经常遇到的问题,而如何处理好跨时钟域间的数据,可以说是每个fpga初学者的必修课。如果是还在校生,跨时钟域处理也是面试中经常常被问到的一个问题。
这里主要介绍三种跨时钟域处理的方法,这三种方法可以说是fpga界最常用也最实用的方法,这三种方法包含了单bit和多bit数据的跨时钟域处理,学会这三招之后,对于fpga相关的跨时钟域数据处理便可以手到擒来。
这里介绍的三种方法跨时钟域处理方法如下:
打两拍;
异步双口ram;
格雷码转换。
01
方法一:打两拍
大家很清楚,处理跨时钟域的数据有单bit和多bit之分,而打两拍的方式常见于处理单bit数据的跨时钟域问题。 打两拍的方式,其实说白了,就是定义两级寄存器,对输入的数据进行延拍。如下图所示。 应该很多人都会问,为什么是打两拍呢,打一拍、打三拍行不行呢? 先简单说下两级寄存器的原理:两级寄存是一级寄存的平方,两级并不能完全消除亚稳态危害,但是提高了可靠性减少其发生概率。总的来讲,就是一级概率很大,三级改善不大。 这样说可能还是有很多人不够完全理解,那么请看下面的时序示意图: data是时钟域1的数据,需要传到时钟域2(clk)进行处理,寄存器1和寄存器2使用的时钟都为clk。假设在clk的上升沿正好采到data的跳变沿(从0变1的上升沿,实际上的数据跳变不可能是瞬时的,所以有短暂的跳变时间),那这时作为寄存器1的输入到底应该是0还是1呢?这是一个不确定的问题。所以q1的值也不能确定,但至少可以保证,在clk的下一个上升沿,q1基本可以满足第二级寄存器的保持时间和建立时间要求,出现亚稳态的概率得到了很大的改善。 如果再加上第三级寄存器,由于第二级寄存器对于亚稳态的处理已经起到了很大的改善作用,第三级寄存器在很大程度上可以说只是对于第二级寄存器的延拍,所以意义是不大的。
02
方法二:异步双口ram
处理多bit数据的跨时钟域,一般采用异步双口ram。假设我们现在有一个信号采集平台,adc芯片提供源同步时钟60mhz,adc芯片输出的数据在60mhz的时钟上升沿变化,而fpga内部需要使用100mhz的时钟来处理adc采集到的数据(多bit)。在这种类似的场景中,我们便可以使用异步双口ram来做跨时钟域处理。 先利用adc芯片提供的60mhz时钟将adc 输出的数据写入异步双口ram,然后使用100mhz的时钟从ram中读出。对于使用异步双口ram来处理多bit数据的跨时钟域,相信大家还是可以理解的。当然,在能使用异步双口ram来处理跨时钟域的场景中,也可以使用异步fifo来达到同样的目的。
03
方法三:格雷码转换
我们依然继续使用介绍第二种方法中用到的adc例子,将adc采样的数据写入ram时,需要产生ram的写地址,但我们读出ram中的数据时,肯定不是一上电就直接读取,而是要等ram中有adc的数据之后才去读ram。这就需要100mhz的时钟对ram的写地址进行判断,当写地址大于某个值之后再去读取ram。 在这个场景中,其实很多人都是使用直接用100mhz的时钟与ram的写地址进行打两拍的方式,但ram的写地址属于多bit,如果单纯只是打两拍,那不一定能确保写地址数据的每一个bit在100mhz的时钟域变化都是同步的,肯定有一个先后顺序。如果在低速的环境中不一定会出错,在高速的环境下就不一定能保证了。所以更为妥当的一种处理方法就是使用格雷码转换。 对于格雷码,相邻的两个数间只有一个bit是不一样的(格雷码,在本文中不作详细介绍),如果先将ram的写地址转为格雷码,然后再将写地址的格雷码进行打两拍,之后再在ram的读时钟域将格雷码恢复成10进制。这种处理就相当于对单bit数据的跨时钟域处理了。 对于格雷码与十进制互换的代码,仅提供给大家作参考: 代码使用的是函数的形式,方便调用,op表示编码或者译码,waddrwidth和raddrwidth表示位宽。
Linux核心4.9出炉,Linus保证史上最大改版!
半导体芯片的制造过程及原理
什么是触摸屏的硬度/分类/有效触摸区域/感应力度/定位精度
并不是所有设备都称为物联网
三星A70s的渲染图曝光,将搭载骁龙675处理器
三种跨时钟域处理的方法
RFID技术还可以提高饮料销量吗
64核锐龙Threadripper 3990X性能终于大增
电桥测量的基础
海内外院士观点交锋 2018人工智能应用创新峰会有哪些看点
电脑硬件基础篇硬盘(硬盘工作原理及作用_特性参数及型号和位置)
如今连接器行业的竞争已经从连接器厂商之间的竞争,转到连接器代理商之间的竞争
审美意识觉醒后,旗袍为何成为国潮顶流?
基于控制器LM3445的TRIAC调光离线LED驱动电路原理解析
什么是终端电阻?CAN总线的终端电阻具体作用是什么呢?
真空断路器合闸步骤_真空断路器的基本结构
变电站巡检机器人的功能
只保留两位小数,多余的删掉
新技术将智能手表传感精度提高100倍
NVIDIA的Holodesk协作涵盖海陆空各种形态 教主告诉你NVIDIA的野心