- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
sjtu sjtu_dsp 2008-1 sjtu TMS320C54x汇编指令集:符号与缩写 TMS320C54x汇编指令集:符号与缩写 TMS320C54x汇编指令集:符号与缩写 TMS320C54x汇编指令集:符号与缩写 算术指令:加法指令(1) 算术指令:加法指令(2) 算术指令:减法指令(1) 算术指令:减法指令(2) 算术指令:乘法指令 算术指令:乘加和乘减指令(1) 算术指令:乘加和乘减指令(2) 算术指令:乘加和乘减指令(3) 算术指令:双字指令(1) 算术指令:双字指令(3) 算术指令:特殊指令(1) 算术指令:特殊指令(2) 逻辑运算:逻辑与、或、异或指令(1) 逻辑运算:逻辑与、或、异或指令(2) 逻辑运算:移位与测试指令 程序控制:跳转指令 程序控制:调用指令 程序控制:中断指令 程序控制:返回指令 程序控制:重复指令 程序控制:堆栈操作指令 程序控制:其他控制指令 加载指令(1) 加载指令(2) 存储指令(1) 存储指令(2) 并行指令(1) 并行指令(2) 并行指令(3) 其他加载和存储指令 用伪指令.mlib来访问宏库,其语法为: --多项式运算 Word32 Acc0; for( i = 0; i N; i++ ) { Acc0 = 0; for( j = 0; j M; j++ ) Acc0 += (x[i+j] * h[j])1; y[i] = Acc0 16; } ; x[0] - AR2; h[0] - AR3; y[0] - AR4; M - AR0; stm #(N-1), BRC rptb loop_end - 1 sub A rpt #(M-1) mac *AR2+, *AR3+, A ; AR2- x[i+M], AR3-h[M] sth A, *AR4+ ; AR4-y[i], *AR4+ - y[i+1] mar *AR2-0 ; AR2 - x[i] mar *AR2+ ; AR2 - x[i+1] mar *AR3-0 ; AR3 - h[0] loop_end: ; x[0] - AR2; h[0] - AR3; y[0] - AR4; -M+2 - AR0; stm #(N-1), BRC stm #0, BK rptb loop_end - 1 sub A; rpt #(M-2) mac *AR2+, *AR3+, A ; AR2 - x[i+M-1], AR3 - h[M-1] mac *AR2+0%, *AR3+0%, A ; AR2 - x[i+1], AR3 - h[1] sth A, *AR4+ mar *AR3- ; AR3 - h[0] loop_end: ; x[0] - AR2; h[0] - AR3; y[0] - AR4; -M+2 - AR0; stm #(N-1), BRC ld #0, ASM rptbd loop_end - 1 stm #0, BK sub A; rpt #(M-2) mac *AR2+, *AR3+, A ; AR2 - x[i+M-1], AR3 - h[M-1] mac *AR2+0%, *AR3+0%, A ; AR2 - x[i+1], AR3 - h[1] st A, *AR4+ || ld *AR3-, A ; AR3 - h[0] loop_end: 汇编程序的优化 合理选择汇编指令 直接实现功能 ld *AR3, A stlm A, AR2 mvdk *AR3, AR2 减少寄存器资源的利用 无流水线冲突考虑 减少流水线冲突 汇编程序的优化 合理选择汇编指令(续) 良好的寻址方式 减少运行时间 减小代码长度 循环结构的嵌套和延迟选项的使用 rpt 硬件支持的单语句循环 rptb 硬件支持的块循环 banz “快速”软件循环 bc 普通循环 汇编程序的优化 循环结构的嵌套和延迟选项的使用(续) rptbd banzd bd 双寻址语句和并行语句 mac *AR2+, *AR3-, A st A, *AR2+ || add *AR3+, B 汇编程序的优化 特殊语句的运用 bit reverse addressing FIRS POLY … 循环缓存的利用 减少数据缓冲更新的时间 汇编程序的优化(举例) 链接器 将COFF文件组合一起,连接相关库文件生成可执行模块。 链接器(续) 按照目标系统需要给存储器分段 对符号和段重新定位,确定最后的地址 确定输入文件之间
原创力文档


文档评论(0)