期刊文献+

代码生成阶段的循环不变量外提

Loop Invariant Code Motion in Code Generator
下载PDF
导出
摘要 循环不变量外提是一种传统的优化算法。在现代编译器中,循环不变量通常在编译器的中端中被删除或外提。中端的中间表示是目标处理机无关的,而编译器的后端的中间表示是目标处理机相关的。尽管中端的优化十分有效,但是从中端的中间表示向后端的中间表示转化的过程中会引入许多循环不变量。因此,有必要在后端再进行循环不变量外提。由于在指令调度的过程能够比较容易地决定一个循环不变量是否需要外提,我们将这一个阶段集成到指令调度中。为了降低指令调度的复杂性,我们把循环不变量的识别和外提区分开来。"识别"独立进行,而决定是否"外提"并实施"外提"则集成到指令调度阶段中。我们在开放源码编译器ORC的代码生成模块中具体实现了本文所介绍的算法。实验结果显示,在代码生成阶段的循环不变量外提能够提高目标代码1%的性能。我们的代价模型避免了78%的循环不变量不必要地外提到循环之外。 Loop invariant code motion (LICM) is a traditional optimization. In modern compiler,it is normally per-formed by the phases of middle-end. The immediate representation (IR) of middle-end is machine independent. And it is machine specific in the back-end. The loop invariants are created when the IR are lowered from middle-end to back-end. Hence,we need to perform the LICM in the back-end. We integrate the LICM into the instruction schedul-ing phase. The reason behind this integration is that it is easy to model the cost of elimination during the phase of scheduling. In order to alleviate the already complex scheduler,we decouple the loop invariant identification from the 'code motion' operation. The identification part is a standalone phase and the 'code motion' part is integrated into scheduling. We have implemented the proposed LICM in the code generator of open source compiler ORC. The result shows the LICM can boost the performance by 1% and obviate the needs of unnecessary motions of 78% loop invariants to their enclosing loops.
出处 《计算机科学》 CSCD 北大核心 2004年第11期158-161,165,共5页 Computer Science
关键词 指令调度 代码生成 编译器 中间表示 目标代码 代价模型 处理机 不变量 循环 优化算法 Loop invariant,Code generation,Partial redundancy elimination,Instruction scheduling
  • 相关文献

参考文献11

  • 1Click C. Global code motion/global value numbering. In:Proc. of the ACM SIGPLAN ′95 Conf. on Programming Language Design and Implementation,La Jolla,California,June 1995. 246-257
  • 2Knoop J,Ruthing O,Steffen B. Lazy code motion. In: Proc. of the ACM SIGPLAN ′ 92 Conf. on Programming Language Design and Implementation. SIGPLAN Notices,1992,27(7):224-234
  • 3Cytron R,Ferrante J,Rosen B K,Wegman M N,Zadeckm F K.Efficiently Computing Static Single Assignment Form and the Control Dependench Graph. ACM Transactions on Programming Languages and Systems, 1991,13(4):461-486
  • 4Muchnick S S. Advanced Compiler Design and Implementation.Morgan Kaufmann Publishers,San Francisco,California. 397-406
  • 5Coffman E G Jr. Computer and Job Shop Scheduling Theory. Wiley,New York,1976
  • 6Muchnick S S. Advanced Compiler Design and Implementation.Morgan Kaufmann Publishers ,San Francisco,California. 539-543
  • 7Chow F C,Hennessy J L. The priority-based coloring approach to register allocation, ACM Trans. on Programming Languages and Systems, 1990,12(4):501-536
  • 8Muchnick S S. Advanced Compiler Design and Implementation.Morgan Kaufmann Publishers, San Francisco,California, 193
  • 9ORC team. ORC v2.0 suite. http://sourceforge. net/projects/ipf-orc,2001-2003
  • 10Intel Corp. http://www. intel.com/design/itanium/itanium/index.htm.

相关作者

内容加载中请稍等...

相关机构

内容加载中请稍等...

相关主题

内容加载中请稍等...

浏览历史

内容加载中请稍等...
;
使用帮助 返回顶部