FPGA开发全攻略——FPGA开发基本流程如果一如当初

FPGA是可编程芯片,因此FPGA的设计方法包括硬件设计和软件设计两部分。硬件包括FPGA芯片电路、存储器、输入输出接口电路以及其他设备,软件即是相应的HDL程序以及最新才流行的嵌入式C程序。

目前微电子技术已经发展到SOC阶段,即集成系统(IntegratedSystem)阶段,相对于集成电路(IC)的设计思想有着革命性的变化。SOC是一个复杂的系统,它将一个完整产品的功能集成在一个芯片上,包括核心处理器、存储单元、硬件加速单元以及众多的外部设备接口等,具有设计周期长、实现成本高等特点,因此其设计方法必然是自顶向下的从系统级到功能模块的软、硬件协同设计,达到软、硬件的无缝结合。

这么庞大的工作量显然超出了单个工程师的能力,因此需要按照层次化、结构化的设计方法来实施。首先由总设计师将整个软件开发任务划分为若干个可操作的模块,并对其接口和资源进行评估,编制出相应的行为或结构模型,再将其分配给下一层的设计师。这就允许多个设计者同时设计一个硬件系统中的不同模块,并为自己所设计的模块负责;然后由上层设计师对下层模块进行功能验证。

自顶向下的设计流程从系统级设计开始,划分为若干个二级单元,然后再把各个二级单元划分为下一层次的基本单元,一直下去,直到能够使用基本模块或者IP核直接实现为止,流行的FPGA开发工具都提供了层次化管理,可以有效地梳理错综复杂的层次,能够方便地查看某一层次模块的源代码以修改错误。

Planahead允许高层设计者为不同的模块划分相应FPGA芯片区域,并允许底层设计者在所给定的区域内独立地进行设计、实现和优化,等各个模块都正确后,再进行设计整合。如果在设计整合中出现错误,单独修改即可,不会影响到其它模块。Planahead将结构化设计方法、团队化合作设计方法以及重用继承设计方法三者完美地结合在一起,有效地提高了设计效率,缩短了设计周期。

不过从其描述可以看出,新型的设计方法对系统顶层设计师有很高的要求。在设计初期,他们不仅要评估每个子模块所消耗的资源,还需要给出相应的时序关系;在设计后期,需要根据底层模块的实现情况完成相应的修订。

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

1、功能定义/器件选型

在FPGA设计项目开始之前,必须有系统功能的定义和模块的划分,另外就是要根据任务要求,如系统的功能和复杂度,对工作速度和器件本身的资源、成本、以及连线的可布性等方面进行权衡,选择合适的设计方案和合适的器件类型。一般都采用自顶向下的设计方法,把系统分成若干个基本单元,然后再把每个基本单元划分为下一层次的基本单元,一直这样做下去,直到可以直接使用EDA元件库为止。

2、设计输入

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

3、功能仿真

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

4、综合优化

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

5、综合后仿真

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

图4-1FPGA典型设计流程

6、实现与布局布线

7、时序仿真

8、板级仿真与验证

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

9、芯片编程与调试

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

目前,由于FPGA性能提升价格下降,同时嵌入越来越多内核,很自然地,很多IC设计公司将FPGA用于ASIC原型验证,把FPGA可编程的优点带到了SOC领域,其系统由嵌入式处理器内核、DSP单元、大容量处理器、吉比特收发器、混合逻辑、IP以及原有的设计部分组成。

SOC平台的核心部分是内嵌的处理内核,其硬件是固定的,软件则是可编程的;外围电路则由FPGA的逻辑资源组成,大都以IP的形式提供,例如存储器接口、USB接口以及以太网MAC层接口等,用户根据自己需要在内核总线上添加,并能自己订制相应的接口IP和外围设备。

基于FPGA的典型SOC开发流程为:

1、芯片内的考虑

从设计生成开始,设计人员需要从硬件/软件协同验证的思路入手,以找出只能在系统集成阶段才会被发现的软、硬件缺陷。然后选择合适的芯片以及开发工具,在综合过程得到优化,随后进行精确的实现,以满足实际需求。由于设计规模越来越大,工作频率也到了数百兆赫兹,布局布线的延迟将变得非常重要。为了确保满足时序,需要在布局布线后进行静态时序分析,对设计进行验证。

2、板级验证

在芯片设计完毕后,需要再进行板级验证,以便在印刷电路板(PCB)上保证与最初设计功能一致。因此,PCB布局以及信号完整性测试应被纳入设计流程。由于芯片内设计所做的任何改变都将反映在下游的设计流程中,各个过程之间的数据接口和管理也必须是无误的。预计SOC系统以及所必须的额外过程将使数据的大小成指数增长,因此,管理各种数据集本身是急剧挑战性的任务。

