FPGA设计的八个重要知识点

时间:2025-04-28  作者:Diven  阅读:0

1.面积与速度的平衡与互换

FPGA设计的八个重要知识点

这里的面积指一个设计消耗FPGA/CPLD的逻辑资源的数量,对于FPGA可以用消耗的FF(触发器)和LUT(查找表)来衡量,更一般的衡量方式可以用设计所占的等价逻辑门数。

速度指设计在芯片上稳定运行,所能达到的最高频率,这个频率由设计的时序状况来决定,和设计满足的时钟要求,PAD to PAD time ,Clock Setup Time,Clock Hold Time,Clock-to-Output Delay等众多时序特征量密切相关。

面积和速度这两个指标贯穿FPGA/CPLD设计的时钟,是设计质量的评价的终极标准。

面积和速度是一对对立统一的矛盾体。要求一个同事具备设计面积最小,运行频率最高是不现实的。更科学的设计目标应该是在满足设计时序要求(包括对设计频率的要求)的前提下,占用最小的芯片面积。或者在所规定的面积下,是设计的时序余量更大,频率跑的更高。这两种目标充分体现了面积和速度的平衡的思想。

作为矛盾的两个组成部分,面积和速度的地位是不一样的。相比之下,满足时序、工作频率的要求更重要一些,当两者冲突时,采用速度优先的准则。

从理论上讲,如果一个设计时序余量较大,所能跑的速度远远高于设计要求,那么就通过功能模块的复用来减少整个设计消耗的芯片面积,这就是用速度的优势换取面积的节约。反之,如果一个设计的时序要求很高,普通方法达不到设计频率,那么一般可以通过将数据流串并转换,并行复制多个操作模块,对整个设计采取乒乓操作和串并转换的思想运行。

2.硬件原则

硬件原则主要针对HDL代码编写而言

Verilog 是采用了C语言形式的硬件的抽象,本质作用在于描述硬件!最终实现结果是芯片内部的实际电路。所以评判一段HDL代码的优劣的最终标准是:其描述并实现的硬件电路的性能。包括面积和速度两个方面。评价一个设计的代码水平较高,仅仅是说这个设计是由硬件想HDL代码这种表现形式的转换更加流畅、合理。而一个设计最终性能,在更大程度上取决于设计工程师所构想的硬件实现方案的效率以及合理性。(HDL代码仅仅是硬件设计的表达形式)

初学者,片面追求代码的整洁、简短,是错误的。是与HDL的标准背道而驰的。正确的编码方法,首先要做到对所需实现的硬件电路胸有成竹,对该部分的硬件的结构和连接十分清晰,然后再用适当的HDL语句表达出来即可。

另外,Verilog作为HDL语言,是分层次的。系统级--算法级--寄存器传输级--逻辑级--门级--开关级。

构建优先级树会消耗大量的组合逻辑,所以如果能够使用case的地方,尽量使用case代替if.....else......

3.系统原则

系统原则包含两个层次的含义:更高层面上看,是一个硬件系统,一块单板如何进行模块花费和任务分配,什么样的算法和功能适合放在FPGA里面实现,什么样的算法和功能适合放在DSP,CPU里面实现,以及FPGA的规模估算数据接口设计等。具体到FPGA设计就要对设计的全局有个宏观上的合理安排,比如时钟域,模块复用,约束,面积,速度等问题。在系统上模块的优化最为重要。

一般来说实时性要求高,频率快的功能模块适合FPGA实现。而FPGA和CPLD相比,更适合实现规模较大,频率较高、寄存器较多的设计。使用FPGA/CPLD设计时,应该对芯片内部的各种底层硬件资源,和可用的设计资源有一个较深刻的认识。比如FPGA一般触发器资源丰富,CPLD的组合逻辑资源更加丰富。FPGA/CPLD一般是由底层可编程硬件单元,BRAM,布线资源,可配置IO单元,时钟资源等构成。底层可编程硬件单元一般由触发器和查找表组成。Xilinx的底层可编程硬件资源较SLICE,由两个FF和2个LUT构成。Altera 的底层硬件资源叫LE,由1个FF和1个LUT构成。

使用片内RAN可以实现单口RAM,双口RAM,同步、异步FIFO,ROM,CAM等常用单元模块。

一般的FPGA系统规划的简化流程

4.同步设计原则

异步电路

