打印

TI C54xx DSP 十天速成讲义 实验二

[复制链接]
2273|2
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
gexingyouxian|  楼主 | 2011-11-20 23:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
实验二 基本运算
<本节选自为HK-DSP实验箱写的实验指导书,有待整理>
DSP指令数量最多的是:算术指令、逻辑指令和数据加载与传送指令。数据加载与传送指令由于处处要用,所以不单独列为实验。算术与逻辑指令也是数量繁多,无法一一举例,这里简单举一个加法和除法的例子,乘法和乘加指令在FIR用得比较多,稍后一并介绍。其它指令有兴趣可以对照指令表的说明,试验一下各指令运行的结果。

相关帖子

沙发
gexingyouxian|  楼主 | 2011-11-20 23:36 | 只看该作者
实验2.1 加减法计算
************************************************
*计算z=x+y-w。
************************************************
.mmregs
.def CodeStart
Data_DP: ;数据段指针
x: .word 10 ;初始化变量
y: .word 26
w: .word 23
z: .word 0

.text
CodeStart:
LD #Data_DP,DP ;装载数据指针DP
STM #STACK+10H,SP
SUMB: LD x,A ;A=x
ADD y,A ;A=A+y
SUB w,A ;A=A-w
STL A,z ;z=A
END: B END

计算结果数据存储器地址存储内容十进制
x1010H000aH10
y1011H001aH26
w1012H0017H23
z1013H000dH13


技巧提示:试验算术指令由于不需要外部资源,可以不需要仿真器和实验箱。同学们可以平时自己用软件仿真,多多实验。但是复杂的算法最好还是在线仿真,因为程序是流水线执行,软件仿真有时与实际硬件执行结果有所不同。

使用特权

评论回复
板凳
gexingyouxian|  楼主 | 2011-11-20 23:37 | 只看该作者
实验2.2 除法计算
DSP并没有除法指令,回想一下我们用在稿纸上演算除法列的竖式,实际是一种移位减法,DSP中也是通过做多次减法的办法来做除法。下面例子是把用除以10的办法二进制数转成BCD码例子:
*********************************
*16进制转BCD码
*********************************
.mmregs
.global CodeStart

.data
x: .word 1234 ;待转换的数字
y: .word 10 ;除数
z: .word 0Fh,0Fh,0Fh,0Fh,0Fh;结果区,每位BCD存一个字,
;初始化为F因为实验板的数码管不显示F

.text
 
CodeStart:
LD #x,DP ;设置DP
LD x,A ;被除数
STM #z,AR1 ;结果区指针
loop:
RPT #15 ;执行完16次减法后,A的高16位是余数
SUBC y,A ;低16位是商
STH A,*AR1+ ;余数保存到Z
AND #0FFFFH,A ;掩盖掉高16位,保留商值
BC loop,ANEQ ;继续做除法直到商为0
end: B end

练习:
练习其他算术指令

其它参考:
spru172c:TMS320C54x DSP Reference Set Volume 2: Mnemonic Instruction
Set,2.1 Arithmetic Operations
这个资料对每个指令都有详细说明。也可以在Help中的TMS320C54x DSP Mnemonic Instruction
Set中查询或搜索相关指令。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

197

主题

1530

帖子

2

粉丝