文章来源 Cytech Engineer

ADI SIGMADSP的软件移植

ADI SIGMADSP的软件移植_0.png

一、SIGMADSP的开发流程简介

ADI 目前在DSP方面的产品主要有SIGMA、BLACKFIN、SHARC三大类型,分别应用于不同的市场。SIGMADSP是完全可编程的单芯片音频DSP,可以通过SIGMASTUDIO图形开发工具轻松地进行配置,非常适用于汽车和便携式音频产品。

 

SIGMADSP的开发基本上是基于SIGMASTUDIO的编程,因为SIGMASTUDIO的SDK不是通用的C语言编辑的环境,而是类似于框架式的结构,通过SDK自带算法块来搭建产品音频处理的流程。在线编译和调试是通过SIGMADSP配套的编译器USBI,将PC的上位机输出I2C的寄存器组到SIGMADSP内部。在实际使用过程中,我们需要通过微控制器来控制SIGMADSP的相关操作。本文将描述如何编程微控制器来控制和引导SIGMADSP,实现生产系统中与SIGMADSP的通信。

图1:SIGMADSP 开发工具 SIGMASTUDIO.png
图1:SIGMADSP 开发工具 SIGMASTUDIO

二、SIGMASTUDIO的操作

SIGMASTUDIO的相关主页如下图(图2)菜单栏红色方框处所示,包括:新建工程、编辑、视图、工具、格式、编译操作等等。

图2:SIGMADSP主页.png
图2:SIGMADSP主页

首先我们需要搭建连接器硬件配置,如下图(图3)所示:

图3:硬件配置连接器.png
图3:硬件配置连接器

接下来我们可以对IC 1(不同DSP配置界面略微不同)进行寄存器配置。

图4:硬件配置界面.png
图4:硬件配置界面

最后通过SIGMASTUDIO内部的基本结构件,对音频流进行相应的功能处理,如图1(SIGMADSP 开发工具 SIGMASTUDIO)所示,我们可以选择左边的配置树下的相关功能进行配置。配置完后可以输出到Capture窗口。

SigmaStudio在Capture窗口中显示以下内容:

  • 显示所有通过USB通信链路写入的数据
  • 参数/寄存器名称、值、十六进制数据、字节数
图5:SIGMASTUDIO的 capture状态栏.png
图5:SIGMASTUDIO的 capture状态栏

当项目被验证并准备好移植到微控制器时,启动该过程只需几个步骤:

  1. 首先,找到并点击“链接、编译、下载”按钮(如下图图6所示)。
  2. 点击“编译”按钮并生成在SigmaDSP上运行项目所需的所有数据文件(如下图图7所示)。
  3. 如果计算机附加了评估板,捕获窗口将显示计算机通过USB端口写入SigmaDSP的所有数据(如上图图5所示)。
  4. 编译完成后,“导出系统文件”按钮将被启用(如下图图8所示)。
图6:链接、编译、下载按钮.png
图6:链接、编译、下载按钮
图7:编译按钮.png
图7:编译按钮
图8:导出系统文件按钮.png
图8:导出系统文件按钮

点击“导出系统文件”按钮将显示一个对话框,用户可从列表中选择保存导出目标文件夹。如下图(图9)所示:

图9:导出文件的相关列表.png
图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)所示:

图10:default_download()函数内容.png
图10:default_download()函数内容

针对于控件一些参数的实时调节,控件在改变组件状态capture时就会生成相关的宏和寄存器,只需要导入寄存器部分即可。线性的调节方面,有一些组件需要相关公式,也有一些组件暂时不提供线性调节的方式,所以有时候在设计UI上面存在一定的不灵活性。

三、总结

由于SIGMASTUDIO在底层的设计是基于SIGMA汇编完成,很大程度无法完全开发程序设计,但基本上一些通用的设计都能够通过几个固定的数组完成调节。而针对一些调节线性要求高的,还是要通过组件的计算公式来进行设计。更多信息,请点击下方「联系我们」,提交您的需求,我们骏龙科技公司将提供更详细的开发流程和相关的技术指导。

更多信息: