理解FPGA的基础知识——同步电路设计

同步电路设计将系统状态的变化与时钟信号同步,并通过这种理想化的方式降低电路设计难度。同步电路设计是 FPGA 设计的基础。

触发器

     触发器(Flip Flop,FF)是一种只能存储1个二进制位(bit,比特)的存储单元,并且具备记忆功能,可以用作时序逻辑电路的记忆元件。FPGA逻辑单元内的D触发器(D-FF)具有两个稳定状态,即"0"和"1",在一定的外界信号作用下,可以从一个稳定状态翻转到另一个稳定状态,就是一种在时钟的上升沿(或下降沿)将输入信号的变化传送至输出的边沿触发器。D-FF的符号和真值表如图1所示。D-FF在CLK信号(时钟)的上升沿将输入值传送至输出Q。

图 1  D 触发器

建立时间和保持时间

   时钟是整个电路最重要、最特殊的信号,系统内大部分器件的动作都是在时钟的跳变沿上进行,这就要求时钟信号时延差要非常小, 否则就可能造成时序逻辑状态出错;因而明确FPGA设计中决定系统时钟的因素,尽量较小时钟的延时对保证设计的稳定性有非常重要的意义。

     建立时间(Tsu:set up time)是指在时钟沿到来之前数据从不稳定到稳定所需的时间,如果建立的时间不满足要求那么数据将不能在这个时钟上升沿被稳定的打入触发器;

     保持时间(Th:hold time)是指数据稳定后保持的时间,如果保持时间不满足要求那么数据同样也不能被稳定的打入触发器。 

    CMOS 工艺下的D-FF结构如图2所示,先由传输门和两个反相器组成一个循环电路(锁存器),再由前后两级锁存器按主从结构连接而成。这里的传输门起开关的作用,随着CLK的状态变化切换开关。只看输出的话,前级锁存器的值会将时钟输入的变化井然有序地传入后级锁存器。为了防止时钟信号变化时输入信号发生冒险,从而使稳定的输入信号进入前级锁存器,前级锁存器的时钟相位应该与产生输入信号的电路时钟反向。图3 为 D-FF 的原理图。

图 2 D-FF 的电路结构

图 3  D-FF 的原理

当CLK=0主锁存器工作)时,位于前级的主锁存器将输入D的值保存进来,后级的从锁存器则维持上一时钟周期的数据。由于此时前级和后级反相器环路之间的传输门是关闭状态,所以前级的信号不会传送到后级。当CLK=1(从锁存器工作)时,前级反相器环路中保存的数据会传输到后级,同时输入D的信号会被隔离在外。此时如果前级反相器环路中的信号没有循环一圈以上,就会出现如图4所示的在 0 和 1 之间摇摆的中间电位,这就是所谓的亚稳态(metastable)。由于亚稳态时间比延迟时间长,在该阶段读取数据可能会引入错误,所以我们引入建立时间(setup time)来约束在时钟上升沿到来前输入 D 保持稳定 的时间。

       当 CLK=1 时,如果输入 D 在传输门关闭前就发生变化,那么本该 在下一周期读取的数据就会提前进入锁存器,从而引起反相器环路振荡 或产生亚稳态。因此在 CLK=1 之后也需要输入 D 维持一定的时间,我 们称之为保持时间(hold time)约束。

      为了正确地从输入读取数据,并正确地将数据输出,FPGA 内所有 的 FF 都要遵守建立时间和保持时间等时序上的约束。

                 图4 建立时间和保持时间

时序分析

   从硬件描述语言(Hardware Description Language,HDL)编写的RTL(Register Transfer Level,寄存器传输级)设计代码生成网表(逻辑门间的配线信息)的过程称为逻辑综合。最终决定逻辑综合所生成的电路网表在FPGA中以何种方式实现的两道工序称为布局和布线。FPGA内部规则地摆放着大量设计好的电路及电路间配线,用以实现用户设计。所谓 FPGA 的设计流程,就是决定专为FPGA综合生成的电路摆放在哪儿、电路之间以什么样的布线路径相连的过程。

  为了保证设计好的电路能够正常工作,不单要保证功能(逻辑)正确,还必须要确保时序正确。而时序分析是以分析时间序列的发展过程、方向和趋势,预测将来时域可能达到的目标的方法。此方法运用概率统计中时间序列分析原理和技术,利用时序系统的数据相关性,建立相应的数学模型,描述系统的时序状态,以预测未来。在 FPGA 的设计流程中,从逻辑综合到布局布线,每一步都会对生成的电路进行评估分析。由于基于仿真的方式分析每个逻辑值并进行动态时序分析的方法过于耗时,所以 FPGA 的性能评估主要采用静态时序分析(Static Timing Analysis,STA)。STA只需要提供电路网表就可以进行全面的评估验证,并且原理上只需遍历一次电路的拓扑结构,因此也具有分析速度快的优点。最近,随着电路规模不断增大,不仅FPGA其他 EDA 工具也采用 STA 的方式来验证电路是否能够按照要求的速度正确工作。时序分析包含对设计电路的建立时间分析和保持时间分析,并能够以此进行时序验证。时序验证主要是评估 FPGA 上设计电路的延迟是否满足时序约束(时序上的设计需求)。布线的延迟取决于 FPGA 设计电路的摆放位置和所使用的布线,也就是说取决于布局布线工具的编译结果。当 FPGA 的性能和逻辑门资源富余时编译过程较为容易;相反,当设计电路的规模和 FPGA 片上资源相当时,布局布线过程所需时间可能会很长。时序分析必须检查所有路径上逻辑延迟和布线延迟的时序余裕,确保它们满足建立时间和保持时间的时序约束。