电路的逻辑核心是用组合逻辑电路实现。比如异步的FIFO/RAM读写信号,地址译码等电路。电路的主要信号、输出信号等并不依赖于任何一个时钟性信号,不是由时钟信号驱动FF产生的。

异步时序电路的最大缺点是容易产生毛刺。在布局布线后仿真和用逻辑分析仪观测实际信号时,这种毛刺尤其明显。

同步时序 

电路的核心逻辑用各种各样的触发器实现

电路的主要信号、输出信号都是由某个时钟沿驱动触发器产生出来的。

同步时序电路可以很好的避免毛刺。布局布线后仿真,和用逻辑分析仪采样实际工作信号都没有毛刺。

是否时序电路一定比异步电路使用更多的资源呢?

从单纯的ASCI设计来看,大约需要7个门来实现一个D触发器,而一个门即可实现一个2输入与非门,所以同步时序电路比异步电路占用更大的面积。(FPGA/CPLD中不同,主要是因为单元块的计算方式)

如何实现同步时序电路的延时?

异步电路产生延时的一般方法是插入一个Buffer,两级与非门等。这种延时调整手段是不适用同步时序设计思想的。首先要明确一点HDL语法中的延时控制语法,是行为级的代码描述,常用于仿真测试激励,但是在电路综合是会被忽略,并不能启动延时作用。

同步时序电路的延时一般是通过时序控制完成的。换句话说,同步时序电路的延时被当做一个电路逻辑来设计。对于比较大的和特殊定时要求的延时,一般用高速时钟产生一个计数器,通过计数器的计数控制延迟;对于比较小的延时,可以用D触发器打一下,这种做法不仅仅使信号延时了一个时钟周期,而且完成了信号与时钟的初次同步,在输入信号采样和增加时序约束余量中使用。

同步时序电路的时钟如何产生?

时钟的质量和稳定性直接决定着同步时序电路的性能。

输入信号的同步

同步时序电路要求对输入信号进行同步化,如果输入数据的节拍和本级芯片的处理时钟同频,并且建立保持时间匹配,可以直接用本级芯片的主时钟对输入数据寄存器采样,完成输入数据的同步化。如果输入数据和本级芯片的处理时钟是异步的,特别是频率不匹配的时候,则要用处理时钟对输入数据做两次寄存器采样,才能完成输入数据的同步化。

是不是定义为Reg型,就一定综合成寄存器,并且是同步时序电路呢?

答案的否定的。Verilog中最常用的两种数据类型Wire和Reg,Wire型指定书数据和网线通过组合逻辑实现,而reg型指定的数据不一定就是用寄存器实现。

5.乒乓操作

乒乓操作是一个常常应用于数据流控制的处理技巧。

数据缓冲模块可以为任何的存储模块,比较常用的存储模块为双口RAM(DPRAM),单口RAM(SPRAM),FIFO等。在等一个缓冲周期,将输入的数据流缓存到数据缓存模块1,在第二个缓冲周期,通过输入数据流选择单元,将输入的数据流缓存到数据缓冲模块2.乒乓操作的最大特点是,通过输入数据选择单元和输出数据选择单元,进行运算和处理。把乒乓操作模块当成一个整体,站在两端看数据,输入数据和输出数据流都是连续不断的,没有任何停顿,因此非常适合对数据流进行流水线式处理。所以乒乓操作常常应用于流水线式算法,完成数据的无缝缓冲和处理。

乒乓操作的第二个优点是可以节约缓冲区空间。比如在WCDMA基带应用中,1帧是由15个时隙组成的,有时需要将1整帧的数据延时一个时隙后处理,比较直接的方法就是将这帧数据缓存起来,然后延时一个时隙,进行处理。这时缓冲区的长度为1帧的数据长,假设数据速率是3.84Mb/s,1帧10ms,此时需要缓冲区的长度是38400bit,如果采用乒乓操作,只需定义两个缓冲1时隙的数据RAM,当向一个RAM写数据时,从另一块RAM读数据,然后送到处理单元处理,此时每块RAM的容量仅需2560bit,2块加起来5120bit的容量。

巧妙的运用乒乓操作,还可以达到低速模块处理高速数据流的效果。

6.串并转换

7.流水线操作

流水线处理是高速设计中一个常用的设计手段。如果某个设计的处理流程分为若干步骤,而且整个数据处理是单流向的。则可以考虑采用流水线设计方法提高系统的工作频率。

