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

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

3天内不再提示

DSP编程的几个关键问题(1)

454398 来源:罗姆半导体社区 作者:罗姆半导体社区 2022-12-27 15:28 次阅读

来源:罗姆半导体社区

DSP芯片凭其优异的性能在高速计算领域有着巨大的应用前景。但其应用所涉及的知识非常庞杂。当程序调不通不知该从何处下手时,此文也许会有所帮助。

1. McBSP(Multichannel Buffered Serial Port)串口利用DMA中的多帧(Multi-Frame)方式通信的中断处理

在实际通信应用中,一个突发之后,程序必须为下一个突发作准备。因此一般采用串口的DMA多帧方式但在串口以DMA方式传输数据时却有一些问题要讨论。首先DMA的传输同步事件应设McBSP的传输事件即XEVT,这样一字节传输后会自动准备另一字节(McBSP的READY上升沿触发DMA传输)。中断发生时意味着一个块已传完,这时DMA的使能自动关闭,McBSP的READY将一直保持高状态。但是在下一次突发传输直接使能DMA时却启动不了传输(相信会有许多我遇到此类问题)。这是因为无法产生McBSP触发启动所需的READY上升沿。解决办法是在中断程序中先关闭McBSP的发送,使READY=0,随后在程序中发送使能DMA,再打开McBSP的发送即可。如先打开McBSP的发送后打开DMA,也是不会工作的。因为McBSP的READY已经由0变到1了,无法再产生READY上升沿。

2. 关闭DMA与关闭McBSP的区别

在通信领域,为了充分利用DSP的片上外设资源,常常利用DMA把从串口来的数据或要发的数据放入缓冲区,再处理。对DMA而言,只要其在数据缓冲区的指针指向了中断应发生的位置,就产生中断。但此时最后一个数据只是进入了McBSP而并未真正发出去,所以在传送结束的中断程序中只能关闭DMA不能关闭McBSP。因为此时McBSP的发寄存器DXR中还有一个字没有发出。

3 .McBSP串口配置的关键时序

主要是寄存器SPCR2的配置:在保持RRST、XRST、FRST各位为0的前提下,配置好其它串口控制寄存器。等待至少2个CLKR/T时钟以确保DSP内部的同步。 (1)可以向DXR装载数据或使能DMA。 (2)使能GRST(GRST=1)(如果需要DSP内部产生采样时钟)。 (3)使能RRST或XRST,注意此时要保证SPCR中仅有此一位发生改变。 (4)使能FRST(FRST=1)(如果需要DSP内部产生帧同步)。 (5)等待2个R/T CLK时钟周期后,收或发端便会有效。

4. 汇编语言程序中的变量

汇编语言程序中的公用变量应在文件中定义,如.def carry。汇编语言程序中使用的局部变量不需定义,可直接声明,例如trn_num .word 00h。如果在两个asm文件中有两个都没有定义的同名变量,则编译程序会认为分他们不是同一变量。在汇编程序的开头应有.mmregs宏语句。它一方面表示对默认定义的确认(ah,bh,trn等),另一方面可以对所用寄存器重新定义。如: .mmregs DMPREC .set 54h ;定义DMA优先和使能寄存器地址在54h DMSA .set 55h DMSDN .set 57h DXR10 .set 23h ;定义串口1的发送寄存器地址在23h。

5. ST1寄存器中CPL位的影响

CPL位是编译模式控制位,它表示在相对直接寻址时采用哪种指针。当CPL=0时,使用页指针DP;当CPL=1时,使用堆栈指针SP。实际使用中二者没有什么差别,但使用SP寻址的程序更易读。在程序中经常使用CPL=1。

审核编辑黄昊宇

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

    关注

    553

    文章

    8030

    浏览量

    349307
  • 编程
    +关注

    关注

    88

    文章

    3627

    浏览量

    93807
