0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何提高嵌入式应用设计中的DSP代码运行性能

电子设计 来源:郭婷 作者:电子设计 2019-08-07 08:12 次阅读

1 引言

随着微控制器威廉希尔官方网站 的发展,以TI公司TMS320C2000系列为代表的DCS型数字信号处理器DSP应用广泛。该类型DSP内部集成Flash存储器,可将二进制代码同化到其内部的Flash存储器直接运行。这种运行方式在传统嵌入式应用设计中很有效,但在一些算法比较复杂、系统响应要求快速、通讯任务比较繁重的嵌入式应用中,这种运行方式会导致控制系统响应迟缓、通讯异常、I/O操作缓慢等问题。针对这些情况,提出一种新的解决方案,来提高DSP代码运行性能。

2 问题分析及设计方案

由于应用程序在Flash中运行速度远低于在RAM中,因此在复杂嵌入式应用中会出现控制系统响应迟缓、通讯异常、I/O操作缓慢等问题。为了避免这些问题,只能让程序在RAM中运行。TI公司的TMS320C2000系列DSP有2种工作模式:微处理器模式和微控制器模式。当DSP处于微控制器模式时,在RAM中程序运行速度达到峰值,但掉电后程序丢失,系统无法重新自动运行,因此这种程序运行方式仅适用于仿真调试阶段。因此,DSP必须工作在微处理器模式下,使用片内Flash作为运行程序的存储和运行介质,才能保证系统上电后自动运行。但其程序运行效率低。因此必须把这2种工作模式相结合:首先将应用程序固化到片内Flash存储器,当系统上电后由专门设计的装载器(Bootloader) 负责将应用程序南Flash搬移到RAM,然后Bootloader将DSP控制权交给应用程序,从而实现DSP运行速度最高和上电后应用程序自动运行,解决了因程序在不同介质的不同效率所导致的系统响应迟缓、通讯异常、I/O操作缓慢等问题。

以TMS320LF2407 DSP为例进行说明:该DSP具有独立的数据存储空间和数据总线,以及程序存储空间和程序总线。只有程序空间的程序才能被DSP视为是可执行程序,数据空间上的程序将被DSP视为操作数据,因此将应用程序直接从片内Flash拷贝到数据空间的RAM后应用程序是不能运行的。若使拷贝后的应用程序能够被 DSP视为可执行程序还必须做一些辅助工作。

通过对TMS320LF2407的存储映射结构分析可发现:程序空间和数据空间的扩展区域有部分地址可配置成相同存储介质(Flash或者RAM),通过某种办法可以实现共享,也就是说DSP可以将从Flash中拷贝到共享RAM的应用程序视为可执行代码。

3 设计方案实施

3.1 TMS320LF2407存储空间配置及CMD文件编写

为实现程序空间与数据空间共享RAM的存储器配置方案,首先要熟悉C语言7个存储段对存储介质的要求,其具体要求如表1所示。

如何提高嵌入式应用设计中的DSP代码运行性能

从表1可以看出:“.bss”、“.sysmem”、“.stack”段的存储介质必须是RAM,且使用数据空间地址;而“.text”、“. swtich”、“.cinit”段的存储介质可以是RAM或ROM,但必须使用程序空间地址。“.text”是用来存放应用程序的可执行代码的专用段,它既可运行在RAM中,也可在Flash中,该段的运行介质决定应用程序是否能够达到最大性能。根据DSP命令链接文件(CMD文件)对汇编段的管理方式可知,“.text”可配置成装载与运行分离的工作模式。这种模式可以使应用程序存储在Flash中,运行在RAM中从而实现DSP上电后全速运行。

其次由于存储空间使用装载与运行分离的配置模式,因此必须重新设计链接文件(CMD文件)。在设计新的CMD文件之前,首先介绍常用的分离配置链接命令指示器:“.label”定义一个可重定位代码段标签,该标签表明代码段内部地址都是相对的,在链接时重新定义该段分配的首地址。相应的段地址为“首地址+ 段内偏移地址”。利用该汇编指示器可提供代码装载地址。“.global”汇编指示器定义全局符号,该符号表示全局地址,链接器利用该汇编指示器定义的运行时全局地址,为程序提供在RAM中运行时的人口地址。“.”汇编指示器表示当前代码的运行地址,它用来帮助计算运行代码的长度。在CMD文件中定义可执行代码的运行时首地址标签_fun_run和代码长度标签_fun_len;在存储空间配置时定义COPYCODE段用来装载应用程序的可执行代码:在存储空间配置时定义DATA0段做为应用程序可执行代码段的运行介质。

