Fast liveness checking for ssa-form programs

  • Authors:
  • Benoit Boissinot;Sebastian Hack;Daniel Grund;Benoît Dupont de Dine hin;Fabri e Rastello

  • Affiliations:
  • ENS Lyon / LIP, Université de Lyon - ENS Lyon - CNRS - Inria - UCBL, Lyon, France;INRIA / LIP, Université de Lyon - ENS Lyon - CNRS - Inria - UCBL, Lyon, France;Saarland University, Saarbrücken, Germany;STMicroelectronics, Grenoble, France;INRIA / LIP, Université de Lyon - ENS Lyon - CNRS - Inria - UCBL, Lyon, France

  • Venue:
  • Proceedings of the 6th annual IEEE/ACM international symposium on Code generation and optimization
  • Year:
  • 2008

Quantified Score

Hi-index 0.00

Visualization

Abstract

Liveness analysis is an important analysis in optimizing compilers. Liveness information is used in several optimizations and is mandatory during the code-generation phase. Two drawbacks of conventional liveness analyses are that their computations are fairly expensive and their results are easily invalidated by program transformations. We present a method to check liveness of variables that overcomes both obstacles. The major advantage of the proposed method is that the analysis result survives all program transformations except for changes in the control-flow graph. For common program sizes our technique is faster and consumes less memory than conventional data-flow approaches. Thereby, we heavily make use of SSA-form properties, which allow us to completely circumvent data-flow equation solving. We evaluate the competitiveness of our approach in an industrial strength compiler. Our measurements use the integer part of the SPEC2000 benchmarks and investigate the liveness analysis used by the SSA destruction pass. We compare the net time spent in liveness computations of our implementation against the one provided by that compiler. The results show that in the vast majority of cases our algorithm, while providing the same quality of information, needs less time: an average speed-up of 16%.