FPGA基本开发设计流程,九个步骤搞定(fpga开发设计的一般流程)

FPGA的设计流程就是利用EDA开发软件和编程工具对FPGA芯片进行开发的过程。FPGA的开发流程一般如图1-10所示,包括电路功能设计、设计输入、功能仿真、综合优化、综合后仿真、实现、布线后仿真、板级仿真以及芯片编程与调试等主要步骤。

FPGA基本开发设计流程,九个步骤搞定(fpga开发设计的一般流程)

图1-10 FPGA开发的一般流程

1.电路功能设计

在系统设计之前,首先要进行的是方案论证、系统设计和FPGA芯片选择等准备工作。系统工程师根据任务要求,如系统的指标和复杂度,对工作速度和芯片本身的各种资源、成本等方面进行权衡,选择合理的设计方案和合适的器件类型。一般都采用自顶向下的设计方法,把系统分成若干个基本单元,然后再把每个基本单元划分为下一层次的基本单元,一直这样做下去,直到可以直接使用EDA元件库为止。

2.设计输入

设计输入是将所设计的系统或电路以开发软件要求的某种形式表示出来,并输入给EDA工具的过程。常用的方法为硬件描述语言(HDL)和原理图输入方法等。原理图输入方式是一种最直接的描述方式,在可编程芯片发展的早期应用比较广泛,它将所需的器件从元件库中调出来,画成原理图。这种方法虽然直观且易于仿真,但效率很低,不易维护,不利于模块构造和重用。其更主要的缺点是可移植性差,当芯片升级后,所有的原理图都需要做一定的改动。目前,在实际开发中应用最广的就是HDL语言输入法,利用文本描述设计,可以分为普通HDL和行为HDL。普通HDL有ABEL、CUR等,支持逻辑方程、真值表和状态机等表达方式,主要用于简单的小型设计。而在中大型工程中,主要使用行为HDL,其主流语言是Verilog HDL和VHDL。这两种语言都是美国电气与电子工程师协会(IEEE)的标准,其共同的突出特点是语言与芯片工艺无关,利于自顶向下设计,便于模块的划分与移植,可移植性好,具有很强的逻辑描述和仿真功能,而且输入效率很高。

3.功能仿真

功能仿真,也称为前仿真,是在编译之前对用户所设计的电路进行逻辑功能验证,此时的仿真没有延迟信息,仅对初步的功能进行检测。仿真前,要先利用波形编辑器和HDL等建立波形文件和测试向量(即将所关心的输入信号组合成序列),仿真结果将会生成报告文件并输出信号波形,从中便可以观察各个节点信号的变化。如果发现错误,则返回修改逻辑设计。常用的工具有Model Tech公司ModelSim、Sysnopsys公司的VCS和Cadence公司的NC-Verilog及NC-VHDL等软件。功能仿真虽然不是FPGA开发过程中的必需步骤,但却是系统设计中最关键的一步。

4.综合

所谓综合就是将较高级抽象层次的描述转化成较低层次的描述。综合优化根据目标与要求优化生成的逻辑连接,使层次设计平面化,以便用FPGA布局布线软件进行实现。就目前的层次来看,综合优化是指将设计输入编译成由与门、或门、非门、RAM、触发器等基本逻辑单元组成的逻辑连接网表,而并非真实的门级电路。真实具体的门级电路需要利用FPGA制造商的布局布线功能,根据综合后生成的标准门级结构网表来产生。为了能转换成标准的门级结构网表,HDL程序的编写必须符合特定综合器所要求的风格。由于门级结构、RTL级的HDL程序的综合是很成熟的技术,所有的综合器都可以支持这一级别的综合。常用的综合工具有Synplicity公司的Synplify/Synplify Pro软件以及各个FPGA厂家自己推出的综合开发工具。

5.综合后仿真

综合后仿真检查综合结果是否与原设计一致。在仿真时,把综合生成的标准延时文件反标注到综合仿真模型中,可估计门延时带来的影响。但这一步骤不能估计线延时,因此估计结果和布线后的实际情况还有一定的差距,并不十分准确。目前的综合工具较为成熟,一般的设计可以省略这一步,但如果在布局布线后发现电路结构和设计意图不符,则需要回溯到综合后仿真来确认问题所在。在功能仿真中介绍的软件工具一般都支持综合后仿真。

6.实现与布局布线

实现是将综合生成的逻辑网表配置到具体的FPGA芯片上,布局布线是其中最重要的过程。布局是指将逻辑网表中的硬件原语和底层单元合理地配置到芯片内部的固有硬件结构上,这往往需要在速度最优和面积最优之间进行选择。布线是指根据布局的拓扑结构,利用芯片内部的各种连线资源,合理正确地连接各个元件。目前,FPGA的结构非常复杂,特别是在有时序约束条件时,需要利用时序驱动的引擎进行布局布线。布线结束后,软件工具会自动生成报告,提供有关设计中各部分资源的使用情况。由于只有FPGA芯片生产商对芯片结构最为了解,所以布局布线必须采用芯片开发商提供的工具。

7.时序仿真与验证