具体存储空间配置及CMD文件编写代码如下:

如何提高嵌入式应用设计中的DSP代码运行性能

如何提高嵌入式应用设计中的DSP代码运行性能

3.2 Bootloader装载器软件及硬件设计

设计Bootloader装载器时应注意两点:首先关闭看门狗,否则可能因为搬移时间过长导致DSP被不断复位,系统无法正常工作;必须定义 Bootloader装载器的入口标签_c_int0和出口标签wfc_int0,实现Bootloader装载完成搬移工作后顺利进入用户应用程序。

考虑到DSP上电工作顺序:从系统复位指令处跳转至运行时支持代码;创建C语言运行环境;用户程序入口 main();完成用户初始化及应用代码。因此负责从Flash将应用程序代码拷贝到RAM的Bootloader装载器必须在恰当的时间工作,否则应用程序不能上电自动运行。由DSP上电工作顺序可以发现,系统上电复位时的复位地址是,固定的但跳转指令所指的地址是由用户指定的,也就是说,可以让该复位跳转指令指向所设计的Bootloader装载器的首地址完成代码搬移工作(其工作原理见图1),然后Bootloader装载器将DSP的控制权交给运行支持库,完成C语言环境建立并进入用户程序入口main()开始用户程序。为此必须对运行支持库做如下修改:

从运行支持库rts.rc源文件中提取boot.asm.将boot.asm的入口地址_c_int0修改为wfc_int0地址,重新编译boot. asm生成boot.obj文件,把boot.obj归档到C语言运行支持库rts.2xx.1ib。将修改后的运行支持库添加到工程中,实现Boot- loader装载器先于运行支持库代码执行。

如何提高嵌入式应用设计中的DSP代码运行性能

Bootloader装载器利用装载地址、运行地址以及链接器提供的代码长度等信息,使用读表指令“TBLR”将代码从程序空间拷贝到数据空间,然后跳转到运行支持库入口地址开始执行程序。DSP的这种搬移指令特点仅适合将数据表从程序空间拷贝到数据空间,要实现全部设计功能必须配合相应的硬件设计,由 TMS320LF2407DSP的存储器映射结构可以看出程序空间与数据空间是物理分离的,即有3个独立的空间片选信号PS、DS、CS。为实现RAM共享,首先必须将PS和DS信号进行“与“操作,然后将其输出信号作为共享RAM的片选信号,实现程序空间与数据空间的统一编址。根据 TMS320LF2407DSP的存储器映射结构,具体的存储空间配置如下:0x0000~0x7FFF片上RAM、外设寄存器和保留的地址区,该区域必须作为数据地址使用;利用图2所示的硬件结构实现0x8000~0xFFFF区域程序空间和数据空间共享RAM。共享RAM配置如下:数据区 0x8000~0xBFFF;程序区0xC000~0xFFFF。

如何提高嵌入式应用设计中的DSP代码运行性能

这里的硬件结构配合Bootloader装载器和特别设计的CMD文件实现了DSP运行速度最大和上电后代码自动运行,解决了在复杂应用情况下控制系统响应迟缓、通讯异常等问题。

具体Bootloader装载器设计代码如下:

如何提高嵌入式应用设计中的DSP代码运行性能

4 测试结果

该方案在某型防空武器火力控制分系统的实践中表现良好。通过提高DSP程序运行效率成功解决了因控制系统实时多任务所导致的通讯异常问题,避免了不必要的硬件升级。经实验对比发现:当系统有5个毫秒级实时任务同时工作时,采用Flash运行方式的 TTCAN通讯接口每毫秒最多可发送2帧数据,而采用本设计方案每毫秒最多可发送6帧数据,代码运行效率提高了3倍。

5 结束语

该设计方案不仅成功解决了程序在Flash中运行效率低所导致的各种异常问题,同时还避免了不必要的处理器升级所带来的成本和开发风险。其设计思想可以推广到其他类似的应用中,从而最大限度的利用现有硬件基础提高嵌入式系统的性能。


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    19291

    浏览量

    229906
  • dsp
    dsp
    +关注

    关注

    553

    文章

    8005

    浏览量

    349000
  • 嵌入式
    +关注

    关注

    5083

    文章

    19129

    浏览量

    305404
