Extended basic block

In computing, an extended basic block[1][2] is a collection of basic blocks of the code within a program with certain properties that make them highly amenable to optimizations. Many compiler optimizations operate on extended basic blocks.

Definition

An extended basic block is a maximal collection of basic blocks where:

  • only the first basic block can have multiple predecessor basic blocks;
  • all the other basic blocks have one single predecessor basic block, which must be within the collection of basic blocks.

Uses

Many local optimizations that operate on basic blocks can be easily extended to operate on extended basic blocks. An example is common subexpression elimination which removes duplicate expressions. In its simplest form it is a local optimization, operating only on basic blocks.[3]

gollark: You're really missing out.
gollark: How did you watch all of it in 2 minutes?
gollark: Maybe we should construct one. I'll look into it.
gollark: https://www.youtube.com/channel/UC1-OfM2S82XP0NYY_xSh54w?app=desktop
gollark: We *might* be. Have you seen the apioform series?

See also

Notes

  1. Cooper, Keith D., and Torczon, Linda, Engineering a Compiler, Morgan Kaufmann, 2004, ISBN 1-55860-699-8 page 405
  2. Steven S. Muchnick Advanced Compiler Design and Implementation, Morgan Kaufmann Publishers, 1997. ISBN 1-55860-320-4 page 175
  3. "Archived copy". Archived from the original on 2014-05-15. Retrieved 2012-07-04.CS1 maint: archived copy as title (link)


This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.