ADI SIGMADSP的软件移植
一、SIGMADSP的开发流程简介
ADI 目前在DSP方面的产品主要有SIGMA、BLACKFIN、SHARC三大类型,分别应用于不同的市场。SIGMADSP是完全可编程的单芯片音频DSP,可以通过SIGMASTUDIO图形开发工具轻松地进行配置,非常适用于汽车和便携式音频产品。
SIGMADSP的开发基本上是基于SIGMASTUDIO的编程,因为SIGMASTUDIO的SDK不是通用的C语言编辑的环境,而是类似于框架式的结构,通过SDK自带算法块来搭建产品音频处理的流程。在线编译和调试是通过SIGMADSP配套的编译器USBI,将PC的上位机输出I2C的寄存器组到SIGMADSP内部。在实际使用过程中,我们需要通过微控制器来控制SIGMADSP的相关操作。本文将描述如何编程微控制器来控制和引导SIGMADSP,实现生产系统中与SIGMADSP的通信。
二、SIGMASTUDIO的操作
SIGMASTUDIO的相关主页如下图(图2)菜单栏红色方框处所示,包括:新建工程、编辑、视图、工具、格式、编译操作等等。
首先我们需要搭建连接器硬件配置,如下图(图3)所示:
接下来我们可以对IC 1(不同DSP配置界面略微不同)进行寄存器配置。
最后通过SIGMASTUDIO内部的基本结构件,对音频流进行相应的功能处理,如图1(SIGMADSP 开发工具 SIGMASTUDIO)所示,我们可以选择左边的配置树下的相关功能进行配置。配置完后可以输出到Capture窗口。
SigmaStudio在Capture窗口中显示以下内容:
- 显示所有通过USB通信链路写入的数据
- 参数/寄存器名称、值、十六进制数据、字节数
当项目被验证并准备好移植到微控制器时,启动该过程只需几个步骤:
- 首先,找到并点击“链接、编译、下载”按钮(如下图图6所示)。
- 点击“编译”按钮并生成在SigmaDSP上运行项目所需的所有数据文件(如下图图7所示)。
- 如果计算机附加了评估板,捕获窗口将显示计算机通过USB端口写入SigmaDSP的所有数据(如上图图5所示)。
- 编译完成后,“导出系统文件”按钮将被启用(如下图图8所示)。
点击“导出系统文件”按钮将显示一个对话框,用户可从列表中选择保存导出目标文件夹。如下图(图9)所示:
下面是自动生成的所有文件的列表,其中“*”表示给定的名称:
- * .hex
包含程序RAM的内容。 - * .params
Cell名称、参数名称、地址、值、数据的详细信息。 - * _IC_1.h
这个文件包含了使用名为“default_download()”的方法访问IC寄存器、程序数据和参数数据所需的所有信息。这个方法完全按照捕获窗口中显 示的方式调用所有寄存器和命令。 - * _IC_1_PARAM.h
包含每个独立模块的参数定义。 - * _IC_1_REG.h
包含SigmaDSP IC的注册定义和设置。 - defines.h
这是一个传统的头文件,它定义了*_IC_1.h文件中已经定义的事务总数(即写入I2C/SPI控制端口),还包含以字节表示的总缓冲区大小。现在很少使用“defines.h”、“NumBytes_IC_1.dat”以及“TxBuffer_IC_1.dat”文件。因为它们一起复制了下载顺序,类似于默认的_download(),仍然是为了保持与旧系统的向后兼容性而生成的。 - NumBytes_IC_1.dat
包含一个数组,大小为命令总数。每个元素都会让微控制器知道事务中将写入多少字节。 - TxBuffer_IC_1.dat
包含下载事务的实际数据,该数据由地址字节和数据组成。
实际上对于系统的启动,我们在微控制器上搭建好底层的通信驱动后,只要调用default_download()函数,整个系统就能初始化完成,并运行起来。而default_download()的调用则是写入一些必要的配置寄存器,如下图(图10)所示:
针对于控件一些参数的实时调节,控件在改变组件状态capture时就会生成相关的宏和寄存器,只需要导入寄存器部分即可。线性的调节方面,有一些组件需要相关公式,也有一些组件暂时不提供线性调节的方式,所以有时候在设计UI上面存在一定的不灵活性。
三、总结
由于SIGMASTUDIO在底层的设计是基于SIGMA汇编完成,很大程度无法完全开发程序设计,但基本上一些通用的设计都能够通过几个固定的数组完成调节。而针对一些调节线性要求高的,还是要通过组件的计算公式来进行设计。更多信息,请点击下方「联系我们」,提交您的需求,我们澳门人巴黎人1797公司将提供更详细的开发流程和相关的技术指导。