收藏 人收藏

    评论

    相关推荐

    嵌入式机器视觉系统有什么特性?怎么优化?

    介绍了基于ARM+DSP架构的嵌入式机器视觉系统的特性,分析了制约嵌入式机器视觉系统性能的因素。从操作系统和应用程序方面,讨论了嵌入式机器视
    发表于 03-11 06:47

    什么是嵌入式系统?

    综合性严格要求的专用计算机系统。简单地说,嵌入式系统集系统的 应用软件 与硬件于 一体 ,类似于 PC BIOS 的工作方式,具有 软件代码 小、高度自动化、 响应速度 快等 特点 ,特别适合于
    发表于 04-16 09:53

    嵌入式和通用DSP之间的差别在哪

    DSP在内的多内核嵌入结构是提高整体数据处理能力的一个有效方案。如何更高速、高效地协调各个内核之间的工作成为这项工作的核心,与此相关的嵌入式软件的
    发表于 12-15 06:01

    如何调试嵌入式代码

    我们在进行嵌入式系统开发调试时,受限于嵌入式芯片资源和性能,一般采用远程调试。在调试嵌入式底层代码时,gdbserver 无法
    发表于 12-17 06:32

    如何在嵌入式设备上运行性能Java

    如何在嵌入式设备上运行性能Java
    发表于 03-28 09:43 16次下载

    嵌入式威廉希尔官方网站 设计专用DSP系统研究

    分析了用嵌入式威廉希尔官方网站 设计专用DSP处理系统的一些基本问题。分析结果指出,嵌入式威廉希尔官方网站 的在专用DSP处理系统的应用设计可以发挥巨大的作用,是
    发表于 05-09 14:15 25次下载

    提高DSP代码运行性能的研究

    传统嵌入式应用设计通常是将程序直接固化到DSP内部的Flash存储器运行,程序运行效率较低,不能充分发挥DSP
    发表于 12-27 15:34 25次下载

    如何优化嵌入式DSP应用的功耗

    如何优化嵌入式 DSP 应用的功耗 采用软硬件威廉希尔官方网站 可以提高电源效率,而使用内置电源管理 API 的 DSP RTOS 更容易实现上述目的。 作者:Scott Gary,德州
    发表于 04-22 11:44 707次阅读

    DSP嵌入式系统人机接口设计

    DSP嵌入式系统人机接口设计  1 引言   人机接口是嵌入式控制系统的重要组成部分,用于人机之间实时交换控制系统并返回系统状态。嵌入式系统大都采用液
    发表于 12-24 16:34 975次阅读
    <b class='flag-5'>DSP</b><b class='flag-5'>嵌入式</b>系统人机接口设计

    嵌入式DSP在家电的应用

    本文将从嵌入式DSP电机控制芯片的基本特征开始,介绍一下基于DSP的磁场定向控制和扩展卡尔曼滤波算法
    发表于 09-24 00:43 909次阅读
    <b class='flag-5'>嵌入式</b><b class='flag-5'>DSP</b>在家电<b class='flag-5'>中</b>的应用

    嵌入式DSP模块和FPGA构架为基础的提高无线信号处理性能的子系统设计

    您可以显著提高无线系统中信号处理功能的性能。怎样提高呢?有效方法是利用FPGA结构的灵活性和目前受益于并行处理的FPGA架构嵌入式
    发表于 07-17 11:48 854次阅读
    以<b class='flag-5'>嵌入式</b><b class='flag-5'>DSP</b>模块和FPGA构架为基础的<b class='flag-5'>提高</b>无线信号处理<b class='flag-5'>性能</b>的子系统设计

    关于嵌入式代码的致命漏洞

    输入可以被制作成“包含代码”,并且该程序可以被欺骗来执行该代码代码注入缺陷意味着黑客可以劫持现有进程,并以与原始进程相同的权限执行任何他们喜欢的代码。 在许多
    的头像 发表于 01-06 15:13 1802次阅读

    DSP嵌入式系统的应用实例

    DSP嵌入式系统的应用实例(嵌入式开发工具软件)-该文档为DSP嵌入式系统
    发表于 07-30 13:09 22次下载
    <b class='flag-5'>DSP</b>在<b class='flag-5'>嵌入式</b>系统<b class='flag-5'>中</b>的应用实例

    DSP与MCU在嵌入式系统的应用

    DSP与MCU在嵌入式系统的应用(嵌入式开发解决方案)-该文档为DSP与MCU在嵌入式系统
    发表于 07-30 13:11 12次下载
    <b class='flag-5'>DSP</b>与MCU在<b class='flag-5'>嵌入式</b>系统<b class='flag-5'>中</b>的应用

    嵌入式代码高效运行指南

    嵌入式C语言之所以经久不衰,在于它的运行效率很高,想要高效运行代码,除了编译器帮忙优化,关键还要靠自己“优化”代码
    的头像 发表于 01-06 15:32 896次阅读