04

单相时钟同步电路

     布局布线上具有一定自由度的 FPGA 都以同步电路设计方式为主, 而同步电路可以使用STA进行时序分析和验证。STA具有验证速度高的优点,但对电路结构有一定的要求:延迟分析的起点和终点必须是基于同一时钟的FF,从而可以通过累加起点和终点间的延迟来计算、验证每条路径的总延迟。因为各条路径上的布线长度长短不一,所以信号的延迟会不同,输出数据变化的时间点也会有所差别。因此如图5所示,FPGA设计中的输入信号会先被送到FF,输出信号则必须从FF引出,并且所有FF都由同相的时钟驱动。这种设计属于由同一时钟的同一边沿同步动作的电路类型,而反相时钟(相位反转的时钟或反方向的边沿)不属于此类。基本上,采用单一时钟进行同步是较为理想的选择。

   同步设计的一个前提是所有FF都必须同时接收到时钟信号,而现实中时钟信号的布线非常长,时钟信号驱动的负荷(扇出数)、布线延迟等原因会导致出现时间差,因此很难严格地满足上述条件。这种时钟信号到达时间的错位称为时钟偏移(skew)。另外,由于时钟振荡器的 变动或信号变形,时钟边沿会偏离平均位置,这种情况称为时钟抖动(jitter)。为了保证所有 FF 的输入时钟信号同步,需要将时钟偏移和时 钟抖动控制在一定范围之内。

图5 单相时钟同步电路 

    时钟偏移和逻辑门电路的延迟一样,会对时钟周期的设定产生影响。因此时钟设计是集成电路时序设计的重要一环。而 FPGA 上已经提前实现好了多层时钟树结构,并且通过驱动能力强的专用布线(global buffer)将时钟低偏移地连接到整个芯片的FF 上,因此在时钟设计上要 比 ASIC 容易很多。 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《FPGA自学笔记——设计与验证》是一本关于FPGA设计和验证的入门教材。本书以VHDL和Verilog两种HDL语言为主要工具,通过实例讲解FPGA的基本概念、设计流程和验证方法。同时,本书还通过实例演示了如何使用Xilinx ISE和ModelSim这两个主流软件工具进行FPGA设计和验证。 本书的内容分为五个部分,分别是FPGA基础知识FPGA设计流程、FPGA验证方法、FPGA性能优化以及FPGA应用实例。其中,FPGA基础知识部分介绍了FPGA的基本构成、组成部件以及通用数字电路设计知识FPGA设计流程部分从设计输入、RTL设计、布局布线、实现生成等方面详细介绍了FPGA设计流程;FPGA验证方法部分主要介绍了功能验证和时序验证这两个方面的知识FPGA性能优化部分介绍了FPGA的几种性能指标以及如何通过一定的优化方法提高FPGA性能;FPGA应用实例部分通过几个实例演示了如何应用FPGA进行数字电路设计。 本书的难度适中,适合初学者学习和参考,同时也可以作为FPGA初学者的参考书籍。本书涉及的知识点较为全面,可以为初学者提供一个全面的FPGA设计和验证入门指南。其内容易于理解,实例讲解深入浅出,对于想要学习FPGA设计和验证的人群来说是一本很好的参考书。 ### 回答2: 《FPGA自学笔记——设计与验证》PDF是一本很好的自学FPGA的书籍。这本书包含了FPGA基本概念、设计流程、Verilog HDL语言、开发工具、测试方法等多个主题,非常详尽地介绍了FPGA的基本知识和开发技巧。读这本书可以帮助我们更好地理解FPGA的原理和功能,从而更加熟练地掌握FPGA设计和验证。 此外,这本书还提供了很多实例来帮助我们更好地理解FPGA设计和验证。这些实例包含多种应用场景,例如数字逻辑、时序控制、通信等,能够帮助我们从不同角度学习FPGA的相关知识。而且,这本书还提供了实验指导,通过做实验来让我们更深入地理解FPGA的各种知识和技能。 总之,这本书《FPGA自学笔记——设计与验证》PDF是一本非常好的FPGA自学指南,通过阅读这本书,我们可以掌握FPGA基本知识和开发技能,更好地应用FPGA进行各种应用开发。我相信,读完这本书,你一定能够对FPGA有更深刻的认识,并且能够灵活运用FPGA进行各种应用开发。 ### 回答3: 《FPGA自学笔记——设计与验证》是一本以FPGA为研究对象的书籍。它详细介绍了FPGA的诸多特性和应用。该书主要分为两部分,第一部分介绍了FPGA的基本概念,并讲解了Verilog的语法和使用方法。第二部分是实践性较强的部分,通过编写案例代码进行实际操作。 该书着重强调了FPGA设计流程,通过案例演示了FPGA设计的全过程。该书还提供了大量的练习题和案例代码,读者可以通过反复练习和实际操作,逐渐掌握FPGA设计和验证技能。 总体来说,《FPGA自学笔记——设计与验证》是一本非常实用的FPGA入门教材。它从基础知识入手,循序渐进地讲解了FPGA的各个方面。并且,该书重点讲解了如何运用Verilog语言进行FPGA设计,这对FPGA初学者来说是一个非常实用的指南。 如果你对FPGA领域感兴趣,且希望通过自学来掌握FPGA的基本操作和设计方法,那么《FPGA自学笔记——设计与验证》是一本非常值得推荐的书籍。  

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值