每日更新教程,评论区答疑解惑,小白也能变大神!"

目录
[1 FPGA设计方法学:硬件与软件的协同](#1 FPGA设计方法学:硬件与软件的协同)
[1.1 FPGA设计的基本构成](#1.1 FPGA设计的基本构成)
[1.2 从集成电路到集成系统的设计思想革命](#1.2 从集成电路到集成系统的设计思想革命)
[1.3 层次化与结构化的设计方法](#1.3 层次化与结构化的设计方法)
[1.4 团队化设计挑战与解决方案](#1.4 团队化设计挑战与解决方案)
[2 典型FPGA开发流程详解](#2 典型FPGA开发流程详解)
[2.1 开发流程概述](#2.1 开发流程概述)
[2.2 电路设计与规划](#2.2 电路设计与规划)
[2.3 设计输入方法](#2.3 设计输入方法)
[2.4 功能仿真](#2.4 功能仿真)
[2.5 综合优化](#2.5 综合优化)
[2.6 综合后仿真](#2.6 综合后仿真)
[2.7 实现与布局布线](#2.7 实现与布局布线)
[2.8 时序仿真](#2.8 时序仿真)
[2.9 板级仿真与验证](#2.9 板级仿真与验证)
[2.10 芯片编程与调试](#2.10 芯片编程与调试)
[3 基于FPGA的SOC设计方法](#3 基于FPGA的SOC设计方法)
[3.1 SOC设计理念与FPGA的结合](#3.1 SOC设计理念与FPGA的结合)
[3.2 基于FPGA的典型SOC开发流程](#3.2 基于FPGA的典型SOC开发流程)
[3.3 基于FPGA的SOC设计挑战与解决方案](#3.3 基于FPGA的SOC设计挑战与解决方案)
[4 总结与展望](#4 总结与展望)
1 FPGA设计方法学:硬件与软件的协同
1.1 FPGA设计的基本构成
FPGA作为可编程芯片,其设计方法包含硬件设计 和软件设计两大组成部分。硬件设计是基础,主要包括FPGA芯片电路、存储器、输入输出接口电路以及其他外围设备。这部分设计方法相对固定,遵循成熟的电子设计规范和原则。软件设计则是FPGA的灵魂,包括相应的硬件描述语言(HDL)程序以及近年来逐渐流行的嵌入式C程序。软件设计决定了FPGA最终实现的逻辑功能,是FPGA设计中最具创造性和灵活性的部分。
在现代FPGA设计中,软硬件协同设计已成为主流理念。硬件提供基础资源和性能保障,软件则赋予硬件特定的功能和灵活性。两者紧密结合,才能充分发挥FPGA的可编程特性。随着FPGA技术的不断发展,硬件平台的能力不断增强,软件设计方法和工具也在持续演进,从早期的原理图输入到硬件描述语言,再到现在的系统级设计工具,设计抽象层次不断提高,设计效率也随之大幅提升。
1.2 从集成电路到集成系统的设计思想革命
微电子技术已经发展到SOC(集成系统)阶段,这一阶段相对于传统的集成电路(IC)设计思想发生了革命性变化。SOC是一个复杂的系统,它将一个完整产品的功能集成在一个芯片上,包括核心处理器、存储单元、硬件加速单元以及众多的外部设备接口等。这种高度集成的特点使得SOC具有设计周期长、实现成本高等特点,因此其设计方法必须是自顶向下的从系统级到功能模块的软、硬件协同设计,以达到软硬件的无缝结合。
SOC设计方法的核心优势在于它能够充分考虑系统级的需求和约束,在设计的早期阶段就进行软硬件的划分和协同验证,避免在设计的后期才发现系统架构的问题,从而减少设计反复,缩短开发周期。这种设计理念与FPGA的可编程特性相结合,产生了基于FPGA的SOC设计方法,为复杂系统设计提供了更加灵活和高效的实现途径。
1.3 层次化与结构化的设计方法
面对现代FPGA设计的复杂性,层次化、结构化的设计方法成为必然选择。这么庞大的工作量显然超出了单个工程师的能力,需要按照层次化、结构化的设计方法来实施。在这种方法中,首先由总设计师将整个软件开发任务划分为若干个可操作的模块,并对其接口和资源进行评估,编制出相应的行为或结构模型,再将其分配给下一层的设计师。这就允许多个设计者同时设计一个硬件系统中的不同模块,并为自己所设计的模块负责;然后由上层设计师对下层模块进行功能验证。
自顶向下的设计流程从系统级设计开始,划分为若干个二级单元,然后再把各个二级单元划分为下一层次的基本单元,一直下去,直到能够使用基本模块或者IP核直接实现为止。这种设计方法的好处在于:首先,它允许设计团队并行工作,大大缩短设计周期;其次,它明确了各个模块的接口和功能,便于模块的复用和系统的集成;最后,它使得复杂系统的设计变得可控,降低了设计风险。
流行的FPGA开发工具都提供了层次化管理功能,可以有效地梳理错综复杂的层次,能够方便地查看某一层次模块的源代码以修改错误。这种工具支持对于实施层次化设计方法至关重要,它使得设计者能够在一个统一的环境中管理整个设计项目,从系统级到最底层的实现细节。
1.4 团队化设计挑战与解决方案
在工程实践中,大型FPGA设计面临软件编译时长的严峻挑战。由于大型设计包含多个复杂的功能模块,其时序收敛与仿真验证复杂度很高,为了满足时序指标的要求,往往需要反复修改源文件,再对所修改的新版本进行重新编译,直到满足要求为止。这里存在两个主要问题:首先,软件编译一次需要长达数小时甚至数周的时间,这是开发所不能容忍的;其次,重新编译和布局布线后结果差异很大,会将已满足时序的电路破坏。因此必须提出一种有效提高设计性能,继承已有结果,便于团队化设计的软件工具。
FPGA厂商意识到了这类需求,由此开发出了相应的逻辑锁定和增量设计的软件工具。例如,Xilinx公司的解决方案就是PlanAhead。PlanAhead允许高层设计者为不同的模块划分相应FPGA芯片区域,并允许底层设计者在所给定的区域内独立地进行设计、实现和优化,等各个模块都正确后,再进行设计整合。如果在设计整合中出现错误,单独修改即可,不会影响到其它模块。
PlanAhead将结构化设计方法、团队化合作设计方法以及重用继承设计方法三者完美地结合在一起,有效地提高了设计效率,缩短了设计周期。这种工具的核心思想是通过物理约束来保持设计稳定性,当设计的一部分需要修改时,其他已经满足时序要求的部分可以保持不变的布局布线,从而避免全面的重新编译,大幅减少迭代时间。
不过从其描述可以看出,新型的设计方法对系统顶层设计师有很高的要求。在设计初期,他们不仅要评估每个子模块所消耗的资源,还需要给出相应的时序关系;在设计后期,需要根据底层模块的实现情况完成相应的修订。这种设计方法要求系统架构师既要有系统级的视野,又要了解实现的细节,对设计师的能力提出了更高的要求。
2 典型FPGA开发流程详解

2.1 开发流程概述
FPGA的设计流程就是利用EDA开发软件和编程工具对FPGA芯片进行开发的过程。典型的FPGA开发流程包括电路设计、设计输入、功能仿真、综合优化、综合后仿真、实现、布线后仿真、板级仿真以及芯片编程与调试等主要步骤。这个流程是一个迭代的过程,在每个步骤中都可能发现问题和需要回溯到前面的步骤进行修改。理解这个流程的每个环节及其相互关系,对于高效地进行FPGA设计至关重要。
2.2 电路设计与规划
在系统设计之前,首先要进行的是方案论证、系统设计和FPGA芯片选择等准备工作。系统工程师根据任务要求,如系统的指标和复杂度,对工作速度和芯片本身的各种资源、成本等方面进行权衡,选择合理的设计方案和合适的器件类型。这个阶段决策的质量直接影响整个项目的成败,需要充分考虑系统的性能要求、功耗约束、成本目标以及开发周期等因素。
一般都采用自顶向下的设计方法,把系统分成若干个基本单元,然后再把每个基本单元划分为下一层次的基本单元,一直这样做下去,直到可以直接使用EDA元件库为止。在这个分解过程中,需要明确各个模块的功能定义、接口规范以及性能指标,为后续的详细设计奠定基础。同时,还需要考虑设计的可测试性和可维护性,为后续的调试和升级留出足够的空间。
2.3 设计输入方法
设计输入是将所设计的系统或电路以开发软件要求的某种形式表示出来,并输入给EDA工具的过程。常用的方法有硬件描述语言(HDL) 和原理图输入方法等。
原理图输入方式是一种最直接的描述方式,在可编程芯片发展的早期应用比较广泛,它将所需的器件从元件库中调出来,画出原理图。这种方法虽然直观并易于仿真,但效率很低,且不易维护,不利于模块构造和重用。更主要的缺点是可移植性差,当芯片升级后,所有的原理图都需要作一定的改动。因此,在现代FPGA设计中,原理图输入主要应用于小型设计或作为HDL设计的补充。
目前,在实际开发中应用最广的就是HDL语言输入法,利用文本描述设计,可以分为普通HDL和行为HDL。普通HDL有ABEL、CUR等,支持逻辑方程、真值表和状态机等表达方式,主要用于简单的小型设计。而在中大型工程中,主要使用行为HDL,其主流语言是Verilog HDL和VHDL。这两种语言都是美国电气与电子工程师协会(IEEE)的标准,其共同的突出特点有:语言与芯片工艺无关,利于自顶向下设计,便于模块的划分与移植,可移植性好,具有很强的逻辑描述和仿真功能,而且输入效率很高。
近年来,高层次综合(HLS) 工具逐渐成熟,允许设计者使用C、C++或SystemC等高级语言进行设计输入,然后自动转换为HDL代码。这种方法可以进一步提高设计效率,特别适用于算法密集型应用。
2.4 功能仿真
功能仿真,也称为前仿真,是在编译之前对用户所设计的电路进行逻辑功能验证,此时的仿真没有延迟信息,仅对初步的功能进行检测。功能仿真是设计验证的第一道关卡,目的是在设计早期发现功能错误,避免错误传递到后续阶段造成更大的修改成本。
仿真前,要先利用波形编辑器和HDL等建立波形文件和测试向量(即将所关心的输入信号组合成序列),仿真结果将会生成报告文件和输出信号波形,从中便可以观察各个节点信号的变化。如果发现错误,则返回设计修改逻辑设计。测试平台的编写是功能仿真的关键,一个良好的测试平台应该能够覆盖所有的功能场景,包括正常操作和边界情况。
常用的功能仿真工具有Model Tech公司的ModelSim、Sysnopsys公司的VCS和Cadence公司的NC-Verilog以及NC-VHDL等软件。这些工具通常支持行为级、RTL级和门级仿真,能够满足不同设计阶段的仿真需求。
2.5 综合优化
所谓综合就是将较高级抽象层次的描述转化成较低层次的描述。综合优化根据目标与要求优化所生成的逻辑连接,使层次设计平面化,供FPGA布局布线软件进行实现。就目前的层次来看,综合优化(Synthesis)是指将设计输入编译成由与门、或门、非门、RAM、触发器等基本逻辑单元组成的逻辑连接网表,而并非真实的门级电路。
真实具体的门级电路需要利用FPGA制造商的布局布线功能,根据综合后生成的标准门级结构网表来产生。为了能转换成标准的门级结构网表,HDL程序的编写必须符合特定综合器所要求的风格。由于门级结构、RTL级的HDL程序的综合是很成熟的技术,所有的综合器都可以支持到这一级别的综合。
常用的综合工具有Synplicity公司的Synplify/Synplify Pro软件以及各个FPGA厂家自己推出的综合开发工具。现代综合工具通常包含丰富的优化选项,设计者可以根据面积、速度、功耗等不同优化目标进行设置,以达到最佳的设计效果。
2.6 综合后仿真
综合后仿真检查综合结果是否和原设计一致。在仿真时,把综合生成的标准延时文件反标注到综合仿真模型中去,可估计门延时带来的影响。但这一步骤不能估计线延时,因此和布线后的实际情况还有一定的差距,并不十分准确。
目前的综合工具较为成熟,对于一般的设计可以省略这一步,但如果在布局布线后发现电路结构和设计意图不符,则需要回溯到综合后仿真来确认问题之所在。在功能仿真中介绍的软件工具一般都支持综合后仿真。
综合后仿真主要用于验证综合过程没有改变设计的原始功能,同时初步评估设计的时序性能。对于时序要求严格的设计,这一步骤仍然是必要的,它可以在设计流程的早期发现潜在的时序问题。
2.7 实现与布局布线
实现 是将综合生成的逻辑网表配置到具体的FPGA芯片上,布局布线是其中最重要的过程。布局将逻辑网表中的硬件原语和底层单元合理地配置到芯片内部的固有硬件结构上,并且往往需要在速度最优和面积最优之间作出选择。布线根据布局的拓扑结构,利用芯片内部的各种连线资源,合理正确地连接各个元件。
目前,FPGA的结构非常复杂,特别是在有时序约束条件时,需要利用时序驱动的引擎进行布局布线。布线结束后,软件工具会自动生成报告,提供有关设计中各部分资源的使用情况。由于只有FPGA芯片生产商对芯片结构最为了解,所以布局布线必须选择芯片开发商提供的工具。
布局布线的质量直接影响设计的性能和可靠性。一个好的布局布线结果应该满足所有的时序要求,同时保留一定的时序余量,并且合理使用芯片资源,避免拥塞。对于复杂的设计,通常需要多次调整布局布线策略和约束条件,才能达到理想的结果。
2.8 时序仿真
时序仿真,也称为后仿真,是指将布局布线的延时信息反标注到设计网表中来检测有无时序违规(即不满足时序约束条件或器件固有的时序规则,如建立时间、保持时间等)现象。时序仿真包含的延迟信息最全,也最精确,能较好地反映芯片的实际工作情况。
由于不同芯片的内部延时不一样,不同的布局布线方案也给延时带来不同的影响。因此在布局布线后,通过对系统和各个模块进行时序仿真,分析其时序关系,估计系统性能,以及检查和消除竞争冒险是非常有必要的。在功能仿真中介绍的软件工具一般都支持时序仿真。
时序仿真虽然精确,但通常速度较慢,特别是对于大规模设计。因此,在实际项目中,常常使用静态时序分析(STA) 作为时序验证的主要手段,而使用时序仿真作为补充,验证特定的时序路径和接口。
2.9 板级仿真与验证
板级仿真主要应用于高速电路设计中,对高速系统的信号完整性、电磁干扰等特征进行分析,一般都以第三方工具进行仿真和验证。随着FPGA的工作频率不断提高,以及接口速度达到吉比特级别,板级仿真变得越来越重要。
板级仿真主要考虑信号在PCB板上的传输特性,包括反射、串扰、损耗、电源完整性等问题。通过板级仿真,可以在制造PCB之前发现潜在的信号完整性问题,避免昂贵的板级返工。
常用的板级仿真工具有Ansys公司的SIwave、Cadence公司的Sigrity以及Synopsys公司的HSPICE等。这些工具能够提取PCB的寄生参数,建立精确的传输线模型,并进行各种信号完整性分析。
2.10 芯片编程与调试
设计的最后一步就是芯片编程与调试。芯片编程是指产生使用的数据文件(位数据流文件,Bitstream Generation),然后将编程数据下载到FPGA芯片中。其中,芯片编程需要满足一定的条件,如编程电压、编程时序和编程算法等方面。
逻辑分析仪(Logic Analyzer,LA) 是FPGA设计的主要调试工具,但需要引出大量的测试管脚,且LA价格昂贵。目前,主流的FPGA芯片生产商都提供了内嵌的在线逻辑分析仪(如Xilinx ISE中的ChipScope、Altera QuartusII中的SignalTapII以及SignalProb)来解决上述矛盾,它们只需要占用芯片少量的逻辑资源,具有很高的实用价值。
现代FPGA调试工具还提供了虚拟IO、系统性能分析、电源监测 等高级功能,大大提高了调试效率。此外,许多FPGA还支持部分重配置功能,允许在系统运行过程中动态修改部分逻辑,为系统升级和故障修复提供了极大的灵活性。
3 基于FPGA的SOC设计方法
3.1 SOC设计理念与FPGA的结合
基于FPGA的SOC设计理念将FPGA可编程的优点带到了SOC领域,其系统由嵌入式处理器内核、DSP单元、大容量处理器、吉比特收发器、混合逻辑、IP以及原有的设计部分组成。相应的FPGA规模大都在百万门以上,适合于许多领域,如电信、计算机等行业。
系统设计方法是SOC常用的方法学,其优势在于,可进行反复修改并对系统架构实现进行验证,包括SOC集成硬件和软件组件之间的接口。不过,目前仍存在很多问题,最大的问题就是没有通用的系统描述语言和系统级综合工具。随着FPGA平台的融入,将SOC逐步地推向了实用。
SOC平台的核心部分是内嵌的处理内核,其硬件是固定的,软件则是可编程的;外围电路则由FPGA的逻辑资源组成,大都以IP的形式提供,例如存储器接口、USB接口以及以太网MAC层接口等,用户根据自己需要在内核总线上添加,并能自己订制相应的接口IP和外围设备。这种架构结合了处理器的灵活性和专用硬件的性能,为复杂系统设计提供了理想的平台。
3.2 基于FPGA的典型SOC开发流程
基于FPGA的典型SOC开发流程包含多个阶段,每个阶段都有其特定的任务和挑战:
芯片内的考虑从设计生成开始,设计人员需要从硬件/软件协同验证的思路入手,以找出只能在系统集成阶段才会被发现的软、硬件缺陷。然后选择合适的芯片以及开发工具,在综合过程得到优化,随后进行精确的实现,以满足实际需求。由于设计规模越来越大,工作频率也到了数百兆赫兹,布局布线的延迟将变得非常重要。为了确保满足时序,需要在布局布线后进行静态时序分析,对设计进行验证。
在这个阶段,硬件/软件协同设计至关重要。传统的设计流程中,硬件和软件往往是分开开发的,直到系统集成阶段才会发现问题,导致昂贵的返工。基于FPGA的SOC设计允许硬件和软件并行开发,并通过FPGA的可编程特性进行早期验证和迭代,大大降低了集成风险。
板级验证在芯片设计完毕后,需要再进行板级验证,以便在印刷电路板(PCB)上保证与最初设计功能一致。因此,PCB布局以及信号完整性测试应被纳入设计流程。由于芯片内设计所做的任何改变都将反映在下游的设计流程中,各个过程之间的数据接口和管理也必须是无误的。预计SOC系统以及所必须的额外过程将使数据的大小成指数增长,因此,管理各种数据集本身是极具挑战性的任务。
板级验证不仅要验证功能的正确性,还要验证系统的信号完整性、电源完整性和热性能等物理特性。对于高速系统,这些物理效应可能严重影响系统的性能和可靠性,必须在设计早期就进行充分考虑。
3.3 基于FPGA的SOC设计挑战与解决方案
基于FPGA的SOC设计面临诸多挑战,需要相应的方法和工具来应对:
设计复杂性管理是首要挑战。随着系统规模不断扩大,设计复杂性呈指数增长。为了解决这个问题,需要采用高层次的抽象设计方法,如使用基于C/C++的设计和验证环境,以及充分利用IP核复用技术。现代SOC设计通常包含数十个甚至上百个IP核,有效的IP核管理和集成至关重要。
系统验证是另一个重大挑战。传统的仿真方法对于SOC规模的设计来说速度太慢,无法在合理的时间内完成充分验证。为了解决这个问题,需要采用多种验证技术相结合的策略,包括仿真、形式验证、硬件加速和原型验证等。特别是FPGA原型验证,由于能够以接近实时的速度运行软件,对于软硬件协同验证具有重要意义。
功耗管理在现代SOC设计中变得越来越重要。基于FPGA的SOC通常面向便携式或嵌入式应用,对功耗有严格的要求。功耗管理需要在各个设计层次上进行,从系统架构的功耗优化,到RTL代码的功耗意识设计,再到物理实现的低功耗技术,如时钟门控、电源门控和多电压设计等。
时序收敛 对于高性能SOC设计始终是一个挑战。随着工艺节点的不断缩小,互连线延迟 dominate 了时序特性,使得时序收敛更加困难。基于FPGA的SOC设计可以借助FPGA的可重配置特性,通过多次迭代优化时序,同时还可以利用FPGA厂商提供的专用时序分析工具和优化技术。
4 总结与展望
FPGA设计方法学经历了从简单的逻辑设计到复杂的系统设计的演变。现代FPGA设计不再是单纯的硬件设计,而是软硬件协同设计的复杂过程。自顶向下的设计方法、团队化协作设计工具以及IP核复用技术,使得设计者能够应对日益复杂的设计挑战。
典型的FPGA开发流程是一个多阶段、迭代的过程,从概念设计到最终的产品实现,每个阶段都有其特定的工具和方法。随着设计规模和复杂度的提高,验证在整个设计周期中所占的比重越来越大,需要采用更加高效和全面的验证策略。
基于FPGA的SOC设计代表了当前FPGA技术的最高水平,它将处理器的灵活性和专用硬件的性能完美结合,为复杂系统设计提供了理想的平台。随着FPGA容量和性能的不断提升,以及设计工具和方法的持续改进,基于FPGA的SOC将在更多领域得到应用。
未来,FPGA设计方法将继续向更高抽象层次 发展,系统级设计工具将更加成熟,软件工程师将能够更加容易地利用FPGA的并行处理能力。同时,异构计算的概念将进一步深化,FPGA将与CPU、GPU等其他计算单元紧密结合,形成更加高效和灵活的计算平台。
随着人工智能和机器学习应用的普及,FPGA在AI加速领域的应用也将推动设计方法的创新,面向特定领域的架构和工具将不断涌现。总之,FPGA设计方法学将继续演进,以应对新的应用挑战和技术机遇。