其基本结构为:将适当划分的n个操作步骤单流向串联起来。流水线操作的最大特点和要求是,数据在各个步骤的处理,从时间上是连续的,如果将每个操作步骤简化假设为一个通过D触发器(就是用寄存器打一个节拍),那么流水线操作就类似一个移位寄存器组,数据流依次流经D触发器,完成每个步骤的操作。流水线设计时序图如下:

流水线设计的关键在于,整个设计时序的合理安排。要求每个操作步骤的划分合理。如果前级操作时间恰好等于后级操作时间,设计最为简单,前级的输出直接汇入后级的输入即可。如果前级操作时间大于后级操作时间,则需要进行适当缓存。如果前级操作时间小于后级操作时间,则必须通过复制逻辑,将数据流分流,或在前级对数据采用存储、后处理的方式。否则会造成后级数据的溢出。

8.数据接口的同步方法

数据接口的同步在FPGA/CPLD设计中一个常见问题。很多设计工作不稳定都是源于数据接口的同步问题。

1.输入输出的延时不可测,或者可能有变动,如何完成数据的同步?

对于数据延迟不可测或者变动,就需要建立同步机制。或者用一个同步使能,或者同步指示信号。另外使数据通过RAM或者FIFO的存取,也可以达到数据同步的目的。

把数据存放在RAM或FIFO的方法如下,将上级芯片提供的数据随路时钟作为写信号,将数据写入RAM或者FIFO,然后使用本级时钟的采样时钟(一般是数据处理的主时钟),将数据读出来即可。这种做法的关键是数据写入RAM或者FIFO要可靠,如果使用同步RAM或者FIFO,就要求有一个与数据延迟相对关系固定的随路指示信号。

猜您喜欢

现代电子元器件中,贴片电阻体积小、性能稳定而应用于各种电路中。贴片电阻的封装方法直接影响其性能、散热效果以及在电路中的适用性。本文将对常用的贴片电阻封装方法进行...
2025-03-19 08:00:01

你是否担心过家里的电费居高不下?其实,除了日常用电习惯,电路本身的功率因数也是影响电费的一个重要因素。今天,我们就来介绍一种能够有效提高功率因数、节约电能的利器...
2024-11-07 00:00:00

贴片电阻是电子电路中不可或缺的元件,其封装尺寸直接影响电路板的设计和空间利用。常见的贴片电阻封装尺寸使用四位数字表示,前两位表示长度,后两位表示宽度,单位是毫米...
2024-11-26 11:29:45

按键开关是常见的电气元件,应用于各种电子设备中。基本功能是通过物理按压来实现电路的开闭,从而控制设备的启动或停止。按键开关通常由外壳、按键、弹簧和触点等部分组成...
2022-08-26 00:00:00

智能手机不离手的时代,手机电池的续航能力成为用户关注的焦点。如何正确充电,延长电池寿命,成为每个人都需要了解的知识。告别电量焦虑,你需要掌握一些手机电池充电的小...
2024-01-05 00:00:00

现代生活中,稳定可靠的电力供应很重要。然而,停电事故时有发生,可能对生产生活造成严重影响。为了应对这种突发情况,自带电源非集中控制应急配电箱应运而生,为关键时刻...
2024-08-27 00:00:00

钢丝是应用于工业和日常生活中的重要材料,根据不同的生产工艺、用途和性能,可以将其分类为多种类型。按材料分,钢丝可分为碳钢丝、不锈钢丝和合金钢丝。碳钢丝优良的强度...
2013-12-11 00:00:00

贴片电阻上的数字和字母可不是随意印上去的,它们代表着电阻的阻值。快速掌握解读方法,让你轻松识别不同电阻!最常见的标识方法是三位数字,例如「102」。前两位数字是...
2025-04-14 15:02:25

在购物时,商品的规格和尺寸往往是消费者关注的重点,尤其是在选择未分类商品时。未分类商品通常指的是那些没有明确分类或标签的商品,因此了解其规格和尺寸显得尤为重要。...
2008-02-17 00:00:00

贴片电阻是电子电路中不可或缺的元器件,其阻值的选择至关重要。常用贴片电阻的阻值范围非常广泛,涵盖了从几欧姆到几兆欧姆的各种数值,以满足不同电路设计的需求。一般来...
2025-04-14 15:01:54