Linear scan register allocation

M Poletto, V Sarkar - ACM Transactions on Programming Languages …, 1999 - dl.acm.org
M Poletto, V Sarkar
ACM Transactions on Programming Languages and Systems (TOPLAS), 1999dl.acm.org
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 …
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.
ACM Digital Library