基于SPB的嵌入式音频处理系统设计

时间:2022-09-05 12:26:01

基于SPB的嵌入式音频处理系统设计

摘 要: FPGA嵌入式设计中,常通过软件编程的方式来访问或者控制某些设备。电路设计软件Altium Designer的软件平台构建器(SPB)是一个包含了用于创建复杂软件系统所需的所有驱动和服务程序的软件构架。SPB中的软件IP模块可以屏蔽底层细节,为FPGA嵌入式设计的快速开发提供便利,提高研发效率。介紹了基于SPB的FPGA嵌入式设计关键技术,并在智能开发平台NanoBoard 3000上实现了基于SPB的嵌入式音频处理系统设计。

关键词: SPB; Altium Designer软件; 嵌入式FPGA设计; 音频流信号

中图分类号: TN710?34; TP319 文献标识码: A 文章编号: 1004?373X(2013)10?0139?03

0 引 言

FPGA(Field Programmable Gate Array)现场可编程门阵列,是在PAL,GAL,PLD基础上进一步发展的,作为专用集成电路(ASIC)领域中的一种半定制电路,FPGA既解决了定制的电路的不足,又克服了原有可编程器件门电路数有限的缺点。使用FPGA来开发数字电路,可以大大缩短设计时间。从简单的与非门电路到高性能的CPU,FPGA能完成所有的数字器件[1?2]。

随着技术的发展,FPGA在嵌入式设计方面的应用也越来越多。通过嵌入式软件开发工具,可以在FPGA上设计多个处理器核的嵌入式工程,并下载到FPGA器件中。电路设计软件Altium Designer(AD)及其智能开发平台NanoBoard 3000(NB 3000)为嵌入式系统设计开发提供了开发环境与实现平台[3?4]。本文利用其软件平台构建器,即SPB(Software Platform Builder),搭建访问NB 3000音频设备接口的软件平台,设计实现从NB 3000的音频编解码器读取音频流信号并进行平滑处理的嵌入式音频处理系统。

1 软件平台构建器

设计FPGA嵌入式系统时,常需要通过软件编程的方式访问设备,如LED、音频接口、触摸屏等。但在编程时需要熟悉相关设备的工作状况,包括设备工作时所需的设备寄存器、设备特定的命令、使用的通信协议及需要处理的中断等。AD软件的软件平台构建器(SPB)为这些特定的设备提供了配置数据和驱动等相关的底层模块(软件IP模块),提供了访问设备的应用编程接口(API)。

在AD软件下进行嵌入式系统设计时,SPB的使用是通过软件平台文件(SwPlatform)实现的。SPB是一个图形化的用户界面,可以自行读取FPGA设计,为设计中的设备导入合适的底层模块,并以此为基础添加更多的高层IP模块到软件平台文件中。具体添加何种IP模块,取决于FPGA嵌入式设计中需要访问哪些设备。访问设备时,可以使用SPB提供的多个IP模块。较底层的IP模块可以访问特定的存储设备,如硬盘、SD卡、RAM驱动器,较高层的IP模块则更抽象也更独立于硬件。

SPB中的软件服务列表(Software Service)是一组应用程序可以使用的类型、定义、结构和功能函数。软件服务包含用于访问SD卡、IDE存储设备、CF卡和闪存上的文件的存储服务;用于提供以太网访问的网络服务;提供符合POSIX规范的多线程功能的核心服务;允许快速构造现代图形界面的GUI服务;用于实现音频和视频功能的多媒体服务。用于中断管理和软件定时管理的系统服务总是出现在软件平台中,并且与特定设备无关。每个不同的软件模块都包含完整的API参考信息。通过API Reference可以访问API参考信息,堆栈中的每一层都会有详细的该层上可用函数的描述。通过Header Files可以查看任意驱动或者服务程序的头文件。

2 嵌入式音频处理系统设计

2.1 OpenBus系统设计

嵌入式设计时,在处理设备与处理器的连接关系时,可以采用AD软件中的开放总线(OpenBus系统)来完成,这样连接过程将被大大简化。“OpenBus系统”是一个描述一种使用普通总线实现整个系统内逻辑功能性“模块”连接的术语[3]。在OpenBus系统文档中,打开OpenBus Palette面板,选择并放置组成系统所需的器件。OpenBus Palette面板中用于FPGA设计的器件,按照功能分类有Connectors(连接器)、Processors(处理器)、Memories(存储器)、Peripherals(设备)等。每个OpenBus器件必须正确配置后才能使用。这种OpenBus系统的设计方法与传统的将处理器和电路作为元件放置在电路板上不同,它移除了所有低级别的走线和互连细节,能够快速地构建系统[3]。

通常情况下,任何使用OpenBus系统的FPGA设计都要设计放置接口电路的顶层原理图[5?7]。图1的OpenBus系统文件为32位处理器TSK3000A和I/O接口逻辑获得了音频流数据,包含了FPGA设计中的主处理器系统。约束文件将原理图顶层的端口连接到目标FPGA器件的实际物理管脚。约束文件中不但包含端口到管脚的映射,还包含如时钟分配、目标器件等其他相关的设计规范。

NB 3000开发板上的音频编解码器为CS4270,因此图3中选择CS4270 Audio Codec Driver模块,不需要再自行编写音频编解码器的驱动代码。设计采用SPI作为配置和控制,I2S用来传输数字音频数据流。因此软件平台文件的底层设计选择了I2S Master Controller和SPI Master Controller模块。中间层设计选择了I2S Driver、SPI Driver和CS4270 Audio Codec模块。软件平台文件使硬件设备的访问变得容易,底层模块为特定的设备提供了配置数据和驱动代码。设计软件平台文件时,选择什么样的模块,取决于设计中需要访问哪些设备。

2.3 嵌入式代码设计

3 设计总结

将嵌入式设计文件下载到智能开发平台NanoBoard 3000上的FPGA器件后,利用音频线将电脑或者音箱的音频源送到NanoBoard 3000的音频输入接口,就能从喇叭上听到处理后的音频效果。设计过程表明,AD的软件平台构建器(SPB)为FPGA嵌入式设计访问硬件电路相关设备提供了底层软件驱动提供了便利。通过搭建软件平台,调用IP模块,避开了对于底层硬件的驱动程序的编写,只要掌握高级C语言就可以方便地对设备进行编程,简化了嵌入式代码的编写,缩短了FPGA嵌入式设计的开发时间。

参考文献

[1] 徐文波.Xilinx FPGA开发实用教程[M].2版.北京:清华大学出版社,2012.

[2] 褚振勇.FPGA设计及应用[M].3版.西安电子科技大学出版社,2012.

[3] 徐向民.Altium Designer快速入门[M].2版.北京:北京航空航天大学出版社,2011.

[4] 李磊.Altium Designer EDA设计与实践[M].北京:北京航空航天大学出版社,2011.

[5] 王静.Altium Designer Winter 09 电路设计案例教程[M].北京:中国水利水电出版社,2010.

[6] 谷树忠.Altium Designer教程:原理图、PCB设计与仿真[M].北京:电子工业出版社,2010.

[7] 穆秀春.轻松实现从Protel到Altium Designer[M].北京:电子工业出版社,2011.

[8] 张义和.Altium Designer完全电路设计:FPGA篇[M].北京:中国电力出版社,2008.

[9] 谭浩强.C程序设计[M].4版.北京:清华大学出版社,2010.

[10] 凌明.嵌入式系统高级C语言编程[M].北京:北京航空航天大学出版社,2011.

上一篇:军用电磁继电器失效分析研究 下一篇:摄像头识别的智能车硬件系统设计