原创 基于FPGA的时序及同步设计

2008-4-30 17:07 9557 13 18 分类: FPGA/CPLD

FPGA/CPLD重要设计思想及工程应用<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


时序及同步设计篇


 


       这是昨晚的课程,主要讲时钟同步,课上做了一个实验仿真的对比。(<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />08.4.24


概述


数字电路中,时钟是整个电路最重要、最特殊的信号。


第一, 系统内大部分器件的动作都是在时钟的跳变沿上进行, 这就要求时钟信号时延差要非常小, 否则就可能造成时序逻辑状态出错.


第二, 时钟信号通常是系统中频率最高的信号.


第三, 时钟信号通常是负载最重的信号, 所以要合理分配负载。出于这样的考虑在FPGA这类可编程器件内部一般都设有数量不等的专门用于系统时钟驱动的全局时钟网络。这类网络的特点是:一、负载能力特别强, 任何一个全局时钟驱动线都可以驱动芯片内部的触发器; 二是时延差特别小; 三是时钟信号波形畸变小, 工作可靠性好。


因此, FPGA设计中最好的时钟方案是: 由专用的全局时钟输入引脚驱动单个主时钟去控制设计项目中的每一个触发器。同步设计时, 全局时钟输入一般都接在器件的时钟端, 否则会使其性能受到影响。


对于需要多时钟的时序电路, 最好选用一个频率是它们的时钟频率公倍数的高频主时钟。


各个功能模块要使用统一的复位电路。在使用带时钟的触发器、计数器等有复位端的库器件时, 一般应尽量使用有同步复位的器件。注意复位时保证各个器件都能复位, 以避免某些寄存器的初始状态不确定而引起系统工作不可靠。


 


若想掌握时钟设计方法首先需要了解建立时间和保持时间的概念。


建立时间(setup time):是指在触发器的时钟信号上升沿到来以前,数据稳定不变的时间,如果建立时间不够,数据将不能在这个时钟上升沿被打入触发器;保持时间(hold time):是指在触发器的时钟信号上升沿到来以后,数据稳定不变的时间,如果保持时间不够,数据同样不能被打入触发器。


 


对于一个设计项目来说,全局时钟(或同步时钟)是最简单和最可预测的时钟。在CPLD/FPGA设计中最好的时钟方案是:由专用的全局时钟输入引脚驱动的单个主时钟去钟控设计项目中的每一个触发器。只要可能就应尽量在设计项目中采用全局时钟。CPLD/FPGA都具有专门的全局时钟引脚,它直接连到器件中的每一个寄存器。这种全局时钟提供器件中最短的时钟到输出的延时。


 


在许多应用中只将异步信号同步化还是不够的,当系统中有两个或两个以上非同源时钟的时候,数据的建立和保持时间很难得到保证,我们将面临复杂的时间问题,那么这个时候怎么办呢?


最好的方法是将所有非同源时钟同步化,那么又怎么样将非同源时钟同步化呢?


我们可以使用带使能端的D触发器,并引入一个高频时钟(频率高于系统中的所有源时钟),便可以达到使系统中所有源时钟同步的效果。


 


 


 


 


       系统时钟设计:


系统有两个不同源时钟,一个为3MHz,一个为5MHz,不同的触发器使用不同的时钟。为了系统稳定,假设我们引入一个20MHz时钟,那么这个20MHz的时钟怎么才能将3M5M时钟同步化呢?<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />


 


97750f53-7cd0-4a6e-aa90-e4439f334c61.jpg


 


20M的高频时钟将作为系统时钟,输入到所有触发器的的时钟端。3M_EN 5M_EN将控制所有触发器的使能端。即原来接3M时钟的触发器,接20M时钟,同时3M_EN 将控制该触发器使能,原接5M时钟的触发器,也接20M时钟,同时5M_EN 将控制该触发器使能。这样我们就可以将任何非同源时钟同步化。


异步信号输入总是无法满足数据的建立保持时间,所以建议大家把所有异步输入都先经过双触发器进行同步化。


 


 


       下面是用20MHz的时钟作为同步时钟得出的功能仿真波形:(下面一个小波形是将上面一个图的EN_3信号的局部放大,可以明显看出黄线前后两个时钟大小相差了一个主时钟周期,这是因为20/3不为整数导致一个EN_3的脉冲周期有可能6个也有可能7个主时钟周期)



 



点击看大图


 

 fb92b0f8-d29b-498c-ae61-6c5a002793f0.jpg


 


       15MHz的同步时钟功能仿真波形,可以得到一致的EN_3EN_5的脉冲,其高电平保持都为1/20M的时间。



 

点击看大图 


 


       综合后的原理图:



点击看大图


 


在通常的FPGA设计中对时钟偏差的控制主要有以下几种方法:


1、控制时钟信号尽量走可编程器件的的全局时钟网络。在可编程器件中一般都有专门的时钟驱动器及全局时钟网络,不同种类、型号的可编程器件,它们中的全局时钟网络数量不同,因此要根据不同的设计需要选择含有合适数量全局时钟网络的可编程器件。一般来说,走全局时钟网络的时钟信号到各使能端的延时小,时钟偏差很小,基本可以忽略不计。


2、若设计中时钟信号数量很多,无法让所有的信号都走全局时钟网络,那么可以通过在设计中加约束的方法,控制不能走全局时钟网络的时钟信号的时钟偏差。


3、异步接口时序裕度要足够大局部同步电路之间接口都可以看成是异步接口,比较典型的是设计中的高低频电路接口、I/O接口,那么接口电路中后一级触发器的建立-保持时间要满足要求,时序裕度要足够大。


4、在系统时钟大于30MHz时,设计难度有所加大,建议采用流水线等设计方法。


5、要保证电路设计的理论最高工作频率大于电路的实际工作频率。


 


       复位和置位信号处理:


在设计时应尽量保证有一全局复位信号,或保证触发器、计数器在使用前已经正确清零状态。在设计寄存器的清除和置位信号时,应尽量直接从器件的专用引脚驱动。另外,要考虑到有些器件上电时,触发器处于一种不确定的状态,系统设计时应加入全局复位/Reset


这样主复位引脚就可以给设计中的每一个触发器馈送清除或置位信号,保证系统处于一个确定的初始状态。需要注意的一点是:不要对寄存器的置位和清除端同时施加不同信号产生的控制,因为如果出现两个信号同时有效的意外情况,会使寄存器进入不定状态。

文章评论5条评论)

