异步多时钟系统的同步设计
- 格式:pdf
- 大小:216.22 KB
- 文档页数:5
异步时钟数据同步方法异步时钟数据同步是指在不同状态、速率或时钟域的两个电子设备之间传输数据时,确保数据的正确性和同步性。
因为不同的状态、速率或时钟域可能导致数据传输的不同步,容易引发数据错误或丢失。
为了解决这个问题,可以采用以下几种方法进行异步时钟数据同步。
1. 同步异步转换器(Synchronizer):同步异步转换器是常用的一种方法,它可以将两个不同时钟域的信号之间建立同步关系。
通常,一个同步异步转换器由两级触发器(Flip-flop)构成。
第一级触发器根据初始时钟域的时钟信号进行触发,而第二级触发器根据目标时钟域的时钟信号进行触发。
这样,可以确保在目标时钟域接收到正确同步的数据。
2. 异步FIFO(First-In-First-Out):异步FIFO是一种具有先进先出功能的存储器,可以在不同时钟域之间传输和同步数据。
异步FIFO通常包括读指针和写指针,用于控制数据的读写和同步。
读指针和写指针的控制逻辑可以根据不同时钟域的时钟信号进行同步,保证数据的正确传输。
3.异步协议:异步协议是一种用于处理异步时钟数据传输的特殊协议。
异步协议通常包括一些额外的控制信号和状态机,用于保证数据的正确传输和同步。
异步协议可以根据不同时钟域的时钟信号进行同步,并且可以在传输数据之前进行握手、校验和错误处理。
4.异步握手协议:异步握手协议是一种用于在异步时钟数据传输中进行数据同步的协议。
异步握手协议通常包括一些额外的控制信号和状态机,用于确保数据的正确传输和同步。
异步握手协议可以根据不同时钟域的时钟信号进行同步,并且可以在传输数据之前进行握手、确认和错误处理。
5.异步串行通信接口:异步串行通信接口是一种用于在不同时钟域之间进行数据传输的接口。
异步串行通信接口通常包括一些特殊的编码和解码技术,用于确保在不同时钟域之间传输的数据的正确性和同步性。
异步串行通信接口可以根据不同时钟域的时钟信号进行同步,并且可以在传输数据之前进行握手、校验和错误处理。
异步FIFO设计同晓荣【摘要】为了解决数字系统中多个时钟不协调的问题,采用可编程逻辑器件为平台设计了一款异步先进先出的数据缓存器,通过使用格雷码编码方式使得亚稳态发生的概率降到最低,最后使用Verilog HDL硬件描述语言在QuartusⅡ软件中仿真验证.%In the digital system there is a plurality of clocks which are not harmonious. An asynchronous FIFO isdesigned in the programmable logic devices. Because the gray code is used, the probability of occurrence of metastabilityis the minimum. Finally the Verilog HDL hardware description language is used and simulated in the Quartus IIsoftware.【期刊名称】《河南科学》【年(卷),期】2012(030)001【总页数】3页(P97-99)【关键词】异步;先进先出;亚稳态;格雷码【作者】同晓荣【作者单位】渭南师范学院数学与信息科学学院,陕西渭南714000【正文语种】中文【中图分类】TP391.8随着微电子工艺的飞速发展,数字系统设计规模也在不断扩大,为了设计的需要,一个系统中往往含有多个时钟.由于不同的时钟之间,时钟频率不相关,使得数据从一个时钟域传递到另一个域时,系统重复地进入亚稳定状态.特别是在高速数据采集系统中,模数转换时钟频率和微型计算机不是同一个时钟频率时,很容易造成采样的过程中采样出错.因此如何设计异步时钟之间的接口电路,是实现异步时钟之间的数据传输的一个关键问题.而解决这个问题的方案是采用异步先进先出的数据缓存器(FIFO).因此异步FIFO在高速数据采集方面具有广泛应用.FIFO是一种先进先出的数据缓冲器,与普通的数据存储器的区别是没有外部读写地址线.这样使用起来非常简单,但缺点就是只能顺序写入数据,顺序地读出数据,其数据地址由内部读写指针自动加1完成,不能像普通存储器那样可以由地址线决定读取或写入某个指定的地址.FIFO分为同步FIFO和异步FIFO.同步FIFO是指读时钟和写时钟为同一个时钟.在时钟沿来临时同时发生读写操作.异步FIFO是指读写时钟不一致,读写时钟是互相独立的.这里主要介绍一种异步FIFO的设计.异步FIFO系统分为读时钟域和写时钟域两个完全独立的时钟域;异步FIFO的存储器是一块双端口RAM,允许同时进行读写操作.在写时钟域部分,由写地址产生逻辑产生写控制信号和写地址;读时钟域部分由读地址产生逻辑产生读控制信号和读地址[1-10].设计异步FIFO系统有两个难点,一是怎样降低亚稳态的发生概率,二是怎样产生空/满标志.亚稳态是指,如果触发器的建立时间/保持时间不满足要求时,可能产生亚稳态,在这个亚稳定期间,触发器可能输出未知电平,经过决断时间之后输出端Q端将稳定到0或1上,但是究竟是0还是1,是随机的,与输入没有必然的关系.即触发器输出端Q在有效时钟边沿到来之后比较长的一段时间处于不确定的状态,在这段时间里输出端Q端可能输出毛刺、振荡、固定的某一电压值,而不是等于数据输入端D的值.在异步的FIFO的实现中,采用可编程逻辑器件FPGA作为开发平台,使用Verilog HDL硬件描述语言,它具有设计灵活、可操作性强等特点.异步FIFO系统具有四个模块,分别为双向端口RAM模块、写控制模块、读控制模块、空/满标志位产生逻辑模块.生成的顶层设计图如图1所示.双端口RAM在普通的随机数据存储器的基础上改进而来,双端口RAM模块有六个端口,分别为读出数据端、写入数据端、读数据端地址、写入数据端地址、读出时钟和写入使能端.双端口RAM在FPGA中的顶层设计图如图2所示.为了降低亚稳态发生概率,对地址采用格雷码编码方式,由于格雷码在相邻的两个码元之间只由一位变换,这就避免计数器与时钟同步的时候发生亚稳态现象.为了保证数据正确的写入或读出,而不发生溢出或读空的状态出现,必须保证FIFO在满的情况下,不能进行写操作,在空的状态下不能进行读操作.而判断FIFO的空/满状态的具体做法是将FIFO地址分成4部分,每部分分别用高两位的最高有效位(MSB),用 00、01、11、10 决定 FIFO 是否为将满或空.如果写指针的高两位MSB小于读指针的高两位MSB则FIFO为“几乎满”,若写指针的高两位MSB大于读指针的高两位MSB则FIFO为“几乎空”.空/满标志位产生逻辑模块在FPGA中的顶层设计图如图3所示.2.2.1 满标志实现满标志是表示FIFO已满或将要满时由FIFO的状态电路送出的一个信号,以阻止FIFO的写操作继续向FIFO中写数据而造成溢出.生成的顶层设计图如图4所示.2.2.2 空标志实现空标志是表示FIFO已空或将要空时由FIFO的状态电路送出的一个信号,以阻止FIFO的读操作继续从FIFO中读出数据而造成无效数据的读出.生成的顶层设计图如图5所示.在Altera公司的FPGA仿真平台QuartusⅡ软件中进行相关仿真,得到的时序图如图6所示,得到的RTL如图7所示.文章在介绍了FIFO的基本概念和工作原理的基础上,分析了亚稳态的产生原因,结合异步FIFO实现的设计难点.设计了一款异步FIFO,并在FPGA开发平台实现,仿真结果表明,格雷码降低了亚稳态出现的概率.【相关文献】[1]谢文华,高文华.FPGA异步FIFO设计中的问题与解决办法[J].单片机与嵌入式系统应用,2009(8):33-35.[2]雷海卫,刘俊.FPGA 中软 FIFO 设计和实现[J].微计算机信息,2008,24(2):207-209.[3]周敏.高速异步 FIFO 的设计和实现[J].计算机工程与科学,2009,31(2):85-87.[4]徐海铭,程月东,刘荣林,等.高速异步 FIFO 设计[J].电子与封装,2009,9(6):14-16.[5]栗永强.基于 FPGA 的高速 FIFO 电路设计[J].电子产品世界,2010,17(4):46-48.[6]于祥凤,刘学斌,胡炳樑,等.基于FPGA的高速数据存储系统中FIFO控制的设计[J].核电子学与探测技术,2010,30(1):59-62.[7]罗先哲,张仁喆,付大鹏.基于FPGA的高速异步FIFO存储器的设计与实现[J].中国科技信息,2009(2):90-94.[8]肖静娴,戴亚文.基于 FPGA 的异步 FIFO 缓存设计[J].电子测量技术,2009,32(11):92-94.[9]庾志衡,叶俊明,邓迪文.基于FPGA与DDR2、SDRAM的大容量异步FIFO缓存设计[J].微型机与应用,2011,30(4):34-36.[10]彭莉,秦建业,付宇卓.异步FIFO 的设计与验证[J].计算机工程与应用,2005,41(3):98-101.。
异步信号同步器设计(2)时间:2011-09-19 14:59 作者:赵信来源:网站投稿三、异步电路中同步的三种方法如果使用GALS设计电路,那么就需要将异步信号进行同步处理,那么同步处理最大的问题就是如何消除亚稳态,本章将主要介绍四种同步方法。
3.1 电平同步器只要在采到异步信号等待足够长的时间,处在亚稳态的触发器就会恢复到一个有效地电平上,这个延时通常通过在采到异步信号的触发器后面再加入一级触发器来实现,也就是说异步信号只有在经过目的时钟域的两级触发器采样后才会对目的时钟域的后续电路起作用。
这样的双触发器构成的异步信号采样逻辑被称为电平同步器。
这些策略不能够消除亚稳态,只是减小亚稳态。
同步使用的两个触发器,这两个触发器之间只要满足hold的要求即可。
注意,如果两个以上的关联信号,需要使用特别的方法,不能使用该方法。
该方法电路如下所示:图4 电平同步器值得注意的是如果第一级触发器进入亚稳态状态,而恢复到稳定电平需要的时间很大,那么第二级触发器很可能采到的数据也是亚稳态状态。
但是事实上实际电路的极小噪声和环境的变化都会是触发器脱离亚稳态状态,所以经过两级触发器同步的后,信号出现亚稳态的可能性就会减小到可以忽略的地步。
如果对性能要求比较高的系统,可以增加同步触发器的级数,来获取更好的稳定性,但是代价是付出更多的同步延时。
这种方法要求两个触发器足够近,时钟的偏斜比较小,且两个触发器之间要满足hold要求。
3.2 脉冲同步器脉冲同步器如下图所示:图5 脉冲同步器波形如下:图6 脉冲同步器波形这种方法的功能是将一个时钟域的单时钟周期信号转换为另一个时钟域的单周期信号,这种方法的局限是两个脉冲之间必须有最小的时间间隔,如果两个脉冲离的太近,那么在同步时钟域的两个脉冲就可能相邻,导致在同步时钟域的信号可能大于一个时钟时钟周期。
如果两个脉冲信号非常近,那么同步器将检测不到任何一个脉冲,一般要求两个脉冲的时间间隔大于两个接受时钟周期。
有一个有趣的现象,众多数字设计特别是与FPGA设计相关的教科书都特别强调整个设计最好采用唯一的时钟域。
换句话说,只有一个独立的网络可以驱动一个设计中所有触发器的时钟端口。
虽然这样可以简化时序分析以及减少很多与多时钟域有关的问题,但是由于FPGA外各种系统限制,只使用一个时钟常常又不现实。
FPGA时常需要在两个不同时钟频率系统之间交换数据,在系统之间通过多I/O接口接收和发送数据,处理异步信号,以及为带门控时钟的低功耗ASIC进行原型验证。
本章讨论一下在FPGA设计中多时钟域和异步信号处理有关的问题和解决方案,并提供实践指导。
这里以及后面章节提到的时钟域,是指一组逻辑,这组逻辑中的所有同步单元(触发器、同步RAM块以及流水乘法器等)都使用同一个网络作为时钟。
假如设计中所有的触发器都使用一个全局网络,比如FPGA的主时钟输入,那么我们说这个设计只有一个时钟域。
假如设计有两个输入时钟,如图1所示,一个时钟给接口1使用,另一给接口2使用,那么我们说这个设计中有两个时钟域。
图1:双时钟域设计平时我们在设计中遇到的门控时钟、衍生时钟以及事件驱动的触发器都可归为时钟域类别。
如图2所示,通过一个简单门控时钟创建了一个新的时钟域。
我们知道,这类时钟控制在FPGA设计中并不被推崇(可以使用时钟使能替代时钟门控),然而它却非常有利于我们理解时钟域这一概念。
本章我们将着重详细讨论以下主题:•两个不同时钟域之间传输信号。
•亚稳态的产生以及对设计的可靠性的影响•通过相位控制避免亚稳态•在时钟域之间传输单个信号,将信号打两拍•使用FIFO在时钟域之间传输多位数据•使用分区同步器模块提高设计的组织架构•处理ASIC验证原型里的门控时钟•建立一个单时钟模块•自动门控移除图2:通过门控时钟创建的时钟域一、跨时钟域设计中包含多时钟域,首先要解决的是在不同时钟域之间传输信号的问题。
信号跨时钟域传输将会是一个大问题,原因如下:1、信号跨时钟域传输产生的故障总是不太容易复现。
同步复位和异步复位的比较3:多时钟系统中复位的处理方法这是一个很实际的问题,因为在较大型的系统中,一个时钟驱动信号显然不能满足要求,一定会根据系统的要求用多个同源时钟当然也可以是非同源了去驱动系统的不同部分;那么在这样的多时钟系统中,复位键怎么设置它的稳定与否直接关系到了整个系统的稳定性,因此要格外注意在我看来,复位信号在同步时序系统中的地位和时钟信号一样重要;下面就说一下具体的处理方法,当然所遵循的原则就仍应该是上文的“异步复位,同步释放”:reset removal:顾名思义,就是同一个系统中的多个同源时钟域的复位信号,由彼此独立的“reset synchronizer”驱动;当异步复位信号有效时,各时钟域同时复位,但是复位释放的时间由各自的驱动时钟决定,也是就说:时钟快的先释放,时钟慢的后释放,但是各复位信号之间没有先后关系;coordinated reset removal:这是相对于上述方式来说的,也就是说各时钟域的复位信号彼此相关,各个部分系统虽然也同时复位,但是却分级释放;而分级的顺序可由各个“reset synchronizer”的级联方式决定;可以先复位前级,再复位后级,也可以反过来;反正方式很灵活,需要根据实际需要而定;由于图片上传问题,我只能用程序表示了,大家凑或看吧,哈哈例子:三级复位系统,系统中的时钟分别为1M,2M,11M:第一级Reset_Sychronizer程序:module Reset_Synchronizeroutput reg rst_n,input clk, asyncrst_n;reg rff1;always posedge clk , negedge asyncrst_n beginif asyncrst_n {rst_n,rff1} <= 2'b0;else {rst_n,rff1} <= {rff1,1'b1};endendmodule第2,3级的Reset_Sychronizer程序:module Reset_Synchronizer2output reg rst_n,input clk, asyncrst_n, d;reg rff1;always posedge clk , negedge asyncrst_n beginif asyncrst_n {rst_n,rff1} <= 2'b0;else {rst_n,rff1} <= {rff1,d};endendmodule顶层模块的源程序:`include ""`include ""module AsynRstTree_Transinput Clk1M,Clk2M,Clk11M,SysRst_ n,output SysRst1M_n,SysRst2M_n,SysRst11M_n;Reset_Synchronizer Rst1M.clkClk1M,. asyncrst_n SysRst_n,.rst_nSysRst1M_n;Reset_Synchronizer2 Rst2M.clkClk2M,.d SysRst1M_n,.asyncrst_nSysRst_n,.rst_nSysRst2M_n;Reset_Synchronizer2 Rst11M.clkClk11M,.d SysRst2M_n,. asyncrst_nSysRst_n,.rst_nSysRst11M_n;endmodule最后,我要说明一下,这两种方法我都试过,复位都很稳定,但并没有明显看出孰优孰劣;不知个人高人是怎么在实际系统中用的,帮忙指点一下呀;哈哈。
一、前言跨时钟域的同步处理,使用异步FIFO是常用的方式之一,对于异步FIFO的设计,网上的大部分资料来源于《Simulation and Synthesis Techniques for Asynchronous FIFO Design》一文其异步FIFO的结构如下图所示本文不是介绍上图描述的设计。
我从基本的数字电路时序开始,介绍异步FIFO的相关问题。
最后介绍如何用时序约束保证设计的正确性二、数字电路时序对于数字电路来讲,我们的信号在时钟边沿发生变化,Dat1信号是一种理想情况,而Dat2是实际情况,其特点是一、相对时钟边沿有延时二、信号变化有一段时间(电平转换时间),在这段时间就是亚稳态在亚稳态期间进行数据采样,不能获得稳定的值。
数字电路中经过时序约束,在T1产生的信号,在T2一定稳定(否则就是不满足时序),所以对于只有一个时钟的数字电路来说,它在T1和T2都能获得稳定的信号(T1时刻的值为0、T2时刻的值为1)三、跨时钟域时序问题对于异步时钟而言(相位不同),对于CLK1产生的信号,CLK2有可能在任意时刻进行数据采样在FIFO的设计中,将会产生2种信号,一种是数据本身(用Data表示),另外一种是指示数据是否有效(用valid表示),注意(valid不一定是一个比特的寄存器,可以是由FIFO中的读写指针产生而来,例如fifo的full或empty状态)异步FIFO的问题在于,如果CLK2在时钟T2进行采样,那么有可能得到valid有效,而数据无效的情况。
这样在CLK2采样取得的设计就是错误的数据。
四、处理异步FIFO的valid和data(理论基础)我们假设valid为低电平表示没有数据,高电平为有数据,解决的办法就是,当CLK对valid进行采样时,即使valid处于亚稳态期间,数据信号也是稳定的如上图所以,在T1时刻进行上升沿采样,虽然valid是一个亚稳态状态,但是此时Data 是一个稳定的值,如果在T1时刻采样的valid为1,那么可以得到稳定的Data信号,如果在T1时刻采样的valid为0,那么控制逻辑认为在T1无法获得数据,从而在下一个时钟获取注意:T2时刻是在下降沿进行采样,而此时的Data信号也是稳定的五、如何实现为了让valid和Data处于上面的状态,我们可以对valid进行延时处理,即使用时钟对其进行采样,必须使用2个寄存器依次采样,才能保证至少有一个时钟的延时valid1是CLK2对valid进行采样产生的,如果采样的时机不好,那么valid1相对valid只有一点点延时,valid2是CLK2对valid1的采样,这样valid2相对于valid至少有CLK2一个周期的延时,也就满足了第二节的条件。
基于多时钟域的异步FIFO设计摘要:在大规模集成电路设计中,一个系统包含了很多不相关的时钟信号,当其目标域时钟与源域时钟不同时,如何在这些不同域之间传递数据成为了一个重要问题。
为了解决这个问题,我们可以用一种异步FIFO(先进先出)存储器来实现。
本文介绍了一种利用格雷码指针实现在多时钟域传递数据的FIFO设计。
关键词:FIFO,多时钟域,异步,格雷码,亚稳态,同步装置1、引言随着计算机、多媒体和数据通信技术的高速发展,数字图像、语音等数据传输技术近年来得到了极大的重视和长足的发展,并得到了广泛的应用。
如何保障这些语音、图像等数据传输的准确性、及时性?如何高效率、高速度地传输这些数据?这些都是当今信息领域的科研人员所必须解决的问题。
而往往在这些数据传输系统中,又会遇到不同系统接口间数据传输的问题。
通常在两个相连接的不同电路系统之间,因为每个系统的数据传输速度不同,在系统的接口部分就会出现数据输入速度和输出速度不同,也就是会发生数据传输速率不匹配的问题。
这种情况往往会让传输的数据产生复写或者丢失,降低数据的传输速率,同时也因为数据复写、丢失和无效数据的读入,将会产生数据出错,因此需要在不同系统的接口处设计数据传输单元来实现数据的高速高效传输。
在现代的系统设计中,为了提高系统的性能,设计者对数据的传输率、数据的传输量,对系统各部分之间的接口部分不同的数据输入和接收传输率的匹配有越来越高的要求,而FIFO存储器以其合理的价格、使用的方便灵活性以及上述的对速度匹配的应用而成为解决这类问题的理想途径,因此FIFO存储器在计算机、多媒体和数据通信领域都有着广泛的应用,因此对FIFO 的研究与设计应用具有理论上和实际应用上的双重意义。
2、FIFO的功能描述FIFO 是数据传输系统中极其重要的一环,特别是在两个处在不同时钟域的系统接口部分,FIFO 的合理设计,不但能使接口处数据传输的输入输出速率进行有效的匹配,不使数据发生复写、丢失和读入无效数据的情况,而且还会有效地提高系统中数据的传输效率,FIFO 存储器主要分为基于移位寄存器型和基于RAM 型,而RAM 型又有单口RAM和双口RAM 之分,目前来说,用的较为广泛的是基于双端口RAM的FIFO。
基于FPGA的异步FIFO设计与实现王伟国;张振东【摘要】随着现代数字电路系统密度和规模的不断扩大,一个系统中通常会包含多个时钟,因此不同时钟之间的数据传输成为亟待解决的问题.而一种可靠易行的解决方案就是异步FIFO.异步FIFO需要非常严格的多时钟技术,难以作出正确的设计合成和分析.本文提出了一种利用格雷码作为读写地址计数器的异步FIFO的设计方法,有效的避免了数据在不同时钟时间传输时遇到的亚稳态问题.并给出了综合仿真结果.%With the expanding of the density and scale of modern digital circuitry,a system will contain multiple clock.Therefore,the transfer of data between different clock becomes a serious problem needs to be solved.A reliable and feasible solution is asynchronous FIFO.Asynchronous FIFO require very strict clock technology,it is difficult to make the correct design of synthesis and analysis.This paper presents a design method of asynchronous FIFO which based on read/write counter in terms of gray code.This method effectively avoid the metastable state in the data transmission between different clock and given a comprehensive simulation results.【期刊名称】《聊城大学学报(自然科学版)》【年(卷),期】2012(025)003【总页数】6页(P79-84)【关键词】多时钟;异步fifo;verilog;HDL;格雷码【作者】王伟国;张振东【作者单位】中国科学院长春光学精密机械与物理研究所,吉林长春130033;中国科学院长春光学精密机械与物理研究所,吉林长春130033/中国科学院研究生院,北京100039【正文语种】中文【中图分类】TN4330 引言随着现代数字电路系统的实时数据处理能力的不断提高,逻辑电路的复杂程度和内核处理器的运算速度也快速增长,在使得一些复杂算法得以实现的同时也加剧了快速CPU与慢速外设之间的冲突.异步FIFO大量数据缓存的能力成功的解决了这一问题,但专用的高速异步FIFO芯片价格昂贵,且容量受限,随着现场可编程逻辑器件容量和速度的不断提高,利用现场可编程逻辑器件设计异步FIFO成为可行的方法.本文首先讨论了异步FIFO设计中经常出现的亚稳态问题和二进制计数器多位同时改变的问题,并给出解决办法,然后讨论了两种格雷码计数器的形式并作出比较,最后给出一种以格雷码为读写地址计数器的异步FIFO的设计方法和在设计异步FIFO时必须要注意的细节.1 多时钟电路中的亚稳态问题在一个时序电路中,合理的建立时间和保持时间是触发器正常工作的前提条件.对于下降沿触发的触发器而言,下降沿触发之前输入数据持续的最短时间是建立时间(setup time),下降沿触发之后输入数据持续的最短时间是保持时间(hold time).当电路时序不能满足setup time/hold time的要求时,系统时序就会出现混乱.在异步时序电路中,不同时钟之间是不存在任何关系的,必然会产生建立时间和保持时间冲突.解决系统时序问题常用双锁存器法如下图1所示,即在不同时钟之间传输数据时连续锁存两次.但是这种方法只是保证了电平的稳定,而在实际的系统中还需要FIFO作为不同时钟之间传输多位数据的接口.图1 避免亚稳态出现的双锁存器法2 异步FIFO指针对于同步FIFO来说,使用一个计数器计算读出和写入到FIFO缓存器中的数据量,计数器在只有写没读是递增,只读没写是递减,既读又写和没读也没写时保持不变.当计数器到达设定值时FIFO满信号置位,为零时空信号置位.在异步FIFO中,由于这种计算数据个数增减的计数器会被两个不同的时钟控制,因此这种计数器不能使用.所以,为了决定FIFO“空”和“满”状态,读指针和写指针必须相互比较.设计FIFO最主要的困难是生成FIFO指针和找到一个决定FIFO“空”和“满”状态的可靠方法.在FIFO设计中,读指针和写指针总是指向下一个要读和写的地址空间.当读或写操作完成后指针自动递增,当FIFO是空时读指针和写指针相等,当FIFO满时读指针和写指针也是相等.一种解决的方法是增加一个多余的MSB位来区分两种状态,当写指针递增超过地址范围时,写指针会递增MSB位,其他位清零,读指针同样也是.当读指针和写指针的MSB位不同时,意味着写指针比读指针多走了一圈,当MSB位相同时意味着走的圈数相等(如图2所示)图2 增加多余MSB后区分FIFO空和FIFO满的方法示意图当FIFO存储缓冲区需要(n-1)位地址时,地址指针用n位,当指针相等(包括MSB位)时空标志置位,当指针低(n-1)位相等且MSB位不等时满标志置位.2.1 二进制FIFO指针的情况二进制地址计数量会有多个位同时变化,因此在把二进制量在不同时钟域之间同步时会出现问题.一个解决的方法是取样并把周期计数量寄存在一个保持寄存器中,并发出一个ready信号,新时钟域收到信号并发出确认信号,这样变化的计数量就安全的传送到新时钟域.用这种方法不会产生上溢和下溢,因为当读指针递增到与写指针相等时,空信号置位,取样的写指针不反映当前写指针的值,而是小于当前值,故永远不能产生下溢,满信号也是如此.最常用的解决方法是用格雷码计数器,格雷码在每个时钟只有一位变换可以极大的减少在同步计数时错误的发生.3 格雷码计数器设计格雷码计数器的方法有很多,这里介绍二种简单直接的方法.下面详细介绍两种方法.3.1 格雷码计数器中的问题为了更好的理解把n-bit计数器转换成(n-1)-bit计数器时出现的问题,先考虑一下一个双重4-bit和3-bit格雷码计数器的例子如图3.图3 4-bit格雷码计数器示例及转换成3-bit格雷码时出现的问题在4-bit计数器中除了MSB位其余位关于中间对称,我们把2nd MSB位反相后,上半部分与下半部分的LSBs便相等.但是经过反相操作后整体便不是格雷码了,例如15(1100)到0(0000)的转变过程有两个bits变化,在下面的第一种格雷码计数器中会有解决方法.3.2 第一种格雷码计数器图4是第一种计数器的框图并是双重格雷码计数器中两个bits同时跳变的解决方法.其中假设输出寄存器的值是格雷码(ptr),此格雷码被输出到格雷码到二进制的转换器中,然后通过一个有条件递增的加法器并输出下一个格雷码值(gnext),连接到输出寄存器的输入端,如框图上半部分所示.(n-1)-bit格雷码简单地通过n-bit格雷码的2个MSBs的异或操作产生,(n-2)个LSBs不变.图4 第一种格雷码计数器示意图及其如何避免了两位同时跳变问题3.3 第二种格雷码计数器此种风格的格雷计数器(如图5所示)用了两组寄存器避免了把格雷码转换成二进制数的步骤.而且第二组寄存器也可以直接用来寻址FIFO存储器.n-bit格雷码指针仍然需要同步到不同的时钟域中.二进制指针可以更容易的通过计算产生“几乎满”和“几乎空”信号.因此在本论文的设计中用此种风格的格雷码计数器.图5 第二种格雷码计数器工作示意图4 总体设计及“空”和“满”信号的产生总体设计如图6所示,本设计方案共有四个模块,双口RAM模块,读控制模块,写控制模块,格雷码同步模块.写控制模块主要是当写使能信号有效且写满信号无效时产生写地址并实行地址递增功能,读控制模块实现相似功能,双口RAM模块用来使缓冲数据其读写动作可同时进行.4.1 “空”和“满”信号的产生“空”信号的产生比较简单,只需同步到读时钟域的写地址格雷码与n-bit的读指针的格雷码完全相等即可代码如下图6 异步FIFO总体设计框图及其信号说明但是,“满”信号的产生就没那么容易,简单地用n-bit格雷码作比较判断“满”信号是不可靠的.因为格雷码除了MSB位外是对称的如图3所示.在图3中假如写指针和读指针都指向地址7,此时写指针递增一次后,写指针指向地址8,读指针和写指针相比较,除了MSB位不同外其余各位均相等,满信号此时有效,但这是不符合实际情况的,错误的.这也是为什么在图4中应用双重n-bit格雷码计数器的一个原因.正确判断满信号的条件是:读写指针的n-bit格雷码的前两个MSBs都不相等,其余的写指针和同步读针相等.代码如下4.2 不同时钟速度因为异步FIFO被两个不同的时钟控制,很明显两个时钟运行在不同的速度下.当把较快的时钟同步到较慢的时钟时,会有一些计数值被跳过.当被同步的格雷码递增两次只被取样一次时也不会出现亚稳态问题,因为亚稳态出现在同步时钟上升沿附近有多位同时跳变时,而在两个同步时钟沿之间有格雷码跳变两次,第一次跳变距离同步时钟条边沿较远,只有第二次跳变在同步时钟沿附近,故不会产生亚稳态.当较快的格雷码计数器在较慢时钟沿之间递增多于一次,不会出现已经溢出却没有检测到的现象,因为同步到写时钟域的读指针滞后于当前的读指针,而写指针只会小于或等于同步读指针,故不会出现溢出.5 设计仿真及总结本设计采用Xilinx公司Spartan3A系列的XC3S1400A,封装时PG484,速度是-4,仿真器是ISE Simulator(VHDL/Verilog),硬件描述语言是Verilog,开发工具是ISE.最后对电路进行时序分析,结果为该FIFO运行速度可达到90.63MHz.wclk、rclk时钟周期分别为:75MHz、80MHz.先向FIFO中写入18个数据,当第16个数据被读入后wfull立即被置位如下图7.图7 写满仿真结果同时向FIFO中写入和读出数据,由于wptr要经过两个读周期才能同步到读时钟域,故在waddr递增后的第二个rclk的上升沿rempty才清零如下图8所示.本文对异步FIFO的结构和重要时序问题给予了详细的阐述,并得到了可靠的仿真结果.在高速数据采集系统中,采用高性能FPGA作为数据预处理和高速异步FIFO 作为数据采集缓存的应用都十分广泛.把FIFO集成在FPGA中简化了电路设计的复杂程度,增加了电路的集成化程度和可靠性,是未来高速数据采集系统的重要发展方向.图8 同时写入读出时的仿真结果参考文献【相关文献】[1] Clifford E.Cummings,Synthesis and Scrip ting Techniques for De signing Multi-Asynchronous Clock Designs[A].SNUG-2001,2001(3):2-8.[2]吴自信,张嗣忠.异步FIFO结构及FPGA设计[J].单片机及嵌入式系统应用,2000,22(3):1.[3]赵雅兴.FPGA原理、设计与应用[M].天津:天津大学出版社,1999.[4]夏宇闻.数字系统设计-Verilog实现[M].北京:高等教育出版社,2006.[5]王金明.Verilog HDL程序设计教程[M].北京:人民邮电出版社,2004.。
含异步清零和同步时钟使能的加法计数器设计(1)实验目的:学习计数器的设计、仿真和硬件测试,进一步熟悉VHDL设计技术。
(2)实验原理:实验程序为例4-22;实验原理参考4.4节(计数器设计),设计流程参考第5章。
【例4-22】设计一个带有异步复位和同步时钟使能的十进制加法计数器。
LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY CNT10 ISPORT(CLK,RST,EN : IN STD_LOGIC;CQ : OUT STD_LOGIC_VECTOR(3 DOWNTO 0);COUT : 0UT STD_LOGIC);END ENTITY CNT10;ARCHITECTURE behav OF CNT10 ISBEGINPROCESS (CLK,RST,EN)VARIABLE CQI : STD_LOGIC_VECTOR(3 DOWNTO 0);BEGINIF RST=‘1’ THEN CQI:=(OTHERS =>‘0’);--计数器异步复位ELSIF C LK’E VENT AND CLK=‘1’ THEN --检测时钟上升沿IF EN=‘1’ THEN --检测是否允许计数(同步他能) IF CQI<9 THEN CQI:=CQI+1; --允许计数,检测是否小于9ELSE CQI := (OTHERS => ‘0’); --大于9,计数值清零END IF;END IF;END IF;IF CQI=9 THEN COUT<=‘1’; --计数大于9,输出进位信号ELSE COUT<=‘0’;END IF;CQ<=CQI; --将计数值向端口输出END PROCESS;END ARCHITECTURE behav;(3)实验内容1:在Quartus II 上对例4-22进行编辑、编译、综合、适配、仿真。