时序仿真,也称为后仿真,是指将布局布线的延时信息反标注到设计网表中来检测有无时序违规(即不满足时序约束条件或器件固有的时序规则,如建立时间、保持时间等)现象。时序仿真包含的延迟信息最全,也最精确,能较好地反映芯片的实际工作情况。由于不同芯片的内部延时不一样,不同的布局布线方案也给延时带来不同的影响。因此在布局布线后,通过对系统和各个模块进行时序仿真,分析其时序关系,估计系统性能,以及检查和消除竞争冒险是非常有必要的。在功能仿真中介绍的软件工具一般都支持综合后仿真。

8.板级仿真与验证

板级仿真主要应用于高速电路设计中,对高速系统的信号完整性、电磁干扰等特征进行分析,一般都用第三方工具进行仿真和验证。

9.芯片编程与调试

设计的最后一步就是芯片编程与调试。芯片编程是指产生使用的数据文件(位数据流文件,Bitstream Generation),然后将编程数据下载到FPGA芯片中。其中,芯片编程需要满足一定的条件,如编程电压、编程时序和编程算法等方面。逻辑分析仪(Logic Analyzer,LA)是FPGA设计的主要调试工具,但需要引出大量的测试引脚,且其价格昂贵。目前,主流的FPGA芯片生产商都提供了内嵌的在线逻辑分析仪(如Xilinx ISE中的ChipScope、Altera QuartusII中的SignalTapII以及SignalProb)来解决上述矛盾,它们只需要占用芯片少量的逻辑资源,具有很高的实用价值。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2023年5月14日 上午9:31
下一篇 2023年5月14日 上午9:47

相关推荐

  • 工程管理系统(工程管理 系统)

    工程管理系统:从概念到应用 随着现代工业的发展,工程管理已经成为企业管理中不可或缺的一部分。工程管理系统是一种通过信息技术来协助企业管理工程活动的软件系统。本文将介绍工程管理系统的…

    科研百科 2024年6月5日
    39
  • 科研项目管理相关内控制度

    科研项目管理相关内控制度 科研项目管理是现代科学和技术发展的重要组成部分。内控制度是确保科研项目管理有效性和可靠性的基础。本文将介绍科研项目管理相关内控制度的重要性,并介绍一些常用…

    科研百科 2024年8月11日
    28
  • 马克思主义理论科研项目申请

    马克思主义理论科研项目申请 马克思主义理论是我们社会主义建设的基础和核心,是我们进行科学研究和推动社会发展的重要理论基础。在当前社会发展的背景下,我们需要加强对马克思主义理论的研究…

    科研百科 2024年8月13日
    22
  • 【脱贫攻坚】扶贫项目库建设、扶贫资金使用和管理及统筹整合涉农涉牧资金政策要点

    学习导引: ◆脱贫攻坚项目库建设要点 主要内容:1、编制范围;2、编制内容;3、编报程序4、项目库管理。 ◆扶贫资金使用和管理要点 主要内容:1、财政专项扶贫资金概念;2、预算安排…

    科研百科 2022年10月11日
    318
  • 共享知识与资源:协同办公系统的意义

    随着信息时代的到来,企业对于知识和资源的依赖越来越强。协同办公系统作为现代企业中不可或缺的一部分,其重要价值之一就是实现共享知识与资源。 提高知识利用率 协同办公系统可以帮助企业提…

    科研百科 2024年3月14日
    63
  • 农发行党委利用“智慧党建”信息系统抓实疫情防控工作(智慧党建 农发行)

    旗帜网 新冠肺炎疫情发生以来,农发行党委坚决贯彻落实习近平总书记关于疫情防控工作的重要指示和中央决策部署,按照中央应对疫情工作领导小组要求,积极主动履职,充分发挥农发行“智慧党建”…

    科研百科 2024年6月22日
    40
  • 巧用“党建工具箱”打造党建新阵地(党建 工具)

    宿迁网讯近日,在宿迁经济技术开发区南蔡乡陈圩村的田间小道上,市城投集团能源党支部党员戴斌手提“党建工具箱”,趁大家巡线工作休息间隙兴致勃勃地给他们讲习培训。“‘党建工具箱’已经成为…

    科研百科 2024年6月24日
    26
  • 国内十大免费低代码平台深度盘点(免费 低代码)

    随着数字化浪潮的汹涌而至,企业对于快速、高效、灵活的应用开发需求日益旺盛。低代码平台应运而生,以其直观的操作界面、强大的功能集成以及高效的开发流程,为企业提供了全新的应用开发体验。…

    科研百科 2024年7月6日
    36
  • 4s店的管理软件

    4s店的管理软件 随着汽车产业的发展,4s店已经成为了汽车制造行业的重要组成部分。然而,随着4s店的规模的扩大和业务的增多,管理起来也越来越困难。因此,开发一款好的管理软件已经成为…

    科研百科 2024年9月30日
    13
  • 业务流程管理体系

    业务流程管理体系:实现企业业务流程优化的利器 业务流程管理(Process Management)是一种管理方法,旨在通过优化业务流程,提高生产效率和质量,实现企业的可持续发展。在…

    科研百科 2024年5月23日
    47