Design and Implementation of a Framework for Integrating Front-End and Back-End Compilers
MINNESOTA UNIV MINNEAPOLIS DEPT OF COMPUTER SCIENCE
Pagination or Media Count:
We propose a new universal High-Level Information HLI format to effectively integrate front-end and back-end compilers by passing front-end information to the back-end compiler. Importing this information into an existing back-end leverages the state-of-the-art analysis and transformation capabilities of existing front-end compilers to allow the back-end greater optimization potential than it has when relying on only locally-extracted information. A version of the HLI has been implemented in the SUIF parallelizing compiler and the GCC back-end compiler. Experimental results with the SPEC benchmarks show that HLI can provide GCC with substantiallymore accurate data dependence information than it can obtain on its own. Our results show that the number of dependence edges in GCC can be reduced substantially for the benchmark programs studied, which provides greater flexibility to GCCs code scheduling pass, common subexpression elimination pass, loop invariant code removal pass and register local allocation pass. Even with GCCs optimizations limited to basic blocks, the use of HLI produces moderate speedups compared to using only GCCs dependence tests when the optimized programs are executed on a MIPS R10000 processor.
- Statistics and Probability
- Operations Research