- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数字信号处理器技术原理与开发应用(第二版)-课件-4
第四章 C54x数字信号处理器程序设计开发基础 本章内容: 4.1 C54x DSP汇编程序设计基础 4.2 数据寻址方式 4.3 汇编语言指令系统 4.4 汇编伪指令 4.5 C54x DSP C程序开发基础 4.6 DSP C与汇编混合编程 4.7 C54x DSP C程序的优化 C54x数字信号处理器程序设计开发基础 4.1 C54x DSP汇编程序设计基础 C54x DSP汇编程序设计基础 汇编程序语句基本结构 汇编语言数据类型 表达式 汇编程序语句基本结构 C54x汇编源程序包括: 汇编伪指令 汇编语言指令 宏汇编指令 注释的源语句 汇编语言数据类型 汇编语言常量 字符串 符号 汇编语言常量 C54x汇编器支持7种类型的常量:二进制整数、八进制整数、十进制整数、十六进制整数、字符常量、汇编时间常量、浮点数常量。 常量不能进行符号扩展。 在C54x代数汇编源程序中,常量必须以 # 开头。 表达式 表达式是由运算符隔开的常量、符号或常量和符号序列。 影响表达式运算顺序的主要因素: 圆括号:圆括号内的表达式先运算 优先级:运算级高的运算先执行,圆括号内的运算优先级最高 同级运算顺序:同级内的运算顺序从左向右 C54x数字信号处理器程序设计开发基础 4.1 C54x DSP汇编程序设计基础 4.2 数据寻址方式 数据寻址方式 数据寻址方式:DSP硬件在寻找指令所指定的参与运算的操作数时所采取的方法。 不同的CPU指令采用的数据寻址方式有所不同 合理使用不同的数据寻址方式有助于提高代码的执行效率 C54x有7种数据寻址方式: 立即数寻址 (Immediate Addressing) 绝对寻址 (Absolute Addressing) 累加器寻址 (Accumulator Addressing) 直接寻址 (Direct Addressing) 间接寻址 (Indirect Addressing) 存储器映射寄存器寻址 (MMR Addressing) 堆栈寻址 (Stack Addressing) 立即数寻址 (Immediate Addressing) 指令中本身就包含一个立即操作数,并在操作数前加“#”来表示,没有寻址过程 立即数有两类: 短立即数:3、5、8 或 9 bits,由单字指令(长度16bit)携带 长立即数:16bits,由双字指令(32bit)携带(立即数占其中16bits) 语法:# 例如 LD #12h,A ;将立即数12h装入累加器A 绝对寻址 (Absolute Addressing) 利用16位绝对地址访问存储单元,指令中包含一个确定的16位地址(可以是程序中的地址标号或符号常数) 该类指令至少为双字长 有四种类型: 数据存储器地址(dmad)寻址:MVKD SAMPLE,*AR5 程序存储器地址(pmad)寻址:MVPD TABLE,*AR7- 端口地址(PA)寻址:PORTR FIFO,*AR5 *(lk)寻址:LD *(BUFFER),A 累加器寻址 (Accumulator Addressing) 把累加器A的数作为地址去访问(扩展)程序存储空间中的数据内容 有两条指令使用这种方式: READA Smem:把累加器A所确定的程序存储器单元中的一个字,传送到Smem所确定的数据存储单元去 WRITA Smem:把Smem所确定的数据存储器单元中的一个字,传送到累加器A所确定的程序存储单元去 直接寻址 (Direct Addressing) 利用数据指针DP和堆栈指针SP寻址,数据存储器的实际地址由基地址(DP或SP指向的地址) 和地址偏移量(要寻址的数据存储器地址(dmad)的低7位) 共同构成 间接寻址 (Indirect Addressing) 将辅助寄存器作为地址指针访问存储器 C54x有 8个16bit辅助寄存器 (AR0 ~ AR7),每个寄存器都可以作为指针寻址64K字数据存储空间的任何一个单元 两个辅助寄存器运算单元 (ARAU0、ARAU1) ,可根据指令对地址指针 ARx 进行递增递减等无符号的16bit算术运算 ARAU0/ARAU1 对指针 ARx 的循环加/减运算和倒序加/减运算为C54x提供了两种特殊的间接寻址方式: 循环寻址 位倒序寻址 如何存储采样数据更节省存储空间 ? 循环缓冲区:一个最新数据的滑动窗口 如何实现循环缓冲区的数据寻址 ? 存储器映射寄存器寻址(MMR Addressing) MMR寻址 由于MMR位于数据空间第0页128字内,所以对其寻址时只利用地址操作数的低7位 可以使用存储器寄存器寻址的8条指令:LDM、MVDM、 MVMD、MVMM、POPM、PSHM、STLM、STM 存储器映射的寄存器地址是
文档评论(0)