- 1、本文档共125页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
DSP指令系统与特点
TMS320C54X的指令系统 ?‘C54x指令集举例 ?‘C54x特殊指令 使用说明 TMS320C54x的指令集 TMS320C54x的指令集有近两百条指令,按功能分为如下几类: ?算术运算指令 ?逻辑运算指令 ?程序控制指令 ?装入和存储指令 一、算术运算指令 算术运算指令可分为如下几类: ? 加法指令 ? 减法指令 ? 乘法指令 ? 乘加指令 ? 乘减指令 ? 双数/双精度指令 ? 特殊操作指令 1、加法指令 使用ADD完成加法 利用ADDS实现32位数据装入 2、减法指令 TMS320C54x汇编指令集:符号与缩写 实现16位定点减法 ‘C54X中提供了多条用于减法的指令,如SUB,SUBB,SUBC和SUBS。其中SUBS用于无符号数的减法运算,SUBB用于带借位的减法运算(如32位扩展精度的减法),而SUBC为带条件的移位减,DSP中的除法就是用该指令来实现的。SUB指令与ADD指令一样,有许多的寻址方式 减法指令使用举例 SUB A, -8, B 利用SUBC实现除法 在‘C54X中没有提供专门的除法指令,一般有两种方法来完成除法。一种是用乘法来代替,除以某个数相当于乘以其倒数,所以先求出其倒数,然后相乘。这种方法对于除以常数特别适用。另一种方法是使用SUBC指令,重复16次减法完成除法运算。 利用SUBC完成Temp1/Temp2 3、乘法指令 实现16定点整数乘法 在‘C54X中提供了大量的乘法运算指令,其结果都是32位,放在A或B寄存器中。乘数在‘C54X的乘法指令很灵活,可以是T寄存器、立即数、存贮单元和A或B寄存器的高16位。如果是无符号数乘时,请使用MPYU指令。这是一条专用于无符号数乘法运算的指令,而其它指令都是有符号数的乘法。 整数乘法举例 实现小数乘法 在‘C54X中,小数的乘法与整数乘法基本一致,只是由于两个有符号的小数相乘,其结果的小数点的位置在次高的后面,所以必须左移一位,才能得到正确的结果。‘C54X中提供了一个状态位FRCT,将其设置为1时,系统自动将乘积结果左移移位。两个小数(16位)相乘后结果为32位,如果精度允许的话,可以只存高16位,将低16位丢弃,这样仍可得到16位的结果。 小数乘法举例 4、乘加与乘减指令 5、双精度/双数操作指令 6、特殊指令 数据归一化相关指令EXP、NORM 归一化一个数是先求其指数,然后把它调整到最大精度格式。实现方法如下: 二、逻辑运算指令 逻辑指令包括与、或、异或、移位和测试指令 1、与指令(AND) 2、或、异或指令 3、移位和测试指令 三、程序控制指令 程序控制指令包括: 分支指令 调用指令 中断指令 返回指令 重复指令 堆栈操作指令 混合程序控制指令 1、分支指令 3、返回指令 4、重复指令和堆栈操作指令 5、混合程序控制指令 四、装入和存储指令 装入和存储指令包括: 一般的装入和存储指令 条件存储指令 并行装入和存储指令 并行装入和乘法指令 并行存储和加件乘指令 混合装入和存储指令 1、一般的装入指令 2、存贮指令 5、并行存储和加、减、乘法指令 6、并行装入和乘法指令 7、混合装入和存储指令 注意:同一条指令在不同存储器中可能有不同执行时间 操作数在双寻址空间、单寻址空间和外部 程序代码在双寻址、单寻址和外部空间 操作数和代码在相同存储器块中 数据空间插入了等待周期 程序空间插入了等待周期 特殊指令使用说明 FIRS指令 FIRS指令用于线性相位滤波器的处理。一个如下图的8阶线性相位滤波器的输出表达式: FIR滤波的两指令MAC、FIRS 数据块移动MVDD、MVDP、MVPD 在C54x系列DSP,数据与数据存储器、数据与程序存储器之间可以方便的进行数据传输,结合单指令循环可实现数据块移动。如16个系数的移动: 最小均方运算LMS 在进行自适应滤波等操作中经常会使用LMS算法,C54x提供的LMS指令方便了编程。如下图所示的自适应滤波器设计中,滤波器系数修正公式为: 基于LMS的自适应滤波编程 C16位用来选择运算处于双精度/双ALU运算模式。 C16=0:双精度模式; C16=1:双ALU运算模式。 If src=0 T=0; Else T=引导位数-8(保护字)-1(符号位) 求引导位数:先将负数转换成补码;移去非有 效位所需要的位数,不包含符号位。 2、调用与中断指令 3 并行装入和存储指令 4、条件存储指令 FIRS指令使用方法: FIRS *AR2+, *A
文档评论(0)