THE END
1.软件开发整个流程图软件开发流程php软件开发整个流程图 软件 开发 流程 软件开发是一个复杂的过程,包括以下步骤: 1. 需求分析:在软件开发之前,必须明确软件的需求。这包括确定软件的功能、性能和可靠性要求。需求分析是软件开发过程的重要一步,将确定软件开发的方向和范围。 2. 设计阶段:在需求分析阶段完成后,需要进行软件设计。这一阶段包括制定软件https://blog.yyzq.team/post/340047.html
2.项目开发流程:四个阶段需求确定开发阶段项目开发流程:四个阶段 1.需求确定阶段: ①需求梳理:双方沟通详细的开发需求,确定各功能模块的业务逻辑,最终形成需求文档供客户确认。 ②评估与报价:功能需求确定后,我们将根据需求文档评估开发成本和开发周期。 我们公司的报价有两个优势。 一是专业开发工程师评估,更准确,无水; 二是我们是一家拥有12年经验的开发https://m.bjhwtx.com/h-nd-129304.html
3.定制开发流程步骤(全面版)开发团队会与客户密切协作,依据具体的业务场景和操作流程,精心设计出贴合实际应用的功能模块。细化功能规划至字段命名级别,这意味着每个数据输入点、展示项以及后台处理逻辑都将得到详尽明确的规划,让所有参与者都能清晰地了解即将开发的软件中包含的所有内容和工作流程。2.原型图设计 框架层设计:界面设计,导航设计,https://baijiahao.baidu.com/s?id=1795916653747173459&wfr=spider&for=pc
4.开发java程序的一般步骤是开发Java程序的一般步骤通常包括需求分析、设计、编码、测试和部署等阶段。下面将详细介绍Java程序开发的一般步骤。 需求分析阶段: 在开始开发Java程序之前,首先需要进行需求分析。需求分析是确定程序需求、功能和约束的过程。这一阶段通常涉及与相关人员交流,理解用户的需求,并将其转化为功能和系统要求的文档形式。 https://www.elecfans.com/d/2326502.html
5.软件开发流程&每阶段注意事项确保需求的可追溯性和复审需求:确认每个需求是否都有对应的测试用例,验证需求设计是否合理、是否存在遗漏等情况。 开发工程师带入新的测试角度:从业务处理流程的角度提供新的测试用例,改善测试用例覆盖情况。 预防缺陷和改善开发质量:通过评审发现潜在的缺陷,进一步改善软件质量。 https://blog.csdn.net/u011305680/article/details/136189271
6.医疗器械设计转换的重要性及其实施流程检测资讯看到这里其实我们对于设计转移要实施的内容相对就比较明确了。尝尝在许多公司的设计开发流程中设计转移和设计确认是放在一起的或放在设计确认后,但值得注意的是设计转移不是在设计确认后才进行的活动,设计转移的活动从首次工艺输出开始,直至设计转移评审形成评审报告前完成。通常设计转移的主要活动包括:完整的工艺操作规程及http://www.anytesting.com/news/1941877.html
7.计算机毕业设计15篇在讲解程序设计时,灌输软件开发流程等概念。在综合性程序设计试验时,引导学员按照软件工程的流程来设计和实现。数据库的基础知识为以后进一步开发数据库应用系统软件提供了重要的基础。这些软件知识互为渗透、相互融合,共同构成了计算机软件技术基础课程的丰富的内涵。注重各种软件知识的结合,也自然成为了课程教学的重要理念https://www.fwsir.com/fanwen/html/fanwen_20230422093603_2738458.html
8.基于Android平台的大学生实用软件设计开发AET基于Android平台的大学生实用软件设计开发 摘要: 在移动互联技术发展成熟的大环境下,对如何应用智能手机等移动通信终端实现校园信息数字化服务这一问题的研究具有深刻的现实意义和广泛的实用价值。基于Android平台设计开发了大学生校园资讯服务软件,可完成对课程表、自习室、通知公告、办事流程、电话黄页等各类信息的浏览和http://www.chinaaet.com/article/3000015385
9.向死而生:面向失败设计之道术技业务开发的新同学有时候可能会有迷之自信,觉得自己写的代码与老鸟们没有什么不同。实际上,编写正常流程的业务代码大家的差异不会太大,但是针对异常、边界、不确定性的处理才真正体现一个程序员的功力。老鸟们往往在长期的训练下已经形成多种肌肉记忆,遇到具体问题就会举一反三脑海里冒出诸多面向失败的设计点,从而写https://maimai.cn/article/detail?fid=1717421141&efid=5muaLLhIsBrDpQNUYWRP4g
10.Java全栈教程:从零开始的全栈开发入门在开始学习Java之前,你需要搭建Java开发环境。首先,你需要下载并安装JDK(Java Development Kit)。JDK是Java开发的必备工具,它包含了Java运行环境(JRE)、编译器(javac)和调试工具(jdb)等。 1.2 Java语言基本语法 Java语言的基本语法包括变量、数据类型、运算符、流程控制语句、数组、方法、类与对象等。 https://www.imooc.com/article/360026
11.技术燃料电池电堆设计开发关键技术(2)熟练的技术队伍和先进的开发流程 专业的电堆开发,人力资源是关键。在产品定义和设计阶段,实现平台化产品和模块化产品设计,充分汲取并应用基础研究和材料的改进创新的成果,才能促进技术不断提高和改进,从而实现电堆性能的整体提升。 (3)向智能化制备迈进 http://www.zhengfeipower.net/Article-2729059.html
12.敏捷研发—前端DevOps流水线实践行云流水线提供了良好的环境基础和丰富的原子准备,使构建自动化流水线时更加的方便快捷,也大大提升了团队的开发时间。团队的前端DevOps流水线即是基于行云流水线搭建。 4.2 流程设计 下图团队设计的前端DevOps自动化流水线,目的是打破开发、测试、产品、运营等不同岗位人员的沟通壁垒,让研发团队人员同时具备不同研发环https://blog.itpub.net/70027825/viewspace-2944076/
13.OA工作流Activiti(一)[通俗易懂]腾讯云开发者社区ACT_HI_*: ‘HI’表示history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。 ACT_GE_*: 通用数据, 用于不同场景下,如存放资源文件。 数据库流程规则表: 1) act_re_deployment 部署信息表 2) act_re_model 流程设计模型部署表 3) act_re_procdef 流程定义数据表 https://cloud.tencent.com/developer/article/2102060
14.智能网联汽车AUTOSAR嵌入式软件开发体系结构智能网联汽车4. AUTOSAR软件开发流程 AUTOSAR嵌入式软件开发流程通常包括以下几个关键步骤: 4.1 系统设计 在系统设计阶段,开发团队根据汽车功能和性能需求,将整个系统划分为不同的软件组件,并定义它们之间的接口和通信方式。同时,确定基础软件和运行环境的配置。 4.2 软件开发 https://www.auto-testing.net/baike/show-1169.html
15.产品人必备干货:产品开发流程(完整版)人人都是产品经理产品开发流程涉及的人员从产品经理到设计师、前端、后端等等一系列人员,这篇文章主要关于产品开发的完整流程,希望对各个工作岗位上的人有借鉴意义。 1 引言 1.1目的 基于现在的开发流程中缺少的环节进行补足,使得开发流程更加的流畅和正规化,以便以后的查阅与归档使用。面对互联网行业中激烈的竞争,让我们的开发流程更完https://www.woshipm.com/pmd/545047.html
16.AUTOSARAP与CP的差异在哪里?CP 与AP开发流程如下图所示: 蓝色虚线框表示CP AUTOSAR的开发流程,绿色表示AP AUTOSAR的开发流程。 上图中,在代码生成阶段没有体现AP要生成Manifest,实际开发时需要。 上图中,只是一个简单的整理,并没有涵盖AUTOSAR所有需要设计的内容。 4.4 接口类型 https://www.dongchedi.com/article/7066418855047954974
17.分布式网络数据抓取系统设计与实现1. 代理ip池的设计与开发流程如下: a. 对免费代理ip网站进行抓取。 b. 对代理ip进行存储并验证 c. 验证通过存储进数据库 d.验证不通过的则删除 (c)爬虫异常状态组件的处理 爬虫没有被屏蔽运行时,访问网站不是一直都是200请求成功,而是有各种各样的状态,像上述爬虫被禁的时候,其实返回的状态是302,防止屏蔽组https://www.jianshu.com/p/fb028ad74798
18.合同期个人工作计划6篇本项目的工作计划从系统需求调研和设计到系统开发、测试和验收,再到系统上线和运维,共计12周。通过详细的工作计划,确保项目的开发流程、任务分配和实现方式的明确清晰,有效避免了项目中出现的风险和错误。在项目的实施中,遇到问题第一时间反馈给相关人员解决,提高项目的执行效率和质量,使得本项目能够成功实施,得到了客户https://www.liuxue86.com/a/4899400.html
19.天津市利达钢管集团有限公司天津a.质量管理体系的范围,见本手册1条款本公司企业简介和发布令;GB/T19001:2008标准应用于本公司时,生产和服务过程中不涉及7.3条款(设计控制),将7.3条款删减; b.根据质量管理体系标准要求和本公司生产和服务的特点,编制实际运行的程序文件;QMS形成文件的已用和QMS所需过程及过程之间相互作用的表述。 http://12365.ce.cn/zlpd/zly2014/cy013/cy2013/tj/201409/19/t20140919_1936402.htm
20.DDD实战Repository模式的妙用在本文中,我们深入探讨了DDD(领域驱动设计)的一个核心构件 —— 仓储模式。借助快照模式和变更追踪,我们成功解决了仓储模式仅限于操作聚合根的约束,这为后续开发提供了一种实用的模式。 大家好,我是飘渺。今天我们继续更新DDD(领域驱动设计) & 微服务系列。 https://www.51cto.com/article/759855.html
21.敏捷开发流程高手必备的用户运营策略有哪些?4.2 提升用户参与度的关键步骤 设计有趣且吸引人的互动活动,例如问答、竞赛、投票等。 提供有价值且分享性强的内容,例如故事、观点、数据等。 鼓励用户之间的社区互动,例如评论、讨论、分享等。 4.3 如何通过参与度提升产品或服务的价值 鼓励用户提供反馈和建议,这有助于了解他们的需求并改进产品。 https://boardmix.cn/article/5-user-operation-strategies/