ARM,DSP,FPGA

ARM,DSP,FPGA概念

         ARM (Advanced RISC(精简指令集计算机) Machines)是微处理器行业的一家知名企业,设计了大量高性能、廉价、耗能低的RISC处理器、相关技术及软件。ARM架构是面向低预算市场设计的第一款RISC微处理器,基本是32位单片机的行业标准,它提供一系列内核、体系扩展、微处理器和系统芯片方案,四个功能模块可供生产厂商根据不同用户要求来配置生产。由于所有产品均采用一个通用的软件体系,所以相同的软件可在所有产品中运行。目前ARM在手持设备市场占有90以上的份额,可以有效地短应用程序开发与测试的时间,也降低了研发费用。

       DSP(digital signal processor)是一种独特的微处理器,有自己的完整指令系统,是以数字信号来处理大量信息的器件。一个数字信号处理器在一块不大的芯片内包括有控制单元、运算单元、各种寄存器以及一定数量的存储单元等等,在其外围还可以连接若干存储器,并可以与一定数量的外部设备互相通信,有软、硬件的全面功能,本身就是一个微型计算机。DSP采用的是哈佛设计,即数据总线和地址总线分开,使程序和数据分别存储在两个分开的空间,允许取指令和执行指令完全重叠。也就是说在执行上一条指令的同时就可取出下一条指令,并进行译码,这大大的提高了微处理器的速度。另外还允许在程序空间和数据空间之间进行传输,因为增加了器件的灵活性。

         工作原理是接收模拟信号,转换为0或1的数字信号,再对数字信号进行修改、删除、强化,并在其他系统芯片中把数字数据解译回模拟数据或实际环境格式。它不仅具有可编程性,而且它的实时运行速度可达每秒数以千万条复杂指令程序,远远超过通用微处理器,是数字化电子世界中日益重要的电脑芯片。它的强大数据处理能力高运行速度,是最值得称道的两大特色。由于它运算能力很强,速度很快,体积很小,而且采用软件编程具有高度的灵活性,因此为从事各种复杂的应用提供了一条有效途径。

        DSP芯片一般具有如下主要特点
(1)在一个指令周期内可完成一次乘法和一次加法
(2)程序和数据空间分开,可以同时访问指令和数据
(3)片内具有快速RAM通常可通过独立的数据总线在两块中同时访问
(4)具有低开销或无开销循环及跳转的硬件支持
(5)快速的中断处理和硬件I/O支持
(6)具有在单周期内操作的多个硬件地址产生器
(7)可以并行执行多个操作
(8)支持流水线操作,使取指、译码和执行等操作可以重叠执行

      FPGA是英文Field Programmable Gate Array(现场可编程门阵列)的缩写,它是在PAL、GAL、PLD等可编程器件的基础上进一步发展的产物,是专用集成电路(ASIC)中集成度最高的一种。FPGA采用了逻辑单元阵列LCA(Logic Cell Array)这样一个新概念,内部包括可配置逻辑模块CLB(Configurable Logic Block)、输出输入模块IOB(Input Output Block)和内部连线(Interconnect)三个部分。用户可对FPGA内部的逻辑模块和I/O模块重新配置,以实现用户的逻辑。它还具有静态可重复编程和动态在系统重构的特性,使得硬件的功能可以像软件一样通过编程来修改。作为专用集成电路(ASIC)领域中的一种半定制电路,FPGA既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点可以毫不夸张的讲,FPGA能完成任何数字器件的功能,上至高性能CPU,下至简单的74电路,都可以用FPGA来实现。FPGA如同一张白纸或是一堆积木,工程师可以通过传统的原理图输入法,或是硬件描述语言自由的设计一个数字系统。通过软件仿真,我们可以事先验证设计的正确性。在PCB完成以后,还可以利用FPGA的在线修改能力,随时修改设计而不必改动硬件电路。使用FPGA来开发数字电路,可以大大缩短设计时间,减少PCB面积,提高系统的可靠性。FPGA是由存放在片内RAM中的程序来设置其工作状态的,因此工作时需要对片内的RAM 进行编程。用户可以根据不同的配置模式,采用不同的编程方式。加电时,FPGA芯片将EPROM中数据读入片内编程RAM中,配置完成后,FPGA进入工作状态。掉电后,FPGA恢复成白片,内部逻辑关系消失,因此,FPGA能够反复使用。FPGA的编程无须专用的FPGA编程器,只须用通用的 EPROM、PROM编程器即可。当需要修改FPGA功能时,只需换一片EPROM即可。这样,同一片FPGA,不同的编程数据,可以产生不同的电路功能。因此,FPGA的使用非常灵活。可以说,FPGA芯片是小批量系统提高系统集成度、可靠性的最佳选择之一。目前FPGA的品种很多,有XILINX的 XC系列、TI公司的TPC系列、ALTERA公司的FIEX系列等。

 ARM,DSP,FPGA区别
        ARM
具有比较强的事务管理功能,可以用来跑界面以及应用程序等,其优势主要体现在控制方面,而DSP主要是用来计算的,比如进行加密解密、调制解调等,优势是强大的数据处理能力和较高的运行速度。FPGA可以用VHDL或verilogHDL来编程,灵活性强,由于能够进行编程、除错、再编程和重复操作,因此可以充分地进行设计开发和验证。当电路有少量改动时,更能显示出FPGA的优势,其现场编程能力可以延长产品在市场上的寿命,而这种能力可以用来进行系统升级或除错。


ARM,DSP,FPGA相关问答

       问:现在DSP跟微处理器结合的情况比较多,实现DSP功能的FPGA是否也要和微处理器合作

       答:现在90%以上的FPGA都运用在处理器上,这也正是FPGA这方面的优势。你可以用FPGA的逻辑搭建一个软处理器,也可以选用具有内嵌硬处理器的产品。因此,可以很容易在FPGA上实现微处理器的性能。

     问:FPGA已经能够实现DSP,为何还要专门开发为DSP应用的FGPA?

     答:首先,所有的FPGA都有乘法器,如果你可以拿这些乘法器做数字信号处理,但是不是最优化的。例如,如果你选择Xilinx Spartan的产品,你是针对DSP应用环境下,建议选择Spartan 3A DSP。 

    问:Spartan 3A DSP在节省功耗上达到50%以上,为什么呢?

    答:就是MAC单元(FPGA的DSP上)乘法累加器(普通DSP上)单元的区别,乘法器可以通过信号处理固化,使效率大大提高,并大大降低功耗。 另外,如果你选择普通的FPGA系列做DSP处理时,你可以用乘法器搭建,但这需要应用的工程师既是一个FPGA的专家,也是DSP专家,才可以搭建一个信号处理的方案。


     问:在实际应用中,如何判断是用FPGA还是用DSP?

     答:我们一直说FPGA和DSP的互补,并存,我们并没有去强调我们去取代DSP,因为它本身是串行结构,FPGA是并行结构,很多情况下两者都会用到,怎么把软和硬达到最佳效果?这取决于客户自己的习惯,客户会首先考虑用DSP,为什么这么说呢?因为他过去常用DSP做软件的设计,因此熟悉DSP,以及DSP芯片的工具灵活、易于使用。但是工程师逐渐发现了性能瓶颈,所以客户也在研究更好的架构和处理方法,这样造成最近几年FPGA+DSP的互补结构,这是一种优化的架构,越来越被广泛使用和接受。


 

 

 

 

 

 



 




 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值