首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

第三方软件快速实现FPGA嵌入式系统设计(2)

第三方软件快速实现FPGA嵌入式系统设计(2)

本帖最后由 yuyang911220 于 2016-12-29 15:28 编辑

传统的系统设计流程

      传统上,应对包含FPGA器件设计和嵌入式软件设计的系统开发流程需要经历三个阶段(图2)。
  


图2 传统的系统设计流程

1、 FPGA设计;
2、 PCB设计;
3、 嵌入式软件设计

      每个阶段相互衔接,逐次实现;由于需要在设计初期完成元器件选型(包括FPGA器件和微处理器),因而必将降低整体方案实现的灵活性;对于设计后期可能在器件性能及功能扩展等方面出现的问题,需要耗费设计者更多的精力才可能弥补,或者只能将现有方案推倒重来。


图3、 创新的系统设计流程。



创新性的系统设计流程

  运用Altium Designer平台实现FPGA的嵌入式系统设计,首先要为系统方案创建一个FPGA工程,并在工程内添加源设计文档。

  在数字组合逻辑电路设计输入方面,一个FPGA项目支持三种类型的输入方法-原理图、HDL (Verilog 或VHDL)以及OpenBus。另外还支持C代码符号的输入。你可以使用这些输入方法的混合输入,并使用层次原理图所用到的符号方块图来对不同的输入文档进行组合。对于FPGA项目,必须将原理图做为顶层文档,因为这是为了支持从FPGA到PCB移植以及同步。首先,创建一个原理图文档并添加到项目中去。如图4所示。



图4 FPGA项目以及新生成的文档的项目面板


  接下来,我们一同体验OpenBus系统设计简易、快捷的特性。OpenBus是一个进行系统级FPGA设计的新方法。它提供了比原理图更为简单的界面,但是并不会因其简单而丢失相应的信息。由于它能自动考虑底层细节,因而设计者只需着眼于顶层系统的设计以及主要元件的互连。而这些元件都是预先综合过的、应用于FPGA开发的IP元件。



图5 OpenBus面板


  在Altium Designer平台中OpenBus文件编辑环境下(如图5所示),你将开始亲身体验如何轻松、便捷地实现FPGA的嵌入式系统设计。如图6所示,整体方案的实现与我们对方案规划设计时,描述的系统结构框架非常相似。依据实现方案所需用到的功能单元,诸如:32位微处理器、视频输入控制模块、TFT显示屏控制模块、I2C控制模块(用于操作视频流数据输入处理器件的控制寄存器单元)、IP内核互连模块、SRAM控制模块和总线仲裁模块,从OpenBus器件列表栏中逐一放置到当前编辑文档内,并完成连接。


图6 完成的OpenBus设计


  随后,还需要为包括SRAM控制器、总线仲裁器、IP内核互连器和微处理器等OpenBus元件配置应用参数。Altium Designer支持独立于FPGA器件原厂商的设计。也就是说,你可以重新绑定你的设计到另外一个厂商的另外一块FPGA芯片。这种移植过程可以通过Altium Designer的配置管理器(configuration management)轻易实现。如图7所示,不同的配置文件以及约束文件可以重新绑定设计到不同的FPGA芯片。



图7 添加约束文件到配置管理器

      至此,你已经为你的嵌入式系统设计方案搭建好了完整的应用平台。最后,你还需要为系统添加嵌入式智能控制软件,最终完成FPGA的嵌入式系统设计。Altium Designer平台下的嵌入式软件开发功能将帮你轻松应对软件设计中所遇到的任何挑战;一个嵌入式项目可以独立地进行开发,但是最终需要这些代码在目标处理器中运行。Altium Designer给你简便的方法,将你的嵌入式项目连接到包含有嵌入式处理器核的FPGA项目中去。

      本实例中的处理器核即为OpenBus文档中用的32位处理器核TSK3000A_1。左键点击并拖动嵌入式项目到上面的FPGA项目。并将嵌入式项目丢在TSK3000A_1 处理器核上(FPGA项目中的处理器核会自动高亮)。如图8所示。在你连接好这两个项目之后,一个新的C头文件会自动添加到嵌入式项目中去。这个头文件 hardware.h由FPGA项目编译的时候自动产生。当完成了嵌入式软件代码的开发后,你就可以在NB2平台下,实时现场调试和验证你的设计方案。正如本篇开始的系统构造示意图所示,你可以将摄像头所捕获的视频信号呈现在TFT显示屏上。



图8 链接嵌入式项目到处理器核


      如果你还想增强系统处理视频码流的性能,使得视频图片可以在TFT显示屏上快速缩放以及旋转,那么需要用到Altium Designer的C-to-hardware转换功能CHC。另外在上述的OpenBus文件里需要使用特殊应用处理器 ASP元件。由于使用了C-to-hardware功能,你可以决定哪些C代码函数需要用数字组合逻辑功能实现,哪些用微处理器实现。由于采用了硬件来实现矢量图形的缩放功能,因而相对于软件实现将更加快速。这方面可以在本实例中进行试验验证。

  在FPGA设计完成之后,Altium Designer还提供一个快捷的方法,可将FPGA项目直接转换到相应的PCB项目,并进行项目之间数据的同步更新。总之,Altium Designer在FPGA以及SOPC方面提供了强大且便捷好用的功能,包括统一、完整的设计环境;多种设计输入方式;独立于处理器的灵活代码;C-to-hardware;可重构的验证平台;独立于FPGA原厂商的设计;设计仿真;虚拟仪器及LiveDesign交互式调试,以及方便快捷的FPGA项目到PCB项目数据同步功能。这些强大的软件功能连同可重构的系统验证平台NB2一起为你提供了一个功能强大的创新平台,在这个创新平台上,设计者可以尽情放飞设计灵感,来创造更有价值的设计。
继承事业,薪火相传
返回列表