登录后参与讨论

用户1809828 2014-11-21 16:41

学习了,赞

用户574984 2011-5-25 13:22

学习了

用户317668 2011-2-26 13:05

为什么我感觉仿真图中en_3 和 en_5都延后了一个时钟周期?

用户557779 2010-11-29 11:20

我想问一下virtual jtag是上升沿收数据下降沿发数据还是上升沿发数据下降沿收数据

用户408932 2010-9-23 10:00

这个怎么看最终的异步信号同步化了~~~难道是看使能端么~~~看不明白~~楼主能不能详细说明下~~~谢谢~~~myself200481108@163.com

ash_riple_768180695 2010-3-13 07:15

Yes, the proper handling of Clock Domain Crossing issue must be added to any VJI instance.

tengjingshu_112148725 2009-2-15 19:30

学习了~ 欢迎踩踩我的blog: www.ednchina.com/blog/tengjingshu
相关推荐阅读
特权ilove314 2016-06-30 21:16
例说FPGA连载6:FPGA开发所需的技能
例说FPGA连载6:FPGA开发所需的技能 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   前面的文字已经做了很多铺垫,相信读...
特权ilove314 2016-06-28 21:09
例说FPGA连载5:FPGA的优势与局限性
例说FPGA连载5:FPGA的优势与局限性 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   若要准确评估FPGA技术能否满足开...
特权ilove314 2016-06-28 21:05
例说FPGA连载5:FPGA的优势与局限性
例说FPGA连载5:FPGA的优势与局限性 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   若要准确评估FPGA技术能否满足开...
特权ilove314 2016-06-26 22:11
例说FPGA连载4:FPGA语言与厂商介绍
例说FPGA连载4:FPGA语言与厂商介绍 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   Verilog与VHDL 说到FP...
特权ilove314 2016-06-23 21:26
例说FPGA连载3:FPGA与其它主流芯片的比较
例说FPGA连载3:FPGA与其它主流芯片的比较 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   FPGA、ASIC和ASSP...
特权ilove314 2016-06-21 20:32
例说FPGA连载2:FPGA是什么
例说FPGA连载2:FPGA是什么 特权同学,版权所有 配套例程和更多资料下载链接: http://pan.baidu.com/s/1c0nf6Qc   2015年伊始,Intel欲出资百亿美金收...
我要评论
5
13
关闭 站长推荐上一条 /2 下一条