什么才是FPGA?优势主要体现在哪些方面呢?

FPGA(Field-Programmable GateArray),即现场可编程门阵列,它是在PAL、GAL、CPLD等可编程器件的基础上进一步发展的产物 。它是作为专用集成电路(ASIC)领域中的一种半定制电路而出现的,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点 。
随着人工智能、嵌入式产业的发展,许多行业名词变得越来越熟悉,我们今天所说的FPGA便是如此,但FPGA到底是什么呢?它的优势主要体现在哪些方面呢?很多人就不那么清楚了 。
 
什么是FPGA?
所谓FPGA,即"现场可编程门阵列"(Field Programmable GateArray)的简称 。它是一种开发者在短时间内利用个人PC就可以在其上面实现自己想要的功能,而且可以多次重写的廉价设备 。
事实上, FPGA已经得到了全球大多数用户的支持 。在2005年时,在isuppli提供的调查报告中显示,ASIC和PLD (包含FPGA可编程产品)的销售量排名中,世界前五名里有两个是FPGA供应商 。在业界中,美国XILINX排名世界第一位,IBM排名世界第二位,美国Altera排名世界第四位 。
诞生背景
Xilinx首创了FPGA这一创新性的技术,并于1985年首次推出商业化产品“XC2000” 。
当时的半导体器件以CMOSLSI为主流,相继出现了大规模的逻辑系统 。“门阵列”是当时将逻辑系统LSI化的最简单方法 。门阵列是指由半导体厂商准备出已经在硅片上形成了被称为基本单元的逻辑门的母板,通过按照用户希望的电路进行布线,在母板上形成电路的半客户定制品芯片 。虽然是ASIC中设计和开发的成本和周期最短的,但仍需要几个星期的开发时间 。
 
另一方面,从PROM派生出来的现场可编程器件PLA得到广泛应用 。PLA为一个逻辑器件,用户进行现场(应用领域)编程 。PLA是以集成结构为特征的逻辑LSI,它能够通过与PROM程序相同的设备,写入连接信息 。然后,EPROM和EEPROM之类的新设备相继出现,因为实用且容易使用而广受欢迎 。然而,还是难以自由实现任意的大规模逻辑,它们都只能起到辅助作用 。
在FPGA诞生的初期,计算机研究员是最先感受到FPGA的巨大优势的 。在此之前,要想实现一个新计算机体架构的设计想法,必须要开发一个ASIC作为原型,在面板上安装很多个体积庞大的IC 。但是,与这些需要投入巨大成本和精力的方式不同,一旦用户创建了具有多个FPGA的原型板,就可以立即运行您设计的新架构 。而且,修正和更改规格也变得轻松简单 。因此,许多新的架构应运而生因此,对可重构处理器的研究和对新FPGA架构的研究也开始蓬勃发展,在此之后,FPGA使用灵活,适用性强的特征在通信/图像处理领域也大获好评,并将其应用于路由器等通信网络的各种设备中 。
关于FPGA的编程技术
2000年初,SRAM是当时主流的FPGA编程技术,除此之外还有各种其他类型的FPGA编程技术 。
在20世纪80年代后期,出现了一种具有与SRAM型FPGA不同概念的技术,被称为“熔丝技术”(反熔丝技术) 。在熔丝技术中,电路的连接点是熔丝,通过烧掉熔丝形成回路 。反熔丝元件是一种只能编程一次的存储元件,一旦编程,它就会以低阻抗导通 。据说它比SRAM器件更紧凑,可以实现高集成度、低阻抗的高速运行 。熔丝技术(反熔丝技术)的弊端是不能重写,不能反复使用 。此外,难以降低的价格也是其缺点 。
与此同时,又一个新的器件“CPLD”发布了 。这是一个通过将多个小型 PLD 集成到一个 LSI中形成的可以实现任意大规模逻辑电路的PLD 。与小规模PLD一样,非易失性和可重写的易用性是CPLD的最大特点 。但是,CPLD在设计自由度方面不如FPGA高 。
在1990年代,出现了使用Flashmemory的“FLASH型FPGA” 。Flash型FPGA同时具备了SRAM技术和反熔丝技术的两大有点,即可重写和非易失性 。但是,由于其构造和制造工序复杂,难以提高集成度和降低价格 。因此,Flash基本没有被用在大规模、高速运行的FPGA中 。
FPGA和PLD的架构
基于SRAM的FPGA和CPLD是目前的主流工艺,高速和大规模的应用使用基于SRAM的FPGA,对不需要高速和规模的应用容易上手的CPLD是最合适的 。无论哪种,都有制造简单和价格便宜的优点 。
【什么才是FPGA?优势主要体现在哪些方面呢?】FPGA设计不是简单的芯片研究,主要是利用 FPGA 的模式进行其他行业产品的设计 。与 ASIC不同,FPGA在通信行业的应用比较广泛 。通过对全球FPGA产品市场以及相关供应商的分析,结合当前我国的实际情况以及国内领先的FPGA产品可以发现相关技术在未来的发展方向,对我国科技水平的全面提高具有非常重要的推动作用 。

    推荐阅读