借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用_第1页
借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用_第2页
借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用_第3页
借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用_第4页
借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精品文档-下载后可编辑借助创新电子设计平台实现FPGA嵌入式系统设计-设计应用FPGA问世已经超过20年,现在FPGA在复杂逻辑电路以及数字信号处理领域中扮演着越来越重要的角色,SoC以其低功耗、高性能、低成本、高可靠性等优点成为嵌入式系统的发展趋势。不过,对于很多设计者来讲这还是“新鲜事物”。学习并掌握一项新的技术或具备某种能力,比如学习FPGA开发技术并将其应用到实际系统中,这是一项艰巨任务。AltiumDesigner提供了一种简单轻松的方法,可以帮助软/硬件工程师共同应对FPGA嵌入式系统开发的挑战。Altiumdesigner拥有强大的嵌入式系统设计功能以及非常便捷的设计流程,它在FPGA及嵌入式智能方面有如下优势:

1)完整功能、统一的设计环境

a)简单易用的FPGA设计工具链(包括原理图和HDL语言混合编辑器、编译器、综合器和)

b)完整的嵌入式软件开发环境(包括编辑器、编译器、生成器、连接器和调试器)

c)创新性系统验证平台——NB2(搭载了丰富的外围接口板和可相互替换的FPGA子板)

2)数字组合逻辑电路开发功能

a)放置和连接预先综合的器件

b)电路原理图和HDL语言混合输入方法

c)丰富的虚拟仪器模块

d)高度抽象化的系统设计——OpenBus

e)灵活的C语言到HDL语言转换——CtoH

3)嵌入式软件设计功能

a)的编码环境

b)独立于处理器的ViperC-编译器

c)目标代码自由的移植——DSF

d)完整的源代码级调试

4)创新性系统验证平台NB2(实施并调试你的方案)

a)独立于FPGA厂商的子板

b)灵活的外围设备板

c)实时调试和更新

d)对产品板的持续研发

5)设计实施模式间紧密结合

a)设计移动到目标硬件

b)PCB和FPGA间设计协同

接下来,我们将在AltiumDesigner平台下,利用一个视频捕获输出的实例去亲身体验如何轻松、便捷地实现FPGA嵌入式系统设计。在这个例子中,我们将使用AltiumDesigner内的几个专门针对提高设计效率,简便设计过程而开发的特定功能。它们包括:OpenBus系统开发;FPGA项目的自动配置;处理器软件架构——DSF。

另外,本例中还将结合NB2的板级硬件资源,加快方案验证和实施的过程;

*复合视频码流输入模块(Compositevideocapture)

*触摸TFT显示屏模块(TouchscreenTFTdisplay)

图1是系统架构示意图,该系统可应用于基于视频捕获和信号处理等设计领域。

图1系统方案示意图。

传统的系统设计流程

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

图2传统的系统设计流程

1、FPGA设计;

2、PCB设计;

3、嵌入式软件设计

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

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

创新性的系统设计流程

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

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

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

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

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

图5OpenBus面板

图6完成的OpenBus设计

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

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

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

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

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

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

在FPGA设计完成之后,AltiumDesigner还提供一个快捷的方法,可将FPGA项目直接转换到相应的PCB项目,并进行项目之间数据的同步更新。总之,AltiumDesigner在FPGA以及SOPC方面提供了强大且便捷好用的功能,包括统一、完整的设计环境

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论