收藏 人收藏

    评论

    相关推荐

    TMS320C6000 DSP软件可编程锁相环控制器指南

    电子发烧友网站提供《TMS320C6000 DSP软件可编程锁相环控制器指南.pdf》资料免费下载
    发表于 12-24 16:54 0次下载
    TMS320C6000 <b class='flag-5'>DSP</b>软件可<b class='flag-5'>编程</b>锁相环控制器指南

    使用 AMD Versal AI 引擎释放 DSP 计算的潜力

    更低的功耗获得高性能 DSP^1^以及更少的可编程逻辑资源。^2^ “Versal AI 引擎可以在降低功耗预算的情况下提高 DSP 计算密度,”
    的头像 发表于 11-29 14:07 544次阅读

    使用AMD Versal AI引擎加速高性能DSP应用

    AMD Versal AI 引擎使您能够扩展数字信号处理( DSP )算力与面向未来的设计,从而适应当前和下一代计算密集型 DSP 应用。借助 Versal AI 引擎,客户能以更低的功耗1和更少的可
    的头像 发表于 11-20 16:35 352次阅读

    通过DSP的mcbsp和i2c接口实现对AIC34芯片的操作,如何编程

    通过DSP的mcbsp和i2c接口实现对AIC34芯片的操作如何编程,有没有相关的例程吗?
    发表于 11-07 08:12

    用PPS进行miniDSP编程几个问题求解答

    是AD转换后的数字信号?DSP_A_DSP_D右边的部分是miniDSP D?里面的数据是DA转换后的模拟信号? 问题三:我还有另一种与上面相矛盾的想法:Dec4xIn_1是采样组件,作为输入源,它的输出
    发表于 11-01 07:29

    DSP控制器的主要优势是什么?

    DSP可以同时处理多个数据流,这对于实时信号处理非常重要。 低功耗 : DSP通常比通用处理器更节能,因为它们专为特定任务优化。 可编程性 : DSP是可
    的头像 发表于 09-24 16:21 517次阅读

    使用运算放大器应注意哪几个问题

    以下是使用运算放大器时应注意的几个关键问题: 运算放大器的基本原理 : 运算放大器是一种高增益、多用途的电子设备,广泛应用于信号放大、滤波、积分和微分等电路中。 了解其基本结构,包括输入级、增益级
    的头像 发表于 08-06 14:26 557次阅读

    DSP的硬件架构与关键技术

    DSP,全称Digital Signal Processor,即数字信号处理器,是一种具有特殊结构的微处理器,其设计初衷是为了高效地进行数字信号处理。DSP芯片内部集成了针对数字信号处理优化的硬件
    的头像 发表于 07-17 16:37 2592次阅读

    解决关键问题 明星产品B15i获客户致谢

    B15i网桥解决关键难题近日,自连客户与我们分享了一则喜讯:因解决了某项目中的关键性技术问题,收到了合作方发来的致谢函。在该项目解决方案中发挥关键作用的重要物联通信产品,便是自连智能终端明星产品之一
    的头像 发表于 06-20 08:16 361次阅读
    解决<b class='flag-5'>关键问题</b>  明星产品B15i获客户致谢

    编程电源如何编程

    编程电源的编程方法和步骤。 ### 1. 可编程电源的基本概念 可编程电源通常由以下几个部分组
    的头像 发表于 06-10 15:24 1405次阅读

    fpga编程与单片机编程的区别

    FPGA编程与单片机编程的主要区别体现在以下几个方面。
    的头像 发表于 03-14 17:16 1029次阅读

    变频器使用必须注意的关键问题

    变频器的保护结构变频器内部产生大量热量,为提高散热的经济性,除小容量变频器都是开启式结构,其余的都采用风扇强制冷却。
    发表于 03-07 11:17 625次阅读

    AMBA总线之AXI设计的关键问题讲解

    首先我们看一下针对AXI接口的IP设计,在介绍之前我们先回顾一下AXI所具有的一些feature。
    的头像 发表于 02-20 17:12 1869次阅读
    AMBA总线之AXI设计的<b class='flag-5'>关键问题</b>讲解

    分享DSP和ARM的激光粒度仪关键电路设计

    DSP技术实现MIE散射算法有很多优点:它是专为算法计算而设计的专用CPU,所以它运算速度很快;与通用CPU相比它成本低,所以有很好的性价比;而且它的体积小,能实现仪器一体化等等优点。ARM具有丰富的片上资源,适合嵌入式系统的开发,主要负责操作系统的运行、任务管理和协调以及DSP
    发表于 02-15 16:13 385次阅读
    分享<b class='flag-5'>DSP</b>和ARM的激光粒度仪<b class='flag-5'>关键</b>电路设计

    分享 | 可编程晶振芯片几个知识点

    什么是可编程晶振?可编程晶振多为有源晶振,由两个芯片组成;一个是全硅MEMS谐振器,一个是具有温补功能的芯片,可以启动电路锁相环CMOS
    的头像 发表于 01-09 17:51 993次阅读
    分享 | 可<b class='flag-5'>编程</b>晶振芯片<b class='flag-5'>几个</b>知识点