Improvements to Conservative and Optimistic Register Coalescing - Archive ouverte HAL Access content directly
Journal Articles Proceedings of the 2008 international conference on Compilers, architectures and synthesis for embedded systems Year : 2008

Improvements to Conservative and Optimistic Register Coalescing

(1) , (1) , (1)
1

Abstract

Register coalescing is used, as part of register allocation, to reduce the number of register copies. Developing efficient register coalescing heuristics is particularly important to get rid of the numerous move instructions introduced by code transformations such as static single assignment, among others. The challenge is to find a good trade-off between a too aggressive strategy that could make the interference graph uncolorable, possibly increasing the spill (transfer to memory), and a too conservative strategy that preserves colorability but leaves too many moves. The two main approaches are ``iterated register coalescing'' by George and Appel and ``optimistic coalescing'' by Park and Moon. The first one coalesces moves, one by one, in a conservative way. In the second one, moves are first coalesced regardless of the colorability, then some coalescings are undone to reduce spilling. Previous experiments show that optimistic coalescing outperforms conservative coalescing. We show that, with a more involved conservative strategy, incremental conservative coalescing can be as efficient as optimistic coalescing. We also develop a more aggressive optimistic approach with a different de-coalescing phase. The combination of the two approaches leads to about 10% improvements compared to traditional optimistic coalescing.
Fichier principal
Vignette du fichier
main-RR-LIP.pdf (187.61 Ko) Télécharger le fichier
Origin : Files produced by the author(s)
Loading...

Dates and versions

ensl-00179685 , version 1 (16-10-2007)

Identifiers

Cite

Florent Bouchez, Alain Darte, Fabrice Rastello. Improvements to Conservative and Optimistic Register Coalescing. Proceedings of the 2008 international conference on Compilers, architectures and synthesis for embedded systems, 2008, pp.147-156. ⟨10.1145/1450095.1450119⟩. ⟨ensl-00179685⟩
141 View
322 Download

Altmetric

Share

Gmail Facebook Twitter LinkedIn More