Publication | Open Access
Linear scan register allocation
349
Citations
15
References
1999
Year
Mathematical ProgrammingEngineeringCompiler TechnologyComputer ArchitectureComputational ComplexitySoftware AnalysisArray ComputingGraph ColoringParallel ComputingCombinatorial OptimizationCompilersInstruction-level ParallelismDynamic CompilationProgramming LanguagesLinear ScanParallelizing CompilerCompiler SupportComputer EngineeringComputer ScienceOptimizing CompilerVirtual MemoryLinear Scan AlgorithmProgram AnalysisParallel Programming
We describe a new algorithm for fast global register allocation called linear scan . This algorithm is not based on graph coloring, but allocates registers to variables in a single linear-time scan of the variables' live ranges. The linear scan algorithm is considerably faster than algorithms based on graph coloring, is simple to implement, and results in code that is almost as efficient as that obtained using more complex and time-consuming register allocators based on graph coloring. The algorithm is of interest in applications where compile time is a concern, such as dynamic compilation systems, “just-in-time” compilers, and interactive development environments.
| Year | Citations | |
|---|---|---|
Page 1
Page 1