- 1、本文档共93页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
DSP器件及应用课件
1 华中科技大学武昌分校 DSP器件及应用 黄向宇 huangmao72@126.com 第三章 TMS320C54x指令系统 3.1 汇编语言源程序格式 助记符指令一般包含4个部分,其一般组成形式为: [标号][:] 指令域 [操作数] [;注释] 1.标号域 所有汇编指令和大多数汇编伪指令前面都可以带有标号,标号可以长达32个字符,由A~Z、a~z、0~9、_、和$符号组成,且第一个字符不能是数字,区分大小写。 2.指令域 指令域不能从第一列开始,否则被认为是标号。 机器-指令助记符(ABS, STH) 汇编伪指令(.data, .list, .set) 宏伪指令(.macro, .var, .mexit) 宏调用 3.操作数区 操作数区是一个操作数列表,可以是常数、符号或常数与符号构成的表达式。操作数间需用“,”号隔开。 操作数前缀的使用规则: 前缀#表示立即数,如: Label: ADD #123, A 前缀*表示其后的操作数为间接地址,如: Label: LD *AR4, A 前缀@表示直接寻址或绝对寻址,如: ADD #10, @XYZ 4.注释区 注释区可以从任何一列开始,可以包含ASCII字符和空格。 3.2 指令集符号与意义 A 累加器A B 累加器B OVA ST0中累加器A的溢出标志 OVB ST0中累加器B的溢出标志 C ST0中的进位位 ARx 辅助寄存器 SP 堆栈指针 IFR 中断标志寄存器 RC 循环计数器 3.3 TMS320C54x的数据寻址方式 3.3.1 立即寻址 3.3.2 绝对寻址 3.3.3 累加器寻址 3.3.4 直接寻址 3.3.5 间接寻址 3.3.6 存储器映象寄存器寻址 3.3.7 堆栈寻址 3.1 立即寻址 在立即寻址方式中,指令中包括了立即操作数。 一条指令中可对两种立即数编码,一种是短立即数(3、5、8或9位),另一种是16位的长立即数。短立即数指令编码为一个字长,16位立即数的指令编码为两个字长。 立即数寻址指令中在数字或符号常数前面加一个“#”号,来表示立即数。 3.2 绝对寻址 3.2.1 数据存储器(dmad)寻址 3.2.2 程序存储器(pmad)寻址 3.2.3 端口地址(PA)寻址 3.2.4 长立即数*(lk)寻址 3.2.1 数据存储器(dmad)寻址 使用数据存储器寻址的指令有: MVDK Smem, dmad MVDM dmad, MMR MVKD dmad, Smem MVMD MMR, dmad 数据存储器寻址使用符号(符号地址)或一个表示16位地址的立即数来指明寻址的数据存储单元的16位绝对地址。例如: MVKD SMAPLE,*AR5; 3.2.2 程序存储器(pmad)寻址 使用程序存储器寻址的指令有: FIRS Xmem, Ymem, pmad MACD Smem, pmad, src MACP Smem, pmad, src MVDP Smem, pmad MVPD pmad, Smem 程序存储器(pmad)寻址使用符号(符号地址)或一个表示16位地址的立即数来给出程序空间的地址。例如,把程序存储器中标号为TABLE单元中的值复制到AR7所指定的数据存储器中去,指令可写为: MVPD TABLE,*AR7; 3.2.3 端口地址(PA)寻址 使用端口地址的指令有: PORTR PA, Smem PORTW Smem , PA 端口地址(PA)寻址使用一个符号(符号地址)或一个表示16位地址的立即数来给出外部I/O口地址。例如: PORTR FIFO ,*AR5; 3.2.4 长立即数*(lk)寻址 长立即数*(lk)寻址用于所有支持单数据存储器操作数(Smem)的指令。 长立即数*(lk)寻址使用一个符号(符号地址)或一个表示16位地址的立即数来指定数据存储空间的一个地址。例如,把数据空间中地址为BUFFER单元中的数据传送到累加器A,指令可写为: LD *(BUFFER),A 3.3 累加器寻址 累加器寻址是用累加器中的数作为一个地址,这种寻址方式可用来对存放数据的程序存储器寻址。共有两条指令可以采用累加器寻址: READA Smem WRITA Smem READA是把累加器A所确定的程序存储器单元中的一个字,传送到单数据存储器(Smem)操作数
文档评论(0)