全面解析FPGA基础知识

上传人:ni****g 文档编号:511947672 上传时间:2024-02-07 格式:DOCX 页数:10 大小:191.79KB
返回 下载 相关 举报
全面解析FPGA基础知识_第1页
第1页 / 共10页
全面解析FPGA基础知识_第2页
第2页 / 共10页
全面解析FPGA基础知识_第3页
第3页 / 共10页
全面解析FPGA基础知识_第4页
第4页 / 共10页
全面解析FPGA基础知识_第5页
第5页 / 共10页
点击查看更多>>
资源描述

《全面解析FPGA基础知识》由会员分享,可在线阅读,更多相关《全面解析FPGA基础知识(10页珍藏版)》请在金锄头文库上搜索。

1、全面解析FPGA基础知识FPGA (Field Programmable Gate Array)即现场可编 程门阵列。它是在 PLA、PAL、GAL、CPLD 等可编程器 件的基础上进一步发展的产物。它是作为专用集成电路 (ASIC)领域中的一种半定制电路,既解决了定制电路的不 足,又克服了原有可编程器件门电路数有限的缺点。1、FPGA简介FPGA普遍用于实现数字电路模块,用户可对FPGA 内部的逻辑模块和I/O模块重新配置,以实现用户的需求。 它还具有静态可重复编程和动态在系统重构的特性,使得 硬件的功能可以像软件一样通过编程来修改。可以毫不夸 张的讲,FPGA能完成任何数字器件的功能,下至

2、简单的 74电路,上至高性能CPU,都可以用FPGA来实现oFPGA 如同一张白纸或是一堆积木,工程师可以通过传统的原理 图输入法,或是硬件描述语言自由的设计一个数字系统。2、FPGA发展史FPGA的发展历史如下图所示。相对于PROM、 PAL/GAL、CPLD而言,FPGA规模更大性能更高。时代PPLDI甘代1970如G&算妙龍IE武酸 稀为ND何綁磐H a*HP曲Tii血介址构 茂邮坝特!ft科(W 卜心)内翎H娃相 炖网远 FPG為时代 | 口吊氏於程中一丘| 怛第勒o.哗屛耳 it.折栓宕用吏次廿 能世凸;设计胆屁詁图1 FPGA发展史FPGA芯片主流生产厂家包括Xilinx、Alte

3、ra、Lattice、Microsemi,其中前两家的市场份额合计达到88%。目前 FPGA主流厂商全部为美国厂商。国产FPGA由于研发起 步较美国晚至少20年,目前还处于成长期,仅限于低端, 在通信市场还没有成熟应用。2015年12月,Intel公司斥资167亿美元收购了 Altera 公司。Altera被收购后不久即制定了英特尔处理器与FPGA 集成的产品路线图。这两种产品集成的好处是可以提供创 新的异构多核架构,适应例如人工智能等新市场的需求, 同时能大幅缩减功耗。图2 FPGA在电信领域的应用历史FPGA 在航天、军工、电信领域有非常成熟和广泛的应 用。以电信领域为例,在电信设备一体机

