- 1、本文档共34页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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 *,
您可能关注的文档
- 电流与电压和电阻的关系(使用).ppt
- 内燃机构造自测题库(按章节分).doc
- Photoshop图像的选取(套索和魔棒工具).ppt
- DPtechFW1000系列防火墙系统测试方案.doc
- 电流电压电阻基础知识练习.doc
- DNC产品介绍0207.ppt
- DOE经典培训资料.ppt
- Dreamweaver入门.ppt
- Dreamweaver教程.ppt
- 电流做功PPT.ppt
- DB4403T-诚信计量管理规范 第2部分:集贸市场.pdf
- DB62T1212-2022 绿色食品粒用型高粱生产技术规程.pdf
- 农作物优异种质资源评价规范 李.pdf
- DB44T1422.1-2014 科普展项及布展通用规范 第1部分:展项设计.pdf
- DB62T4517-2022 鸡滑液囊支原体病防控技术规范.pdf
- 肥料 汞、砷、镉、铅、铬含量的测定.pdf
- DB33T1303-2023 公共体育场馆应急救护管理规范.pdf
- QNBSH24-2023 深冲用无间隙原子热轧钢带.pdf
- TZZB-防腐防爆磁致伸缩液位计.pdf
- DGJ08-2070-2010 房屋白蚁防治技术规程 (2).pdf
文档评论(0)