- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第五讲 DSP芯片的汇编语言101102;1.算术运算指令(79条分为6小类)
? 加法指令(ADD);
? 减法指令(SUB);
? 乘法指令(MPY);
? 乘加指令(MAC)和乘减指令(MAS);
? 双数/双精度指令(DADD、DSUB);
? 特殊操作指令(ABDST、SQDST)。 ; (1) 加法指令(13条)《附录A TMS320C54X指令集》
说明:① 不同的加法指令用途不同;
ADD:不带进位;
ADD《:不带进位、移位;
ADDC:带进位;
ADDM:专用于立即数;
ADDS:无符号数;
;Add Instructions; 加法指令举例
【例1】 ADD *AR3+, 14, A
;将AR3所指的数据存储单元内容,左移14位与A相加,结果放A中,AR3加1。
; 加法指令举例
【例1】 ADD *AR3+, 14, A
;将AR3所指的数据存储单元内容,左移14位与A相加,结果放A中,AR3加1。
;Example 2: ADD #4568, 8, A, B;Example 2: ADD #4568, 8, A, B;(2) 减法指令(13条) 《附录A》
说明:SUBS用于无符号数的减法运算;
SUBB用于带借位的减法运算(如32位扩展精度的减法);
SUBC为条件减法 .
;减法指令举例: P182;Example 3: SUBB 5, A;Example 3: SUBB 5, A; (3) 乘法指令(10条)《附录A》
说明: ① 不同的乘法指令完成不同的功能
MPY:普通乘指令;
MPYR:带四舍五入指令;
MPYA: A累加器高端参与乘法;
MPYU:无符号乘法;
SQUR:平方;
② 小数乘法
将FRCT设置为1,系统自动将乘积结果左移1位。 ; 乘法指令举例
【例5】 MPY 13,A ;P164;(4) 乘加和乘减指令(15条)《附录A》
【例6】 MAC *AR5+,A ;A+(AR5)*T→A, AR5= AR5+1 ;(4) 乘加和乘减指令(15条)《附录A》
【例6】 MAC *AR5+,A ;A+(AR5)*T→A, AR5= AR5+1 ;MAC *AR3+, *AR4+, A ;?;Example 7: MACR *AR5+, *AR6+,A, B;Example 7: MACR *AR5+, *AR6+,A, B;问题;(5)长操作数指令(6条)《附录A》
DADD Lmem,src [,dst] ;P149;例 8: DADD *AR3–, A, B;例 8: DADD *AR3–, A, B;(6)特殊应用指令(15条)《附录A》
? 求绝对值
? 求累加器指数
? 求累加器的最大/小值
? 归一化
? 求多项式的值
? 求两点之间距离的平方
? 求最小均方值
? 对称有限冲击响应滤波器等 ;FIRS Xmem, Ymem, pmad
;B = B + A(32~16) * pmad ,
A = (Xmem + Ymem) 16
MAX dst dst = max(A, B)
MIN dst dst = min(A, B);例 9: FIRS *AR3+, *AR4+, COEFFS ;P154;例 9: FIRS *AR3+, *AR4+, COEFFS; 2. 逻辑指令(5小类)
? 与指令(AND);
? 或指令(OR);
? 异或指令(XOR);
? 移位指令(ROL);
? 测试指令(BITF)。
(1) 与、或、异或指令(共15条)《附录A》
(2) 移位指令和测试指令(共11条)《附录A》
;与指令(AND);例 10: AND A, 3, B;例 10: AND A, 3, B;
文档评论(0)