dsp第五章指令.ppt

  1. 1、本文档共34页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
dsp第五章指令

第五章 寻址方式和汇编指令 §5.1 寻址方式 寻址方式是指寻找指令中操作数地址的方式。 TMS320C2000汇编指令有3种存储器寻址方式: 立即寻址方式 直接寻址方式 间接寻址方式 一、立即寻址方式 在立即寻址方式中,指令字包含该指令要操作的常数。 在指令中常数前加“#”用于表示立即操作数。 C2000立即寻址方式分两种类型: 短立即寻址方式 长立即寻址方式。 短立即寻址方式: 指令的操作数为一个8位、9位或13 位的常数; 短立即寻址方式的指令是一个单指令字,该常数就包含在这个单指令字中。 短立即寻址方式: 指令的操作数为一个8位、9位或13 位的常数; 短立即寻址方式的指令是一个单指令字,该常数就包含在这个单指令字中。 短立即寻址方式: 指令的操作数为一个8位、9位或13 位的常数; 短立即寻址方式的指令是一个单指令字,该常数就包含在这个单指令字中。 长立即寻址方式: 指令的操作数为一个16位的常数 指令需两个指令字,该常数为第二指令字。 这个16位的常数可以作为一个绝对值,也可以作为二进制的补码数。 二、直接寻址方式 访问数据存储器的方式:直接和间接寻址方式。 直接寻址方式将指令中的7位操作数与数据存储器页面指针(DP)的9位连接在一起,形成个16位数据存储器地址。 直接寻址方式可访问64k数据存储器的512个数据页面和每个数据页中的128个字单元。 偏移量是指令中的操作数,是页面中的某个地址单元。 偏移量是7位的立即数,作为64K数据存储器地址的低7位, DP值作为数据存储器地址的高9位,用来确定当前数据页。 直接寻址方式的数据存储器地址产生 使用直接寻址方式访问数据存储器的步骤: 1)设置数据页面,将当前数据页面(0-511)装入DP: LDP #k 2)设置偏移量, 给出7位偏移量作为指令的一个操作数。 ADD 5Dh 例1: LDP #4 ADD 9h,5 例2: LDP #500 ; 500 = 1F4h ADDC 6h 三、间接寻址方式 通过一个16位的辅助寄存器间接访问数据存储器。 利用8个16位的辅助寄存器(AR0—AR7)可提供灵活多变且功能强大的间接寻址方式。 辅助寄存器的内容作为一个16位地址可访问64K数据存储器中的任意单元。 除了具有立即操作数或没有操作数的指令外,所有的指令都能使用间接寻址方式。 间接寻址方式不要考虑页地址DP 1. 辅助寄存器的选择 装载ARP来选择辅助寄存器: LST指令 MAR指令 例: MAR *, AR1 支持间接寻址方式的任意指令 由ARP指定的辅助寄存器称为当前辅助寄存器或当前AR 在使用间接寻址方式的指令中,当前辅助寄存器的内容为数据存储器的访问地址。 2. 间接寻址的选择 使用当前辅助寄存器进行间接寻址之后,辅助寄存器算术单元(ARAU)可以对当前辅助寄存器的内容进行修改。 C2000提供了4种修改方法: 无增量或减量 加1或减1 加或减一个变址量 按逆向进位方式加或逆向借位方式减一个变址量 2. 间接寻址的选择 使用当前辅助寄存器进行间接寻址之后,辅助寄存器算术单元(ARAU)可以对当前辅助寄存器的内容进行修改。 C2000提供了4种修改方法: 无增量或减量 加1或减1 加或减一个变址量 按逆向进位方式加或逆向借位方式减一个变址量 2. 间接寻址的选择 使用当前辅助寄存器进行间接寻址之后,辅助寄存器算术单元(ARAU)可以对当前辅助寄存器的内容进行修改。 C2000提供了4种修改方法: 无增量或减量 加1或减1 加或减一个变址量 按逆向进位方式加或逆向借位方式减一个变址量 2. 间接寻址的选择 使用当前辅助寄存器进行间接寻址之后,辅助寄存器算术单元(ARAU)可以对当前辅助寄存器的内容进行修改。 C2000提供了4种修改方法: 无增量或减量 加1或减1 加或减一个变址量 按逆向进位方式加或逆向借位方式减一个变址量 2. 间接寻址的选择 使用当前辅助寄存器进行间接寻址之后,辅助寄存器算术单元(ARAU)可以对当前辅助寄存器的内容进行修改。 C2000提供了4种修改方法: 无增量或减量 加1或减1 加或减一个变址量 按逆向进位方式加或逆向借位方式减一个变址量 3.下次使用的辅助寄存器 许多间接寻址的指令除了可以改变当前AR的内容外,还可以指定下次使用的AR 。 当这些指令执行完毕时,指定的AR成为下一条指令的当前AR ,即为下次使用的AR。 指定下次使用的AR的指令实际上是将一个0-7的值装入ARP中,当前的ARP值则被复制到ARB中 例 : MAR *,

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档