keil优化等级设置42.pdfVIP

  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文档。上传文档
查看更多
keil优化等级设置42

优化级别说明(仅供参考): 则其中的 CodeOptimization 栏就是用来设置C51 的优化级别。共有9个优化 级别(书上这么写的),高优化级别中包含了前面所有的优化级别。现将各个级 别说明如下: 0级优化: 1、 常数折叠:只要有可能,编译器就执行将表达式化为常数数字的计算,其中 包括运行地址的计算。 2、 简单访问优化:对8051系统的内部数据和位地址进行访问优化。 3、跳转优化:编译器总是将跳转延至最终目标上,因此跳转到跳转之间的命令 被删除。 1级优化: 1、 死码消除:无用的代码段被消除。 2、 跳转否决:根据一个测试回溯,条件跳转被仔细检查,以决定是否能够简化 或删除。 2级优化: 1、数据覆盖:适于静态覆盖的数据和位段被鉴别并标记出来。连接定位器BL51 通过对全局数据流的分析,选择可静态覆盖的段。 3级优化: 1、“窥孔”优化:将冗余的MOV命令去掉,包括不必要的从存储器装入对象及 装入常数的操作。另外如果能节省存储空间或者程序执行时间,复杂操作将由简 单操作所代替。 4级优化: 1、寄存器变量:使自动变量和函数参数尽可能位于工作寄存器中,只要有可能, 将不为这些变量保留数据存储器空间。 2、扩展访问优化:来自IDATA、XDATA、PDATA和CODE区域的变量直接包 含在操作之中,因此大多数时候没有必要将其装入中间寄存器。 3、局部公共子式消除:如果表达式中有一个重复执行的计算,第一次计算的结 果被保存,只要有可能,将被用作后续的计算,因此可从代码中消除繁杂的计算。 4、CASE/SWITCH语句优化:将CASE/SWITCH语句作为跳转表或跳转串优化。 5级优化: 1、全局公共子式消除:只要有可能,函数内部相同的子表达式只计算一次。中 间结果存入一个寄存器以代替新的计算。 2、 简单循环优化:以常量占据一段内存的循环再运行时被优化。 6级优化: 1、 回路循环:如果程序代码能更快更有效地执行,程序回路将进行循环。 7级优化: 1、扩展入口优化:在适合时对寄存器变量使用DPTR数据指针,指针和数组访 问被优化以减小程序代码和提高执行速度。 8级优化: 1、 公共尾部合并:对同一个函数有多处调用时,一些设置代码可被重复使用, 从而减小程序代码长度。 9级优化: 1、 公共子程序块:检测重复使用的指令序列,并将它们转换为子程序。C51甚 至会重新安排代码以获得更多的重复使用指令序列。 当然,优化级别并非越高越好,应该根据具体要求适当选择。 KeilC51 的编译器有一个优化设置,不同的优化设置,会产生不同的编译结果。一 般情况缺省编译优化设置被设定为8级优化,实际最高可设定为9级优化: 1.Deadcodeelimination。 2.Dataoverlaying。 3.Peepholeoptimization。 4.Registervariables。 5.Commonsubexpressionelimination。 6.Looprotation。 7.ExtendedIndexAccessOptimizing。 8.ReuseCommonEntryCode。 9.CommonBlockSubroutines。 附表:KeilC51 中的优化级别及优化作用 级别 说明 0 常数合并:编译器预先计算结果,尽可能用常数代替表达式。包括运行 地址计算。 优化简单访问:编译器优化访问8051系统的内部数据和位地址。 跳转优化:编译器总是扩展跳转到最终目标,多级跳转指令被删除。 1 死代码删除:没用的代码段被删除。 拒绝跳转:严密的检查条件跳转,以确定是否可以倒置测试逻辑来改进或删除。 2 数据覆盖:适合静态覆盖的数据和位段被确定,并内部标识。BL51连 接/定位器可以通过全局数据流分析,选择可被覆盖的段。 3 窥孔优化:清除多余的MOV指令。这包括不必要的从存储区加载和常 数加载操作。当存储空间或执行时间可节省时,用简单操作代替复杂操作。 4 寄存器变量:如有可能,自动变量和函数参数分配到寄存器上。为这些 变量保留的存储区就省略了。 优化扩展访问:IDATA、XDATA、PDATA和CODE 的变量直接包含在操作中。 在多数时间没必要使用中间寄存器。 局部公共子表达式删除:如果用一个表达式重复进行相同的计算,则保存第一次 计算结果,后面有可能就用这结果。多余的计算就被删除。 Case/Switch优化:包含SWITCH和CASE 的代码优化

文档评论(0)

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

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

1亿VIP精品文档

相关文档