第四章ccs软件优化.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CCS软件优化 赵翠芳 主要内容 优化方法 软件流水 多周期循环流水线设计 理解软件优化结果的反馈信息 优化方法 优化和优化过程概述(复习) 利用代码生成工具对C代码进行优化(复习) 汇编代码的优化 概述 程序优化:对软件代码进行处理以获得以下两个主要目标: 更快的运行时间 更大的代码大小 Note: 一般在更快的执行速度和更小的代码大小之间需要进行一个折中(trade off) 概述 1个时钟周期内让尽可能多的功能单元在执行指令。 趋近8*主频(MHz) MIPS 前提:满足各种资源限制(resource bound) 途径: (1)资源合理分配、充分使用 (2)算法?映射?结构 DSP适合对大量数据做相同的运算 概述 为实现高效代码,编程者必须熟练掌握以下几个方面的知识: 处理器结构 编程语言:C、汇编、线性汇编 代码生成工具:编译器、汇编器、连接器 代码优化的三个层次 1、C语言级的优化 2、线性汇编优化 3、手工汇编优化 C语言级的优化 ——编译器选项 C优化编译器 使用ANSI C代码语言,可达到手工汇编代码效率的80%。如选择-o2,-o3等 整个优化过程包括不同阶段、不同层次的优化。 必须掌握每个阶段、层次的优化知识。 C语言级优化 ——C语言程序优化 通过下述方法改进C语言程序,可以提供编译出代码的性能: 1、使用intrinsics内联函数替代复杂的C语言程序。 2、对短字长的数据使用宽长度的存储器访问——数据打包处理(Packed Data Processing) 3、改进C语言循环程序,使之更有利于用软件流水技术优化。 线性汇编语言简介 线性汇编语句的基本结构 线性汇编中的伪指令 线性汇编资源安排 C代码转换为线性汇编 线性汇编语句的基本结构 基本格式与汇编语言相同,必须是ASCII码文件,扩展名必须是”.sa”,用作汇编优化器的输入文件 Label[[:]] [||] [[register]] mnemonic [unit specifier] [operand list] [;commend] 线性汇编中的伪指令 1、调用一个函数 .call [ret_reg=]func_name(arg1,arg2)(仅在过程procedure)内有效 2、定义一个可被汇编优化器优化,而且可被C/C++当做函数调用的线性汇编代码段的伪指令。 label .cproc [vari1[,vari2,…]] 起始 .endproc 结束 3、定义一个可被汇编优化器优化的线性汇编代码段的伪指令。 label .proc [vari1[,vari2,…]] 起始 .endproc 结束 线性汇编中的伪指令 4、表明存储器地址相关与不相关的伪指令 .mdep[symbol1],[symbol2] 1,2相关 .no_mdep 其后定义的函数段内存储器地址不相关 5、定义变量,或者说描述存入寄存器的数值变量的伪指令: .reg variable1[,variable2,…] 6、过程的返回值 .return [argument] 7、指出循环迭代次数的伪指令 label .trip minimum value 线性汇编资源安排 读取指令(LDH)必须使用.D单元 乘法指令(MPY)必须使用.M单元 加法指令(ADD)必须使用.L单元 减法指令(SUB)必须使用.S单元 跳转指令(B)必须使用.S单元 线性汇编 线性汇编文件使用“.sa”扩展名 线性汇编过程可以: 传递参数 返回结果 使用符号变量 不考虑流水线问题 写线性汇编代码举例—点积 C代码转换为线性汇编 short DP(short *m, short *n, short count) { short i ; short product ; short sum = 0 ; for(i=0;icount;i++) { product = m[i] * n[i] ; sum += product ; } return(sum) ; } 线性汇编 实现上式,需要包括如下步骤: (1)加载采用点数据x[i] (2)加载滤波器系数h[i] (3)x[i]和h

文档评论(0)

wx171113 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档