4、阶段,FPGA由 于其编程的灵活性以及高性能被应用网络协议解析以及接 口转换。在 NFV(NetworkFunction Virtualization 阶段, FPGA 基于通用服务器和Hypervisor实现网元数据面5倍的性能 提升,同时能够被通用 Openstack 框架管理编排。在云时代,FPGA已经被作为基本IaaS资源在公有云 提供开发服务和加速服务,AWS、华为、BAT均有类似通 用服务提供。截至目前,Intel的Stratix 10器件已被成功应用于微软 实时人工智能云平台Brainwave项目。3、两家主流FPGA公司发展近况Xilinx 聚焦芯片领先和丰富的加速解决方案,通

5、过开放 策略获得主流云平台支持,确立了其在数据中心的领先地 位。其UltraScale+系列FPGA领先友商1年多,使其在 云平台竞争中占领先机,其 VU9P 器件被大量应用于包括 AWS、Baidu、Ali、Tencent及华为在内的多家公司的云 计算平台。为满足加速器领域对FPGA芯片日益递增的性能需求, Xilinx已发布面向数据中心的下一代ACAP芯片架构、推 出7nm Everest器件。此器件已不属于传统的FPGA,它 集成了 ARM、DSP、Math Engine处理器阵列等内核,将 于2019年量产。相较于VU9P, Everest支持的AI处理性 能将能提升 20 倍。Int

6、el 则提供从硬件到平台到应用的全栈解决方案,不 开放硬件和平台设计以避免生态碎片化,投入巨大但进展 缓慢。28nm1 rimVIRTEXKINTEXVIF?TEX7KINTEX.7VIRTEXKINTEXARTIX:SRR1AN3图 3 Xilinx 产品系列图图4 Intel(以Stratix系列为例)产品工艺年代FPGA 在数据中心服务器市场的实际应用中存在一定 技术难点,具体包括如下几方面:1、编程门槛较高:硬件描述语言不同于软件开发语言, 需要开发者对底层硬件有着较深刻的认识;因此人才也就 成为限制 FPGA 应用的一个重要因素。据了解,目前国内 从事 FPGA 开发的人员初步估计大

7、约两万多人。2、集成难度较大:FPGA开发与应用需要软硬件的协 同,包括使用高级语言的系统建模、硬件代码(电路)设计、 硬件代码仿真、底层驱动软件与硬件逻辑的联调等等。3、开发周期相对软件要长:硬件开发比软件开发过程 复杂,调试周期也被拉长。4、很难获取独立逻辑 IP。4、FPGA 整体结构FPGA架构主要包括可配置逻辑块CLB(Configurable Logic Block)、输入输出块 IOB(lnput Output Block)、内咅B 连线(Interconnect)和其它内嵌单元四个部分。CLB是FPGA的基本逻辑单元。实际数量和特性会依 器件的不同而改变,但是每个 CLB 都包

8、含一个由 4或 6个 输入、若干选择电路(多路复用器等)和触发器组成的可配置 开关矩阵。开关矩阵具有高度的灵活性,经配置可以处理 组合型逻辑、移位寄存器或 RAM。FPGA可支持许多种I/O标准,因而可以为系统设计提 供理想的接口桥接。FPGA内的I/O按bank分组,每个 bank能独立支持不同的I/O标准。目前最先进的FPGA提 供了十多个I/O bank,能够提供灵活的I/O支持。CLB 提供了逻辑性能,灵活的互连布线则负责在 CLB 和 I/O 之间传递信号。布线有几种类型,从设计用于专门 实现 CLB 互连(短线资源)、到器件内的高速水平和垂直长 线(长线资源)、再到时钟与其它全局信

9、号的全局低skew布 线(全局性专用布线资源)。一般,各厂家设计软件会将互连 布线任务隐藏起来,用户根本看不到,从而大幅降低了设 计复杂性。内嵌硬核单元包括RAM、DSP、DCM(数字时钟管理 模块)及其它特定接口硬核等,FPGA器件内部结构如下示 意图。图5 FPGA器件内部结构图一般来说,器件型号数字越大,表示器件能提供的逻辑 资源规模越大。在FPGA器件选型时,用户需要对照此表 格,根据业务对逻辑资源(CLB)、内部BlockRAM、接口(高 速Serdes对数)、数字信号处理(DSP硬核数)以及今后扩 展等多方面的需求,综合考虑项目最合适的逻辑器件。5、FPGA开发流程FPGA的设计流

10、程就是利用EDA开发软件和编程工具 对FPGA芯片进行开发的过程。FPGA的开发流程一般如 下图所示,包括功能定义/器件选型、设计输入、功能仿真、 逻辑综合、布局布线与实现、编程调试等主要步骤。1、功能定义/器件选型:在FPGA设计项目开始之前, 必须有系统功能的定义和模块的划分,另外就是要根据任 务要求,如系统的功能和复杂度,对工作速度和器件本身 的资源、成本、以及连线的可布性等方面进行权衡,选择 合适的设计方案和合适的器件类型。2、设计输入:设计输入指使用硬件描述语言将所设计 的系统或电路用代码表述出来。最常用的硬件描述语言是 Verilog HDL。3、功能仿真:功能仿真指在逻辑综合之前

11、对用户所设 计的电路进行逻辑功能验证。仿真前,需要搭建好测试平 台并准备好测试激励,仿真结果将会生成报告文件和输出 信号波形,从中便可以观察各个节点信号的变化。如果发 现错误,则返回设计修改逻辑设计。常用仿真工具有 Model Tech 公司的 ModelSim、 Sysnopsys 公司的 VCS 等软件。4、逻辑综合:所谓综合就是将较高级抽象层次的描述 转化成较低层次的描述。综合优化根据目标与要求优化所 生成的逻辑连接,使层次设计平面化,供FPGA布局布线 软件进行实现。就目前的层次来看,综合优化是指将设计 输入编译成由与门、或门、非门、RAM、触发器等基本逻 辑单元组成的逻辑连接网表,而

12、并非真实的门级电路。真实具体的门级电路需要利用 FPGA 制造商的布局布 线功能,根据综合后生成的标准门级结构网表来产生。为 了能转换成标准的门级结构网表,HDL程序的编写必须符 合特定综合器所要求的风格。常用的综合工具有 Synplicity 公司的 Synplify/Synplify Pro 软件以及各个 FPGA 厂家自 己推出的综合开发工具。5、布局布线与实现:布局布线可理解为利用实现工具 把逻辑映射到目标器件结构的资源中,决定逻辑的最佳布 局,选择逻辑与输入输出功能链接的布线通道进行连线, 并产生相应文件(如配置文件与相关报告);实现是将综合生 成的逻辑网表配置到具体的 FPGA 芯

13、片上。由于只有 FPGA 芯片生产商对芯片结构最为了解,所以布局布线必 须选择芯片开发商提供的工具。6、编程调试:设计的最后一步就是编程调试。芯片编 程是指产生使用的数据文件(位数据流文件, Bitstream Generaon),将编程数据加载到FPGA芯片中;之后便可进 行上板测试。最后将FPGA文件(如.bit文件)从电脑下载到 单板上的 FPGA 芯片中。6、如何使用 FPGAFPGA 开发完毕,最终得到验证好的加载文件。输出加 载文件后,即可开始正常业务处理和验证(以软件加载方式 为例,描述整个过程)1、逻辑加载;2、单板软件加载逻辑后,需要复位逻辑;3、复位完成后,软件需等待等待一段时间至逻辑锁相 环工作稳定;4、软件启动对逻辑的外部RAM、内部Block RAM、DDRC 等的自检操作;5、软件完成自检以后,对逻辑所有可写 RAM 空间及 寄存器进行初始化操作;6、初始化完毕,软件参考逻辑芯片手册配置表项及寄 存器;7、逻辑准备好,可以开始处理业务。7、FPGA 适用场景FPGA 适合非规则性多并发、密集计算及协议解析处理 场景,例如人工智能、基因测序、视频编码、数据压缩、 图片处理、网络处理等各领域的加速。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号