keil优化等级设置

keil优化等级设置

ID:9219190

大小:120.99 KB

页数:6页

时间:2018-04-23

keil优化等级设置_第1页
keil优化等级设置_第2页
keil优化等级设置_第3页
keil优化等级设置_第4页
keil优化等级设置_第5页
资源描述:

《keil优化等级设置》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、优化级别说明(仅供参考):则其中的CodeOptimization栏就是用来设置C51的优化级别。共有9个优化级别(书上这么写的),高优化级别中包含了前面所有的优化级别。现将各个级别说明如下:0级优化:1、常数折叠:只要有可能,编译器就执行将表达式化为常数数字的计算,其中包括运行地址的计算。2、简单访问优化:对8051系统的内部数据和位地址进行访问优化。3、跳转优化:编译器总是将跳转延至最终目标上,因此跳转到跳转之间的命令被删除。1级优化:1、死码消除:无用的代码段被消除。2、跳转否决:根据一个测试回溯,条件跳转被仔细检查,以决定是否能够简化或删除。2级优化:1、数据覆

2、盖:适于静态覆盖的数据和位段被鉴别并标记出来。连接定位器BL51通过对全局数据流的分析,选择可静态覆盖的段。3级优化:1、“窥孔”优化:将冗余的MOV命令去掉,包括不必要的从存储器装入对象及装入常数的操作。另外如果能节省存储空间或者程序执行时间,复杂操作将由简单操作所代替。4级优化:1、寄存器变量:使自动变量和函数参数尽可能位于工作寄存器中,只要有可能,将不为这些变量保留数据存储器空间。2、扩展访问优化:来自IDATA、XDATA、PDATA和CODE区域的变量直接包含在操作之中,因此大多数时候没有必要将其装入中间寄存器。3、局部公共子式消除:如果表达式中有一个重复执行

3、的计算,第一次计算的结果被保存,只要有可能,将被用作后续的计算,因此可从代码中消除繁杂的计算。4、CASE/SWITCH语句优化:将CASE/SWITCH语句作为跳转表或跳转串优化。5级优化:1、全局公共子式消除:只要有可能,函数内部相同的子表达式只计算一次。中间结果存入一个寄存器以代替新的计算。2、简单循环优化:以常量占据一段内存的循环再运行时被优化。6级优化:1、回路循环:如果程序代码能更快更有效地执行,程序回路将进行循环。7级优化:1、扩展入口优化:在适合时对寄存器变量使用DPTR数据指针,指针和数组访问被优化以减小程序代码和提高执行速度。8级优化:1、公共尾部合

4、并:对同一个函数有多处调用时,一些设置代码可被重复使用,从而减小程序代码长度。9级优化:1、公共子程序块:检测重复使用的指令序列,并将它们转换为子程序。C51甚至会重新安排代码以获得更多的重复使用指令序列。当然,优化级别并非越高越好,应该根据具体要求适当选择。KeilC51的编译器有一个优化设置,不同的优化设置,会产生不同的编译结果。一般情况缺省编译优化设置被设定为8级优化,实际最高可设定为9级优化:1.Deadcodeelimination。2.Dataoverlaying。3.Peepholeoptimization。4.Registervariables。5.Co

5、mmonsubexpressionelimination。6.Looprotation。7.ExtendedIndexAccessOptimizing。8.ReuseCommonEntryCode。9.CommonBlockSubroutines。附表:KeilC51中的优化级别及优化作用级别说明0常数合并:编译器预先计算结果,尽可能用常数代替表达式。包括运行地址计算。优化简单访问:编译器优化访问8051系统的内部数据和位地址。跳转优化:编译器总是扩展跳转到最终目标,多级跳转指令被删除。1死代码删除:没用的代码段被删除。拒绝跳转:严密的检查条件跳转,以确定是否可以倒置测

6、试逻辑来改进或删除。2数据覆盖:适合静态覆盖的数据和位段被确定,并内部标识。BL51连接/定位器可以通过全局数据流分析,选择可被覆盖的段。3窥孔优化:清除多余的MOV指令。这包括不必要的从存储区加载和常数加载操作。当存储空间或执行时间可节省时,用简单操作代替复杂操作。4寄存器变量:如有可能,自动变量和函数参数分配到寄存器上。为这些变量保留的存储区就省略了。优化扩展访问:IDATA、XDATA、PDATA和CODE的变量直接包含在操作中。在多数时间没必要使用中间寄存器。局部公共子表达式删除:如果用一个表达式重复进行相同的计算,则保存第一次计算结果,后面有可能就用这结果。多

7、余的计算就被删除。Case/Switch优化:包含SWITCH和CASE的代码优化为跳转表或跳转队列。5全局公共子表达式删除:一个函数内相同的子表达式有可能就只计算一次。中间结果保存在寄存器中,在一个新的计算中使用。简单循环优化:用一个常数填充存储区的循环程序被修改和优化。6循环优化:如果结果程序代码更快和有效则程序对循环进行优化。7扩展索引访问优化:适当时对寄存器变量用DPTR。对指针和数组访问进行执行速度和代码大小优化。8公共尾部合并:当一个函数有多个调用,一些设置代码可以复用,因此减少程序大小。9公共块子程序:检测循环指令序列,并转

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。