欢迎来到天天文库
浏览记录
ID:8460551
大小:345.50 KB
页数:3页
时间:2018-03-28
《多时钟域数据传递的fpga实现》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、多时钟域数据传递的FPGA实现随着EDA技术的发展,由于其在电子系统设计领域中的明显优势,FPGA已经在许多方面得到了广泛应用特别是在无线通信领域,FPGA以其极强的实时性,指令软件编程的极大灵活性赢得了巨大的市场本文采用FPGA来设计一款广泛应用于计算机、Modem、数据终端以及许多其他数字设备之间的数据传输的专用异步并行通信接口芯片,实现了某一时钟域(如66MHz)的8位并行数据到另一低时钟域(如40MHz)16位并行数据的异步转换,并且客户可以根据自己的要求进行数据定义完成数据在不同时钟域间的正确传递的同时防止亚稳
2、态的出现,保持系统的稳定,是电路设计的关键1时钟域转换中亚稳态的产生触发器是数字电路设计中的一个重要元件,而触发器工作过程中存在数据建立与保持时间的约束,如果这种约束得不到满足,触发器就会进入某个不确定状态——亚稳态亚稳态的存在可能导致连锁反应,以致引起整个系统功能混乱在单时钟域电路设计中由于不存在时钟之间的延迟和错位,所以建立条件和保持条件的时间约束容易满足而在多时钟域里由于各个模块的非同步性,则必须考虑亚稳态的发生,如图1所示2多时钟域数据传递方案多时钟域传递的信号有两种,其一为控制信号,其二为数据流信号针对这两种不
3、同的信号,分别采取不同方案遏制系统堕入亚稳态对控制信号采用同步器装置,即在2个不同的时钟域之间插入同步器;而对于不同独立时钟域之间的数据流传递,为了避免异步时钟域产生错误的采样电平,采用FIFO存储器作为其转换接口,在输入端口使用写时钟写数据,在输出端口使用读时钟读数据,这样就完成了异步时钟域之间的数据交换芯片的总体逻辑框图如图2所示,图中输入输出信号定义如表1所示从逻辑结构上将芯片划分为3块:写时钟域I/OBUFFER、读时钟域I/OBUFFER及FIFO存储器I/OBUFFER的主要作用是对外部信号进行预处理,消除外
4、部信号的毛刺,保证信号可靠并使外部的信号与时钟信号同步,消除不稳定的因素根据信号的数目,BUFFER由相应数目的多个D触发器构成FIFO存储器结构框图如图3所示,他由双端口存储器(DualPortRAM)、写控制单元(WritcControl)和读控制单元(ReadControl)构成其中DUALPORTRAM是由ISE6.0的一个编辑软件COREGENERATER自动生成,使用者只需设定RAM的端口数、内存大小和渎写控制便可以生成一个适合程序的子模块由于读写时钟属于不同的时钟域,满帧信号Frame从写控制单元向读控制单
5、元传递时必须采取同步器(Synchronizer)同步2.1写控制单元设计写控制单元主要的功能是根据写数据有效信号wdataen判断输入数据是否正确,在检测到写入数据帧的开始标志位wsof后开始计数控制写指针waddr的移动,将正确的数据写入DUALPORTRAM中,并在一帧数据写满后向读控制单元发出写数据满帧信号wframe为防止亚稳态的出现,设计中采取了两个措施:一是采用锁存器将帧头信号wsof拉长,确保其被稳定的采集;二是采用Gray编码计数器替代普通二进制编码计数器来控制写指针waddr的移动,因为Gray码相邻
6、两个编码之间有且只有1位发生变化从而抑制了竞争冒险的出现2.2同步器设计写控制单元发出的写数据满帧信号wframe属于控制信号,他从写时域进入读时域必须采用同步器实现信号同步,将写时域的满帧信号wframe变换为读时域的满帧信号rframe由于信号是从高时钟域(66MHz)流向低时钟域(40MHz),因此采用如图4所示的同步器同步器时序图如图5所示,可见在写时域的满帧信号wframe经过3个clka周期延后跨越到读时钟域2.3读控制单元设计数据从写时域传递到读时域,时钟发生了变化,而且读控制单元的行为受到写控制单元及Du
7、alPortRAM中数据的存储情况的双重制约,因此他的设计是整个芯片设计成功的关键由于当DualPortRAM中写入一帧完整的正确数据后才能输出,所以读控制首先必须判断DualPortRAM一帧是否写满榆测到满帧信号rframe后,在等待输出数据帧头信号rfp到来后控制读指针waddr移动读出数据,并置位rvalid表征输出数据的可靠性部分程序没计如下:3多时钟域数据传递的FPGA实现设计方案完成后选用XilinxSpartan.IIFPGA实现电路,并在XilinxISE6.0集成环境下用Modelsim5.7进行了电
8、路仿真图6为写使能信号dataen恒为有效值“1”的仿真结果截图可见,在写使能信号dataen恒为有效值“1”的情况下,在写时钟clka控制下当写数据帧头信号sof有效时,写控制器开始写入数据,接收到连续8个数据后,写控制器发出一个帧满信号wframewframe信号经过异步转换后转换成clkb时钟域的信号在读控制器
此文档下载收益归作者所有