Affiliation:
1. Univ. of Virginia, Charlottesville, VA
Abstract
To reduce complexity and simplify their implementation, most compilers are organized as a set of passes or phases. Each phase performs a particular piece of the compilation process. In an optimizing compiler, the assignment of function and order of application of the phases is a critical part of the design. A particularly difficult problem is the arrangement of the code generation and optimization phases so as to avoid phase ordering problems caused by the interaction of the phases. In this paper, we discuss the implementation of a compiler/linker that has been designed to avoid these problems. The key aspect of this design is that the synthesis phases of the compiler and the system linker share the same intermediate program representation. This results in two benefits. It permits the synthesis phases of the compiler to be performed in any order and repeatedly, thus eliminating potential phase ordering problems. Second, it permits code selection to be invoked at any point during the synthesis phases as well as at link time. The ability to perform code selection at link time presents many opportunities for additional optimizations. Measurements about the effectiveness of using this approach in a C compiler on two different machines are presented.
Publisher
Association for Computing Machinery (ACM)
Subject
Computer Graphics and Computer-Aided Design,Software
Reference14 articles.
1. An overview of the PL.8 compiler
2. Experience with the pascal P-compiler
3. T.R. Crowley Combining Table-Driven Effect Selection and Description-Driven Peephole Optimization for Automatic Code Generation M.S. Thesis Massachusetts Institute of Technology Boston MA September 1982. T.R. Crowley Combining Table-Driven Effect Selection and Description-Driven Peephole Optimization for Automatic Code Generation M.S. Thesis Massachusetts Institute of Technology Boston MA September 1982.
4. Code selection through object code optimization
Cited by
32 articles.
订阅此论文施引文献
订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献
1. Optimization Algorithm for Link Time Based on Function Reordering;2023 8th International Conference on Control, Robotics and Cybernetics (CRC);2024-12-22
2. Automatic Safe Data Reuse Detection for the WCET Analysis of Systems With Data Caches;IEEE Access;2020
3. Comparative analysis of simulation system for teaching compilers;Bizinfo Blace;2019
4. Decoupling address generation from loads and stores to improve data access energy efficiency;Proceedings of the 19th ACM SIGPLAN/SIGBED International Conference on Languages, Compilers, and Tools for Embedded Systems;2018-06-19
5. Redesigning a tagless access buffer to require minimal ISA changes;Proceedings of the International Conference on Compilers, Architectures and Synthesis for Embedded Systems - CASES '16;2016