您好,欢迎访问三七文档
当前位置:首页 > 行业资料 > 其它行业文档 > 基于FPGA的嵌入式系统设计
基于FPGA的嵌入式系统设计摘要:可编程片上系统设计是一个崭新的、富有生机的嵌入式系统设计技术研究方向。本文在阐述可编程逻辑器件特点及其发展趋势的基础上,探讨了智力产权复用理念、基于嵌入式处理器内核和xilinxFPGA的SOPC软硬件设计技术,引入了基于英特网可重构逻辑概念并提出了设计实现方法,为基于FPGA的嵌入式系统设计提供了广阔的思路。1概述1.1FPGA的特点及其发展趋势嵌入式系统是一个面向应用、技术密集、资金密集、高度分散、不可垄断的产业,随着各个领域应用需求的多样化,嵌入式设计技术和芯片技术也经历着一次又一次的革新。虽然ASIC的成本很低,但设计周期长、投入费用高、风险较大,而可编程逻辑器件(ProgrammableLogicalDevice)设计灵活、功能强大,尤其是高密度现场可编程逻辑器件(FieldProgrammableGateArray)其设计性能已完全能够与ASIC媲美,而且由于FPGA的逐步普及,其性能价格比已足以与ASIC抗衡。因此,FPGA在嵌入式系统设计领域已占据着越来越重要的地位。FPGA的基本结构由以下几个部分构成:可编程逻辑功能模块CLB(ConfigurableLogicBlocks)可编程输入输出模块IOB(Input/OutputBlocks)可编程内部互连资源PI(ProgrammableInterconnection)随着工艺的进步和应用系统需求,一般在FPGA中还包含以下可选资源:存储器资源(BlockRAM和SelectRAM)数字时钟管理单元(分频/倍频、数字延迟)I/O多电平标准兼容(SelectI/O)算数运算单元(乘法器、加法器)特殊功能模块(MAC等硬IP核)微处理器(PPC405等硬处理器)以FPGA为核心的PLD产品是近几年集成电路中发展得最快的产品。随着FPGA性能的高速发展和设计人员自身能力的提高,FPGA将进一步扩大可编程芯片的领地,将复杂专用芯片挤向高端和超复杂应用。目前FPGA的发展趋势主要体现在以下几个方面:向更高密度、更大容量的千万门系统级方向迈进向低成本、低电压、微功耗、微封装和绿色化发展IP资源复用理念将得到普遍认同并成为主要设计方式MCU、DSP、MPU等嵌入式处理器IP将成为FPGA应用的核心随着处理器以IP的形式嵌入到FPGA中,ASIC和FPGA之间的界限将越来越模糊,未来的某些电路版上可能只有这两部分电路:模拟部分(包括电源)和一块FPGA芯片,最多还有一些大容量的存储器。Xilinx等公司最新一代FPGA:SpartanII/E、VirtexIIPro及其相关IPCore的推出,使我们有理由相信,可编程片上系统(SystemonProgrammableChip)的时代已经离我们不远了。1.2可编程片上系统(SOPC)的基本特征可编程片上系统(SOPC)是一种特殊的嵌入式系统:首先它是片上系统(SOC),即由单个芯片完成整个系统的主要逻辑功能;其次,它是可编程系统,具有灵活的设计方式,可裁减、可扩充、可升级,并具备软硬件在系统可编程的功能。SOPC结合了SOC和FPGA各自的优点,一般具备以下基本特征:至少包含一个嵌入式处理器内核具有小容量片内高速RAM资源丰富的IPCore资源可供选择足够的片上可编程逻辑资源处理器调试接口和FPGA编程接口可能包含部分可编程模拟电路单芯片、低功耗、微封装SOPC设计技术实际上涵盖了嵌入式系统设计技术的全部内容,除了以处理器和实时多任务操作系统(RTOS)为中心的软件设计技术、以PCB和信号完整性分析为基础的高速电路设计技术以外,SOPC还涉及目前以引起普遍关注的软硬件协同设计技术。由于SOPC的主要逻辑设计是在可编程逻辑器件内部进行,而BGA封装已被广泛应用在微封装领域中,传统的调试设备,如:逻辑分析仪和数字示波器,已很难进行直接测试分析,因此,必将对以仿真技术为基础的软硬件协同设计技术提出更高的要求。同时,新的调试技术也已不断涌现出来,如Xilinx公司的片内逻辑分析仪ChipScopeILA就是一种价廉物美的片内实时调试工具。2IP资源复用理念与IPCore设计2.1IP资源复用理念由于芯片设计的复杂性和产品面市时间对于保证终端市场的成功率至关重要,设计师不断寻求缩短设计周期的方法,以及更有效的设计方式。随着我们步入系统级芯片时代,利用IP内核和可编程逻辑进行设计复用显得日趋重要。IP资源复用(IPReuse)是指在集成电路设计过程中,通过继承、共享或购买所需的智力产权内核,然后再利用EDA工具进行设计、综合和验证,从而加速流片设计过程,降低开发风险。IPReuse已逐渐成为现代集成电路设计的重要手段,在日新月异的各种应用需求面前,超大规模集成电路设计时代正步入一个IP整合的时代。IPReuse不仅仅应用于专用集成电路设计,对基于FPGA的嵌入式系统设计领域而言,更是具有举足轻重的地位。FPGA在采用IP内核方面走在了市场的前面,其原因有以下几个方面:FPGA具有极高的灵活性和面市时间短的特点,这使得多项设计迭代可以在数小时而不是数周内完成由于FPGA密度达到了百万门甚至是千万门,越来越多的设计师倾向于使用IP内核保持和提高产品的产量可编程逻辑价格低廉,可以作为切实可行的生产工具以及最佳原型设计,而且不许要昂贵的EDA设计工具,大大降低了设计门槛2.2IPCore设计方法:编码风格与项目模板IPCore是IPReuse的载体和核心内容,基于应用需求、规范协议和行业标准的不同,IPCore的内容也是千差万别的。但是,为了使IPCore易于访问和易于集成,其设计必须遵循一定的规范和准则。在IPCore的开发方面,许多开放性的团体都付出了巨大的努力来推动各种IPCore的开发和IPReuse理念的推广,其中比较著名的是OpenCores开发组织()。他们不仅开发了许多开放源代码的IPCore,涵盖了处理器IP、处理器外设控制器IP、算术运算单元IP、DSP算法IP等方面,而且编写了详细的IPCore编码风格和项目模板,并倡导了一种总线标准wishbone,用于规范各种IPCore的接口标准。国内开放性团体IPCore开发小组()也在IPCore开发和IPReuse理念的推广和普及方面进行了不懈的努力。编码风格(CodingStyle)是基于HDL的IPCore源码编写的指导性文档,其可读性直接关系到IPCore的易于访问和易于集成性。编码风格一般包含几个方面的约定:文件头和版本说明、联机注释、命名规则、可综合编码等。项目模板则规定了完成一个IPCore设计包含的主要内容及所需提供的文档,项目模板内容及其文档直接关系到IPCore的易于集成特性,一个IPCore必须是完整的、经过全面验证的,才能顺利地集成到应用项目中去。项目模板一般包含几个方面的内容:项目定义、接口说明、系统结构和模块、设计文档说明、测试验证报告、约束和实现、版本说明、试用评价以及参考文献等。编码风格和项目模板详细文档的英文版和中文版可分别从上述两个网站获得。2.3IPCore验证:仿真、测试与评估板IPCore设计在完成编码阶段以后,对其功能的测试验证是一项非常重要的内容,因为这直接关系到IPCore资源的可用性。仅仅通过功能仿真、时序仿真和测试向量验证的IPCore是不完备的,它必须通过实际系统的验证。国际上各大公司通常采用的办法是评估板验证,也即构建一个与实际系统IPCore应用一致的硬件环境,通过下载FPGA配置使其具备相应的逻辑功能,并进行实物仿真。另外,由于IPCore的许可成本较高,用户也通常希望在购买IPCore之前,对其功能进行充分的验证以确定是否适合于目标系统,从而降低投资风险,(当然,内核和源代码的知识产权是加了保护措施的),Xilinx公司的SingOnce和Altera公司的OpenCore均提供了这样的平台。Xilinx公司和Altera公司均提供了许多用于评估IPCore的FPGA评估板,如USB、MAC、IEEE1394等等。许多第三方设计中心,如Insight,还开发了用于SOPC系统集成的VirtexIIMicroBlaze评估板和VirtexIIProPPC405评估板等等。XilinxFPGA的国内专业设计公司长沙依元素科技()还开发了用于测评各类基本IPCore以及学习培训用途的数字刀剑?系列(DigitalSword?SeriesKit)评估板,该系列评估板提供了VGA、LCD、音频、键盘鼠标、串口、并口、USBSlave、I2C等电平接口,并提供了标准扩展总线以及丰富的子板功能模块支持。3.1FPGA基本开发流程与开发工具FPGA基本开发流程主要包括设计输入(DesignEntry);设计仿真(Simulation);设计综合(Synthesize);布局布线(Place&Route);配置(Configuration)五个主要步骤。设计输入主要有原理图输入和HDL输入两种方式,一般开发商都同时支持两种输入方式。有些熟悉硬件设计的工程师开始喜欢利用原理图进行设计,这种方法非常直观,但基于可移植性和规范化方面的考虑,绝大部分深入FPGA设计和ASIC设计的工程师最终都将统一到HDL平台上来。设计仿真包含功能仿真和时序仿真两项主要内容,功能仿真忽略了综合和布局布线导致的时延等因素,仅仅从逻辑上进行仿真,这对设计思路的验证是有帮助的,但必须通过时序仿真作进一步验证,发现并修正时序问题。设计综合将HDL语言生成用于布局布线的网表和相应的约束。综合效果直接导致设计的性能和逻辑门的利用效率,因此,许多可编程逻辑器件开发商都支持第三方综合和仿真工具,著名的有:Synplicity、Synopsys和ModelSim等。布局布线工具利用综合生成的网表,在FPGA内部进行布局布线,并生成可用于配置的比特流文件。布局布线工具与可编程逻辑器件工艺及其布线资源密切相关,一般由可编程逻辑器件开发商直接提供。随着可编程逻辑器件容量的不断增大和设计性能要求的不断提高,对传统的FPGA开发工具提出了挑战。以Xilinx公司为例,应IPCore开发和集成的需要,开发了IPCore使用工具CoreGenerator和IPCore包装工具IPCapture;提供了模块化设计工具ModularDesign用于超大规模设计的团队项目开发;用片内逻辑分析仪ChipScopeILA进行片内逻辑调试;Xpower则用于设计功耗分析并得出相应的解决方案;还有SystemGenerator结合Simulink甚至可以简单地实现数字信号处理模型(如FIR滤波器和FFT等)的FPGA硬件实现。此外,一些有争议的设计工具,如基于C语言的FPGA开发工具DK1等为超大容量FPGA设计和复杂逻辑设计提供了值得尝试的途径。3.2处理器IPCore:MicroBlaze与PPC405将处理器IPCore嵌入到可编程逻辑器件是基于FPGA的嵌入式系统设计的前提条件,目前,国内外许多单位已成功的将51单片机、arm和PPC等处理器内核嵌入各种可编程逻辑器件并进行了应用系统的设计,其中最著名的要数Xilinx公司的MicroBlaze和Altera公司的Nois了。Xilinx从PicoBlaze到MicroBlaze,再到PPC405,完成了从8位单片机到32位微处理器的逐步完善和性能提升。MicroBlaze是一个专门为XilinxFPGA优化的RISC嵌入式软处理器,符合IBMCoreConnect标准,能够与PPC405系统无缝连接,MicroBlaze软处理器内核的结构如图2所示,图2MicroBlazeIPCore结构框图它具备以下基本特征:32个32bit通用寄存器硬件乘法器(仅限VirtexII系列)32bit地址总线和32bit数据总线三操作数32bit指令字,两种寻址模式独立的片内程序32
本文标题:基于FPGA的嵌入式系统设计
链接地址:https://www.777doc.com/doc-2569667 .html