《(精品)第1章FPGA概述-新教材.ppt》由会员分享,可在线阅读,更多相关《(精品)第1章FPGA概述-新教材.ppt(35页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、第第1 1章章 FPGA概述概述 l重点重点 FPGA的基本工作原理的基本工作原理 FPGA的芯片结构的芯片结构 IP核简介核简介 FPGA常见技术常见技术 l FPGAField Programmable Gate Array 现场可编程门阵列现场可编程门阵列 (1)侧重于低成本应用、容量中等、性能可以满足一般逻辑设侧重于低成本应用、容量中等、性能可以满足一般逻辑设计要求的计要求的Spartan系列系列 Xilinx的的FPGA产品主要分为两大类:产品主要分为两大类:FPGA市场占有率最高的两大公司市场占有率最高的两大公司Xilinx和和Altera l FPGA属于专用集成电路芯片属于专用
2、集成电路芯片 ASIC (2)侧重于高性能应用、容量大、性能可满足各类高端应用的侧重于高性能应用、容量大、性能可满足各类高端应用的Virtex系列系列 l查找表查找表(Look-Up-Table)结构结构 查找表查找表(Look-Up-Table)简称为简称为LUT,LUT本本质上就是一个质上就是一个RAM。目前目前FPGA中多使用中多使用4输入的输入的LUT,所以每一,所以每一个个LUT可以看成是一个有可以看成是一个有4位地址线的位地址线的RAM。当用。当用户通过原理图或户通过原理图或HDL语言描述一个逻辑电路以后,语言描述一个逻辑电路以后,PLD/FPGA开发软件会自动计算逻辑电路的所有可
3、开发软件会自动计算逻辑电路的所有可能结果,并把真值表能结果,并把真值表(即结果即结果)写入写入RAM,这样,每,这样,每输入一个信号进行逻辑运算就等于输入一个地址去输入一个信号进行逻辑运算就等于输入一个地址去进行查表,找出地址对应的内容,然后输出即可。进行查表,找出地址对应的内容,然后输出即可。1.1 FPGA的基本工作原理的基本工作原理 LUT示例芯片组成芯片组成 1.2 FPGA的芯片结构的芯片结构 主要有可编程输入主要有可编程输入/输出单元、基本可编程逻辑单输出单元、基本可编程逻辑单元、内嵌元、内嵌SRAM、布线资源、底层嵌入功能单元和、布线资源、底层嵌入功能单元和内嵌专用单元等内嵌专用
4、单元等。1.1.可编程输入输出单元(可编程输入输出单元(IOB)IOB单元是芯片与外界电路的接口部分,可单元是芯片与外界电路的接口部分,可完成不同电气特性下对输入完成不同电气特性下对输入/输出信号的驱输出信号的驱动与匹配要求动与匹配要求.FPGA的的IOB被划分为若干个组被划分为若干个组(Bank),每个,每个Bank的接口的接口标准由其接口电压标准由其接口电压VCCO决定,一个决定,一个Bank只能有一种只能有一种VCCO,但不同,但不同Bank的的VCCO可以不同。只有相同电气标可以不同。只有相同电气标准的端口才能连接在一起,要求准的端口才能连接在一起,要求VCCO电压相同是接口标电压相同
5、是接口标准的基本条件。准的基本条件。典型的典型的IOB内部结构示意图内部结构示意图 2.2.可配置逻辑块可配置逻辑块(CLB)CLB是是FPGA内的基本逻辑单元内的基本逻辑单元.CLB的实际数量和特性会依据器件的不同而不同,但是每的实际数量和特性会依据器件的不同而不同,但是每个个CLB都包含一个可配置开关矩阵,此矩阵由选型电路都包含一个可配置开关矩阵,此矩阵由选型电路(多多路复用器等路复用器等)、触发器和、触发器和4或或6个输入组成。个输入组成。典型的典型的CLB结结构示意图构示意图 在Spartan-和E系列中,每个CLB含有两个切片(Slice),每个Slice包括两个LC。Slice内部
6、结构如图所示,Look-Up Table(LUT),Carry and Control Logic(CCL,进位控制逻辑)。除了4个基本的LC外,在CLB模块中还包括附加逻辑和运算逻辑。CLB模块中的附加逻辑可以将2个或4个函数发生器组合起来,用于实现更多输入的函数发生器。3.3.数字时钟管理模块(数字时钟管理模块(DCM)Xilinx推出的推出的FPGA可提供数字时钟管理和可提供数字时钟管理和相位环路锁定。相位环路锁定。DCM的主要优点在于:的主要优点在于:可实现零时钟偏移(可实现零时钟偏移(Skew),消除时钟分配延),消除时钟分配延迟,并实现时钟闭环控制。迟,并实现时钟闭环控制。时钟可以
7、映射到时钟可以映射到PCB上用于同步外部芯片,这上用于同步外部芯片,这样就减少了对外部芯片的要求,而将芯片内外的样就减少了对外部芯片的要求,而将芯片内外的时钟控制一体化,以利于系统设计。时钟控制一体化,以利于系统设计。DCM模块的关键参数:输入时钟频率范围、输出模块的关键参数:输入时钟频率范围、输出时钟频率范围和输入时钟频率范围和输入/输出时钟允许抖动范围等。输出时钟允许抖动范围等。4.4.嵌入式块嵌入式块RAM(BRAM)大多数大多数FPGA都具有内嵌的块都具有内嵌的块RAM,这大大,这大大拓展了拓展了FPGA的应用范围和灵活性。的应用范围和灵活性。块块RAM可被配置为单端口可被配置为单端口
8、RAM、双端口、双端口RAM、内容地址存储器(内容地址存储器(CAM)以及)以及FIFO等常用的存储块。等常用的存储块。在实际应用中,芯片内部块在实际应用中,芯片内部块RAM的数量也是选择的数量也是选择芯片的一个重要因素。芯片的一个重要因素。单片块单片块RAM的容量为的容量为18 kb,可以将多片块,可以将多片块RAM级联起来形成更大的级联起来形成更大的RAM。5.5.丰富的布线资源丰富的布线资源 布线资源连通布线资源连通FPGA内部的所有单元,而连内部的所有单元,而连线的长度和工艺决定着信号在连线上的驱动线的长度和工艺决定着信号在连线上的驱动能力和传输速度。能力和传输速度。根据工艺、长度、宽
9、度和分布位置的不同,可将根据工艺、长度、宽度和分布位置的不同,可将FPGA芯片的内部布线资源划分为四个不同的类别:芯片的内部布线资源划分为四个不同的类别:第一类是全局布线资源;第一类是全局布线资源;第二类是长线资源;第二类是长线资源;第三类是短线资源;第三类是短线资源;第四类是分布式的布线资源。第四类是分布式的布线资源。6.6.底层内嵌功能单元底层内嵌功能单元 内嵌专用硬核是相对于底层嵌入的软核而言内嵌专用硬核是相对于底层嵌入的软核而言的,硬核(的,硬核(Hard Core)使)使FPGA具有强大具有强大的处理能力,等效于的处理能力,等效于ASIC电路。电路。IP(Intelligent Pr
10、operty)核)核1.3 IP核简介核简介 是具有知识产权的集成电路芯核总称,是是具有知识产权的集成电路芯核总称,是经过反复验证过的、具有特定功能的宏模经过反复验证过的、具有特定功能的宏模块,与芯片制造工艺无关,可以移植到不块,与芯片制造工艺无关,可以移植到不同的半导体工艺中。同的半导体工艺中。IP核的提供方式上看,通常将其分为软核、硬核和核的提供方式上看,通常将其分为软核、硬核和固核这三类。从完成固核这三类。从完成IP核所花费的成本来讲,硬核核所花费的成本来讲,硬核代价最大;从使用灵活性来讲,软核的可复用性代价最大;从使用灵活性来讲,软核的可复用性最高。最高。其优点是灵活性高,可移植性强,
11、允许用户自其优点是灵活性高,可移植性强,允许用户自配置。其缺点是对模块的预测性较低,在后续配置。其缺点是对模块的预测性较低,在后续设计中存在发生错误的可能性,有一定的设计设计中存在发生错误的可能性,有一定的设计风险。软核是风险。软核是IP核应用最广泛的形式。核应用最广泛的形式。1.软核软核 在在FPGA设计中,指的是对电路设计中,指的是对电路的硬件语言描述,包括逻辑描述、的硬件语言描述,包括逻辑描述、网表和帮助文档等。网表和帮助文档等。与软核相比,固核的设计灵活性稍差,但在可与软核相比,固核的设计灵活性稍差,但在可靠性上有较大提高。目前,固核也是靠性上有较大提高。目前,固核也是IP核的主核的主
12、流形式之一。流形式之一。2.固核固核 在在FPGA设计中,可以看成是带设计中,可以看成是带有布局规划的软核,通常以有布局规划的软核,通常以RTL代码和对应具体工艺网表的混合代码和对应具体工艺网表的混合形式提供。形式提供。IP硬核的不允许修改特点使其复用有一定的困硬核的不允许修改特点使其复用有一定的困难,因此只能用于某些特定应用,使用范围较难,因此只能用于某些特定应用,使用范围较窄。窄。3.硬核硬核在在FPGA设计中,指布局和工艺设计中,指布局和工艺固定、经过前端和后端验证的设固定、经过前端和后端验证的设计,设计人员不能对其修改。计,设计人员不能对其修改。1.数字时钟管理数字时钟管理DCM 1.
13、4 FPGA常见技术常见技术 数字时钟管理模块(数字时钟管理模块(DCM,Digital Clock Manager)是基于)是基于Xilinx的其他系列器件的其他系列器件所采用的数字延迟锁相环(所采用的数字延迟锁相环(DLL,Delay Locked Loop)模块。)模块。DCM由四部分组成由四部分组成:1.DLL模块;模块;2.数字频率合成器数字频率合成器DFS 3.数字移相器数字移相器DPS 4.数字频谱扩展器数字频谱扩展器DSS DCM功能块和功能块和相应的信号相应的信号 DLL主要由一个延时线和控制逻辑组成。主要由一个延时线和控制逻辑组成。延时线对时钟输入端延时线对时钟输入端CLK
14、IN产生一个延时,产生一个延时,时钟分布网线将该时钟分配到器件内的各时钟分布网线将该时钟分配到器件内的各个寄存器和时钟反馈端个寄存器和时钟反馈端CLKFB;控制逻辑在反馈时钟到达时,采样输入时控制逻辑在反馈时钟到达时,采样输入时钟以调整二者之间的偏差,实现输入和输钟以调整二者之间的偏差,实现输入和输出的零延时。出的零延时。(1)DLL模模块块 DLL简单模简单模型示意图型示意图 在在FPGA设计中,消除时钟的传输延迟,实现高扇出设计中,消除时钟的传输延迟,实现高扇出最简单的方法就是用最简单的方法就是用DLL,把,把CLK0与与CLKFB相连即相连即可。可。Xilinx DLL的典的典型模型示意
15、图型模型示意图 利用一个利用一个DLL可以可以实现实现2倍频输出倍频输出 利用两个利用两个DLL就可就可以实现以实现4倍频输出倍频输出 DFS可以为系统产生丰富的频率合成时钟可以为系统产生丰富的频率合成时钟信号,输出信号为信号,输出信号为CLKFB和和CLKFX180,可提供输入时钟频率分数倍或整数倍的时可提供输入时钟频率分数倍或整数倍的时钟输出频率方案,输出频率范围为钟输出频率方案,输出频率范围为1.5320 MHz(不同芯片的输出频率范围是不(不同芯片的输出频率范围是不同的)。同的)。(2)数字频率合成器数字频率合成器DFS 输入频率和输出频率之间的关系为输入频率和输出频率之间的关系为 D
16、CM具有移动时钟信号相位的能力,因此具有移动时钟信号相位的能力,因此能够调整能够调整I/O信号的建立时间和保持时间,信号的建立时间和保持时间,能支持对其输出时钟进行能支持对其输出时钟进行0,90,180,270的相移粗调和相移细调。的相移粗调和相移细调。(3)数字移相器数字移相器 DCM DSS技术通过展宽输出时钟的频谱,来减少技术通过展宽输出时钟的频谱,来减少EMI和达到和达到FCC要求。这一特点使设计者能要求。这一特点使设计者能够极大地降低系统成本,使电路板重新设计够极大地降低系统成本,使电路板重新设计的可能性降到最小,并不再需要昂贵的屏蔽,的可能性降到最小,并不再需要昂贵的屏蔽,从而缩短
17、了设计周期。从而缩短了设计周期。(4)数字频谱合成器数字频谱合成器 DSS2.串化与解串技术串化与解串技术 串化与解串即串化与解串即Serdes,它能将低速的并行,它能将低速的并行信号转换成高速的串行数据,也可以将高信号转换成高速的串行数据,也可以将高速的串行数据转换成低速的并行数据。速的串行数据转换成低速的并行数据。Serdes的基的基本构成模块本构成模块 3.字对齐技术字对齐技术 字对齐又称为字对齐又称为Comma对齐,用于在将串行对齐,用于在将串行数据转换成并行数据时,确定有效数据的数据转换成并行数据时,确定有效数据的边界,以便使转换后的并行数据正确。边界,以便使转换后的并行数据正确。C
18、omma对齐的原理是:接收器在输入数据流中扫描对齐的原理是:接收器在输入数据流中扫描搜寻特定的比特序列,如果找到序列,解串器调整搜寻特定的比特序列,如果找到序列,解串器调整字符边界以匹配检测到的字符边界以匹配检测到的Comma字符序列,扫描是字符序列,扫描是连续进行的。一旦对齐确定,所有后续的连续进行的。一旦对齐确定,所有后续的Comma字字符均会发现对齐已经确定。当然,在任意的序列组符均会发现对齐已经确定。当然,在任意的序列组合里合里Comma字符序列必须是唯一的。字符序列必须是唯一的。Comma对齐对齐过程过程 4.通道绑定技术通道绑定技术 通道绑定是指将多个串行通道组合在一起通道绑定是指
19、将多个串行通道组合在一起构成一个并行通道,以此来提高收发的数构成一个并行通道,以此来提高收发的数据吞吐率。据吞吐率。由于每个通道在收发器互连、时钟再生和数据接收由于每个通道在收发器互连、时钟再生和数据接收延迟上各不相同,会使接收到的数据产生延迟上各不相同,会使接收到的数据产生“错位错位”的情况,因此要在发送端数据流中加入一个特殊的的情况,因此要在发送端数据流中加入一个特殊的序列序列通道绑定序列,如图通道绑定序列,如图1.14中的中的“P”字符。字符。每个绑定通道都设定每个绑定通道都设定“P”字符为通道绑定序列,在字符为通道绑定序列,在接收端指定一个通道为主通道,其余通道都依据主接收端指定一个通
20、道为主通道,其余通道都依据主通道的通道的CHBONDO有效指示进入绑定状态,进而锁有效指示进入绑定状态,进而锁定本通道在定本通道在Elastic Buffer中接收到通道绑定序列的中接收到通道绑定序列的位置。位置。通道绑定原通道绑定原理示意图理示意图 5.预加重技术预加重技术 在印制的电路板上,线路是呈现低通滤波在印制的电路板上,线路是呈现低通滤波器的频率特性的,为解决高频部分的损失,器的频率特性的,为解决高频部分的损失,就要采取预加重技术。就要采取预加重技术。预加重技术的思想是:在传输信号时,抬高预加重技术的思想是:在传输信号时,抬高信号的高频信号,以补偿线路上高频分量的信号的高频信号,以补
21、偿线路上高频分量的损失。损失。没有预加重没有预加重的发送波形的发送波形 预加重后的预加重后的发送波形发送波形 没有预加重没有预加重的接收波形的接收波形 有预加重的有预加重的接收波形接收波形 思考题思考题 1.1 简述简述FPGA的一般工作原理和结构,查阅资料看看有哪的一般工作原理和结构,查阅资料看看有哪些公司生产些公司生产FPGA产品,各公司的产品,各公司的FPGA产品的工作原理、产品的工作原理、结构与特性有何不同?结构与特性有何不同?1.2 通过查阅资料比较通过查阅资料比较Xilinx的的FPGA芯片中几大系列的发展芯片中几大系列的发展过程,以及该公司的不同过程,以及该公司的不同FPGA芯片的性能与技术特点。芯片的性能与技术特点。1.3 FPGA的芯片组成部分主要有哪些?各个单元的基本构的芯片组成部分主要有哪些?各个单元的基本构造是什么?造是什么?1.4 什么是固核、软核、硬核?三者的区别是什么?什么是固核、软核、硬核?三者的区别是什么?1.5 FPGA涉及的主要技术有哪些?涉及的主要技术有哪些?1.6 DCM模块的优点有哪些?模块的优点有哪些?
限制150内