Property of an intermediate representation in a compiler
In compiler design, static single assignment form (often abbreviated as SSA form or simply SSA) is a type of intermediate representation (IR) where each variable is assigned exactly once. SSA is used in most high-quality optimizing compilers for imperative languages, including LLVM, the GNU Compiler Collection, and many commercial compilers.
There are efficient algorithms for converting programs into SSA form. To convert to SSA, existing variables in the original IR are split into versions, new variables typically indicated by the original name with a subscript, so that every definition gets its own version. Additional statements that assign to new versions of variables may also need to be introduced at the join point of two control flow paths. Converting from SSA form to machine code is also efficient.
SSA makes numerous analyses needed for optimizations easier to perform, such as determining use-define chains, because when looking at a use of a variable there is only one place where that variable may have received a value. Most optimizations can be adapted to preserve SSA form, so that one optimization can be performed after another with no additional analysis. The SSA based optimizations are usually more efficient and more powerful than their non-SSA form prior equivalents.
In functional language compilers, such as those for Scheme and ML, continuation-passing style (CPS) is generally used. SSA is formally equivalent to a well-behaved subset of CPS excluding non-local control flow, so optimizations and transformations formulated in terms of one generally apply to the other. Using CPS as the intermediate representation is more natural for higher-order functions and interprocedural analysis. CPS also easily encodes call/cc, whereas SSA does not.[1]
History
SSA was developed in the 1980s by several researchers at IBM. Kenneth Zadeck, a key member of the team, moved to Brown University as development continued.[2][3] A 1986 paper introduced birthpoints, identity assignments, and variable renaming such that variables had a single static assignment.[4] A subsequent 1987 paper by Jeanne Ferrante and Ronald Cytron[5] proved that the renaming done in the previous paper removes all false dependencies for scalars.[3] In 1988, Barry Rosen, Mark N. Wegman, and Kenneth Zadeck replaced the identity assignments with Φ-functions, introduced the name "static single-assignment form", and demonstrated a now-common SSA optimization.[6] The name Φ-function was chosen by Rosen to be a more publishable version of "phony function".[3] Alpern, Wegman, and Zadeck presented another optimization, but using the name "static single assignment".[7] Finally, in 1989, Rosen, Wegman, Zadeck, Cytron, and Ferrante found an efficient means of converting programs to SSA form.[8]
Benefits
The primary usefulness of SSA comes from how it simultaneously simplifies and improves the results of a variety of compiler optimizations, by simplifying the properties of variables. For example, consider this piece of code:
y := 1
y := 2
x := y
Humans can see that the first assignment is not necessary, and that the value of y being used in the third line comes from the second assignment of y. A program would have to perform reaching definition analysis to determine this. But if the program is in SSA form, both of these are immediate:
y1 := 1
y2 := 2
x1 := y2
Compiler optimization algorithms that are either enabled or strongly enhanced by the use of SSA include:
Constant propagation – conversion of computations from runtime to compile time, e.g. treat the instruction a=3*4+5; as if it were a=17;
Value range propagation[9] – precompute the potential ranges a calculation could be, allowing for the creation of branch predictions in advance
Strength reduction – replacing expensive operations by less expensive but equivalent ones, e.g. replace integer multiply or divide by powers of 2 with the potentially less expensive shift left (for multiply) or shift right (for divide).
Register allocation – optimize how the limited number of machine registers may be used for calculations
Converting to SSA
Converting ordinary code into SSA form is primarily a matter of replacing the target of each assignment with a new variable, and replacing each use of a variable with the "version" of the variable reaching that point. For example, consider the following control-flow graph:
Changing the name on the left hand side of "x x - 3" and changing the following uses of x to that new name would leave the program unaltered. This can be exploited in SSA by creating two new variables: x1 and x2, each of which is assigned only once. Likewise, giving distinguishing subscripts to all the other variables yields:
It is clear which definition each use is referring to, except for one case: both uses of y in the bottom block could be referring to either y1 or y2, depending on which path the control flow took.
To resolve this, a special statement is inserted in the last block, called a Φ (Phi) function. This statement will generate a new definition of y called y3 by "choosing" either y1 or y2, depending on the control flow in the past.
Now, the last block can simply use y3, and the correct value will be obtained either way. A Φ function for x is not needed: only one version of x, namely x2 is reaching this place, so there is no problem (in other words, Φ(x2,x2)=x2).
Given an arbitrary control-flow graph, it can be difficult to tell where to insert Φ functions, and for which variables. This general question has an efficient solution that can be computed using a concept called dominance frontiers (see below).
Φ functions are not implemented as machine operations on most machines. A compiler can implement a Φ function by inserting "move" operations at the end of every predecessor block. In the example above, the compiler might insert a move from y1 to y3 at the end of the middle-left block and a move from y2 to y3 at the end of the middle-right block. These move operations might not end up in the final code based on the compiler's register allocation procedure. However, this approach may not work when simultaneous operations are speculatively producing inputs to a Φ function, as can happen on wide-issue machines. Typically, a wide-issue machine has a selection instruction used in such situations by the compiler to implement the Φ function.
Computing minimal SSA using dominance frontiers
In a control-flow graph, a node A is said to strictly dominate a different node B if it is impossible to reach B without passing through A first. In other words, if node B is reached, then it can be assumed that A has run. A is said to dominate B (or B to be dominated by A) if either A strictly dominates B or A = B.
A node which transfers control to a node A is called an immediate predecessor of A.
The dominance frontier of node A is the set of nodes B where A does not strictly dominate B, but does dominate some immediate predecessor of B. These are the points at which multiple control paths merge back together into a single path.
For example, in the following code:
[1] x = random()
if x < 0.5
[2] result = "heads"
else
[3] result = "tails"
end
[4] print(result)
Node 1 strictly dominates 2, 3, and 4 and the immediate predecessors of node 4 are nodes 2 and 3.
Dominance frontiers define the points at which Φ functions are needed. In the above example, when control is passed to node 4, the definition of result used depends on whether control was passed from node 2 or 3. Φ functions are not needed for variables defined in a dominator, as there is only one possible definition that can apply.
There is an efficient algorithm for finding dominance frontiers of each node. This algorithm was originally described in "Efficiently Computing Static Single Assignment Form and the Control Graph" by Ron Cytron, Jeanne Ferrante, et al. in 1991.[10]
Keith D. Cooper, Timothy J. Harvey, and Ken Kennedy of Rice University describe an algorithm in their paper titled A Simple, Fast Dominance Algorithm:[11]
for each node b
dominance_frontier(b) := {}
for each node b
if the number of immediate predecessors of b ≥ 2
for each p in immediate predecessors of b
runner := p
while runner ≠ idom(b)
dominance_frontier(runner) := dominance_frontier(runner) ∪ { b }
runner := idom(runner)
In the code above, idom(b) is the immediate dominator of b, the unique node that strictly dominates b but does not strictly dominate any other node that strictly dominates b.
Variations that reduce the number of Φ functions
"Minimal" SSA inserts the minimal number of Φ functions required to ensure that each name is assigned a value exactly once and that each reference (use) of a name in the original program can still refer to a unique name. (The latter requirement is needed to ensure that the compiler can write down a name for each operand in each operation.)
However, some of these Φ functions could be dead. For this reason, minimal SSA does not necessarily produce the fewest Φ functions that are needed by a specific procedure. For some types of analysis, these Φ functions are superfluous and can cause the analysis to run less efficiently.
Pruned SSA
Pruned SSA form is based on a simple observation: Φ functions are only needed for variables that are "live" after the Φ function. (Here, "live" means that the value is used along some path that begins at the Φ function in question.) If a variable is not live, the result of the Φ function cannot be used and the assignment by the Φ function is dead.
Construction of pruned SSA form uses live-variable information in the Φ function insertion phase to decide whether a given Φ function is needed. If the original variable name isn't live at the Φ function insertion point, the Φ function isn't inserted.
Another possibility is to treat pruning as a dead-code elimination problem. Then, a Φ function is live only if any use in the input program will be rewritten to it, or if it will be used as an argument in another Φ function. When entering SSA form, each use is rewritten to the nearest definition that dominates it. A Φ function will then be considered live as long as it is the nearest definition that dominates at least one use, or at least one argument of a live Φ.
Semi-pruned SSA
Semi-pruned SSA form[12] is an attempt to reduce the number of Φ functions without incurring the relatively high cost of computing live-variable information. It is based on the following observation: if a variable is never live upon entry into a basic block, it never needs a Φ function. During SSA construction, Φ functions for any "block-local" variables are omitted.
Computing the set of block-local variables is a simpler and faster procedure than full live-variable analysis, making semi-pruned SSA form more efficient to compute than pruned SSA form. On the other hand, semi-pruned SSA form will contain more Φ functions.
Block arguments
Block arguments are an alternative to Φ functions that is representationally identical but in practice can be more convenient during optimization. Blocks are named and take a list of block arguments, notated as function parameters. When calling a block the block arguments are bound to specified values. MLton, Swift SIL, and LLVM MLIR use block arguments.[13]
Converting out of SSA form
SSA form is not normally used for direct execution (although it is possible to interpret SSA[14]), and it is frequently used "on top of" another IR with which it remains in direct correspondence. This can be accomplished by "constructing" SSA as a set of functions that map between parts of the existing IR (basic blocks, instructions, operands, etc.) and its SSA counterpart. When the SSA form is no longer needed, these mapping functions may be discarded, leaving only the now-optimized IR.
Performing optimizations on SSA form usually leads to entangled SSA-Webs, meaning there are Φ instructions whose operands do not all have the same root operand. In such cases color-out algorithms are used to come out of SSA. Naive algorithms introduce a copy along each predecessor path that caused a source of different root symbol to be put in Φ than the destination of Φ. There are multiple algorithms for coming out of SSA with fewer copies, most use interference graphs or some approximation of it to do copy coalescing.[15]
Extensions
Extensions to SSA form can be divided into two categories.
Renaming scheme extensions alter the renaming criterion. Recall that SSA form renames each variable when it is assigned a value. Alternative schemes include static single use form (which renames each variable at each statement when it is used) and static single information form (which renames each variable when it is assigned a value, and at the post-dominance frontier).
Feature-specific extensions retain the single assignment property for variables, but incorporate new semantics to model additional features. Some feature-specific extensions model high-level programming language features like arrays, objects and aliased pointers. Other feature-specific extensions model low-level architectural features like speculation and predication.
Swift defines its own SSA form above LLVM IR, called SIL (Swift Intermediate Language).[18][19]
Erlang rewrote their compiler in OTP 22.0 to "internally use an intermediate representation based on Static Single Assignment (SSA)", with plans for further optimizations built on top of SSA in future releases.[20]
The LLVM Compiler Infrastructure uses SSA form for all scalar register values (everything except memory) in its primary code representation. SSA form is only eliminated once register allocation occurs, late in the compile process (often at link time).
The GNU Compiler Collection (GCC) makes extensive use of SSA since the version 4 (released in April 2005). The frontends generate "GENERIC" code that is then converted into "GIMPLE" code by the "gimplifier". High-level optimizations are then applied on the SSA form of "GIMPLE". The resulting optimized intermediate code is then translated into RTL, on which low-level optimizations are applied. The architecture-specific backends finally turn RTL into assembly language.
Go (1.7: for x86-64 architecture only; 1.8: for all supported architectures).[21][22]
IBM's open source adaptive Java virtual machine, Jikes RVM, uses extended Array SSA, an extension of SSA that allows analysis of scalars, arrays, and object fields in a unified framework. Extended Array SSA analysis is only enabled at the maximum optimization level, which is applied to the most frequently executed portions of code.
libFirm, a library for use as the middle and back ends of a compiler, uses SSA form for all scalar register values until code generation by use of an SSA-aware register allocator.[27]
Various Mesa drivers via NIR, an SSA representation for shading languages.[28]
The ETH Oberon-2 compiler was one of the first public projects to incorporate "GSA", a variant of SSA.
The Open64 compiler used SSA form in its global scalar optimizer, though the code is brought into SSA form before and taken out of SSA form afterwards. Open64 uses extensions to SSA form to represent memory in SSA form as well as scalar values.
In 2002, researchers modified IBM's JikesRVM (named Jalapeño at the time) to run both standard Java bytecode and a typesafe SSA (SafeTSA) bytecode class files, and demonstrated significant performance benefits to using the SSA bytecode.
jackcc is an open-source compiler for the academic instruction set Jackal 3.0. It uses a simple 3-operand code with SSA for its intermediate representation. As an interesting variant, it replaces Φ functions with a so-called SAME instruction, which instructs the register allocator to place the two live ranges into the same physical register.
The Illinois Concert Compiler circa 1994[34] used a variant of SSA called SSU (Static Single Use) which renames each variable when it is assigned a value, and in each conditional context in which that variable is used; essentially the static single information form mentioned above. The SSU form is documented in John Plevyak's Ph.D Thesis.
The COINS compiler uses SSA form optimizations as explained here.
Reservoir Labs' R-Stream compiler supports non-SSA (quad list), SSA and SSI (Static Single Information[35]) forms.[36]
Although not a compiler, the Boomerang decompiler uses SSA form in its internal representation. SSA is used to simplify expression propagation, identifying parameters and returns, preservation analysis, and more.
^Cytron, Ron; Lowry, Andy; Zadeck, F. Kenneth (1986). "Code motion of control structures in high-level languages". Proceedings of the 13th ACM SIGACT-SIGPLAN Symposium on Principles of Programming Languages - POPL '86: 70–85. doi:10.1145/512644.512651. S2CID9099471.
^Cytron, Ronald Kaplan; Ferrante, Jeanne. What's in a name? Or, the value of renaming for parallelism detection and storage allocation. International Conference on Parallel Processing, ICPP'87 1987. pp. 19–27.
^Barry Rosen; Mark N. Wegman; F. Kenneth Zadeck (1988). "Global value numbers and redundant computations"(PDF). Proceedings of the 15th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages.
^Alpern, B.; Wegman, M. N.; Zadeck, F. K. (1988). "Detecting equality of variables in programs". Proceedings of the 15th ACM SIGPLAN-SIGACT symposium on Principles of programming languages - POPL '88. pp. 1–11. doi:10.1145/73560.73561. ISBN0897912527. S2CID18384941.
^Cooper, Keith D.; Harvey, Timothy J.; Kennedy, Ken (2001). A Simple, Fast Dominance Algorithm(PDF) (Technical report). Rice University, CS Technical Report 06-33870. Archived from the original(PDF) on 2022-03-26.
For other uses, see Kuta (disambiguation). Place in Bali, IndonesiaKuta ᬓᬸᬢ (Balinese)Kuta BeachKutaLocation in Badung Regency and IndonesiaShow map of Badung RegencyKutaKuta (Indonesia)Show map of IndonesiaCoordinates: 8°44′S 115°10′E / 8.733°S 115.167°E / -8.733; 115.167CountryIndonesiaProvinceBaliRegencyBadungDistrictKuta Kuta is a tourist area, administratively an urban village (kelurahan), and the capital of Kuta District, Badung Regency, southe...
Оскар Багуї Особисті дані Народження 10 грудня 1982(1982-12-10) (40 років) Борбон, Еквадор Зріст 173 см Прізвисько Borbon Громадянство Еквадор Позиція захисник Інформація про клуб Поточний клуб «Емелек» Номер 23 Професіональні клуби* Роки Клуб І (г) 2001–2007 «Ольмедо» 176 (2) 2008–...
P. S. KrøyerPotret diri, 1897LahirPeder Severin Krøyer(1851-07-23)23 Juli 1851Stavanger, NorwegiaMeninggal21 November 1909(1909-11-21) (umur 58)Skagen, DenmarkKebangsaanDenmarkPendidikanAkademi Kesenian Kerajaan DenmarkDikenal atasMelukisGerakan politikImpresionisme Peder Severin Krøyer (23 Juli 1851 – 21 November 1909) adalah seorang pelukis asal Denmark. Ia lebih dikenal dengan sebutan P. S. Krøyer. Referensi KID Kunst Index Danmark (Art Index Denmark) Danish Biogra...
هذه المقالة يتيمة إذ تصل إليها مقالات أخرى قليلة جدًا. فضلًا، ساعد بإضافة وصلة إليها في مقالات متعلقة بها. (يوليو 2019) سوني كينغ معلومات شخصية الميلاد سنة 1940 (العمر 82–83 سنة) سيدني مواطنة أستراليا الحياة العملية المهنة فنان اللغات الإنجليزية تعديل مصدري - تعد
Selección de fútbol sub-20 de México Datos generalesPaís MéxicoCódigo FIFA MEXFederación Federación Mexicana de FútbolConfederación CONCACAFSeudónimo(s) El Tricolor, El TriSeleccionador TBAEquipaciones Primera Segunda Primer partido México 5:0 HaitíPanamá, Panamá — 5 de marzo de 1962Torneo Juvenil de la Concacaf 1962Mejor(es) resultado(s) México 16:0 Puerto Rico Toronto, Canadá — 17 de agosto de 1974Torneo Sub-20 de la Concacaf 1974Peor(es) resultado(s) Estados Unid...
Australian Open singles finalistsLocationMelbourne AustraliaCreated1969(55 finals, including 2023)Men's most10: Novak DjokovicMen's most consecutive3: Mats WilanderIvan LendlNovak DjokovicWomen's most8: Serena WilliamsWomen's most consecutive6: Evonne Goolagong CawleyMartina HingisMost meetingsMen's (4 times): Djokovic vs. Murray (4–0) Women's (3 times):Navratilova vs. Evert (2–1)Official website Main article: Australian Open The Australian Open is a Grand Slam tennis tournament held...
Mon Laferte discographyMon Laferte in 2020Studio albums8Singles41Promotional singles3 Chilean-Mexican singer Mon Laferte has released 8 studio albums, 32 singles and three promotional singles. In 2003, Laferte, then known as Monserrat Bustamante, released her first studio album, La Chica de Rojo. In 2007, Laferte decided to start a new chapter in her musical career by moving to Mexico City from Chile, recording an album in 2009, which was released two years later titled Desechable.[1]...
Die Kapelle auf dem Friedhof Die Friedhofskapelle (auch Gottesackerkapelle, Friedhofskirche) ist eine kleine evangelisch-lutherische Kapelle in Mönchsondheim. Sie bildet den Mittelpunkt des Friedhofs im Norden des Dorfes. Inhaltsverzeichnis 1 Geschichte 2 Architektur 3 Ausstattung 4 Literatur 5 Weblinks 6 Einzelnachweise Geschichte Die Errichtung der Kapelle und des sie umgebenden Friedhofs hängt eng mit dem Wachstum des Dorfes im Spätmittelalter zusammen. Bereits im 16. Jahrhundert verleg...
2006 studio album by Plastic LittleShe's MatureStudio album by Plastic LittleReleasedSeptember 19, 2006 [1]Recorded2006GenreRap, Underground rapLength73:51LabelTraffic Entertainment, TonearmProducerMichael SquidPlastic Little chronology She's Mature(2006) Welcome to the Jang House(2008) She's Mature is the debut studio album by the Philadelphian rap group, Plastic Little. The album was released on September 19, 2006 through Traffic Entertainment Group. The album contains many ...
Dit is een lijst van koningen van Koguryo. Koningen van Koguryo Koguryo Tongmyong Wang 37 v.Chr. - 19 v.Chr. Yuri(myong) Wang 19 v.Chr. - 18 AD Taemusin Wang 18 - 44 Minjung Wang 44 - 48 Mobon Wang 48 - 53 T'aejo Wang 53 - 146 Ch'adae Wang 146 - 165 Sindae Wang 165 - 179 Kogukch'on Wang 179 - 196 Sansang Wang 196 - 227 Tongch'on Wang 227 - 248 Chungch'on Wang 248 - 270 Soch'on Wang 270 - 292 Pongsang Wang 292 - 300 Mich'on Wang 300 - 331 Kogugwon Wang 331 - 371 Sosurim Wang 371 - 384 Kogugyan...
Jean-Philippe Rameau Les Paladins is an opera by Jean-Philippe Rameau first performed on 12 February 1760 at the Paris Opera. The author of the libretto is not known for sure but was probably one of the Duplat de Monticourt brothers. Rameau called Les Paladins a comédie lyrique, putting it in the same category as his earlier work Platée. Authorship of the libretto The identity of the librettist is uncertain. In the 18th century, Charles Collé relayed the rumour that the author was Gentil-B...
Dr. Ir. Hj. R. Sabrina, M.Si. (lahir 12 Mei 1961) merupakan seorang pensiunan birokrat yang pernah menjabat sebagai Sekretaris Daerah Provinsi Sumatera Utara dari 8 Juni 2018 sampai 1 Juni 2021. Beliau juga pernah menjabat sebagai Pelaksana Harian Gubernur Sumatera Utara menggantikan Tengku Erry Nuradi dikarenakan Masa Jabatanya Telah Berakhir Menjadi Gubernur Sumatera Utara. Beliau juga pernah sempat menjadi Plt. Bupati Labuhanbatu Selatan periode 2009-2011. Dan saat ini, beliau juga mengabd...
Harvard College Project for Asian and International RelationsAbbreviationHPAIRFormation1991TypeNon-profitPurposeInternational relations and global engagement with AsiaHeadquartersCambridge, MassachusettsOfficial language EnglishPresidentsJessica Chen, Ellen Fitzsimons, Kaitlyn ZhouParent organizationHarvard UniversityWebsitehttp://hpair.org/ The Harvard College Project for Asian and International Relations (HPAIR) is a student-led not-for-profit organization associated with the Harvard Univer...
Organizational structure A matrix organization Matrix management is an organizational structure in which some individuals report to more than one supervisor or leader–relationships described as solid line or dotted line reporting. More broadly, it may also describe the management of cross-functional, cross-business groups and other work models that do not maintain strict vertical business units or silos grouped by function and geography. Matrix management, developed in U.S. aerospace in the...
Soap opera character Priya KapoorNeighbours characterPortrayed byMenik GooneratneDuration2011–2013First appearance1 September 2011Last appearance10 June 2013ClassificationFormer; regularIntroduced bySusan BowerIn-universe informationOccupationPrincipal of Erinsborough HighHusbandAjay Kapoor (until 2013)DaughtersRani Kapoor Priya Kapoor is a fictional character from the Australian television soap opera Neighbours, played by Menik Gooneratne. The actress, who made a guest ...
Human settlement in EnglandWitton GilbertWitton GilbertLocation within County DurhamPopulation2,419 (2011)[1]OS grid referenceNZ235459Unitary authorityCounty DurhamCeremonial countyDurhamRegionNorth EastCountryEnglandSovereign stateUnited KingdomPost townDURHAMPostcode districtDH7Dialling code0191PoliceDurhamFireCounty Durham and DarlingtonAmbulanceNorth East UK ParliamentCity of Durham List of places UK England County Durham 54°48′29″...
Bangladeshi Association football club Football clubFortis FCFull nameFortis Football Club LimitedFounded2020; 3 years ago (2020)GroundMuktijuddho Sriti StadiumCapacity15,000OwnerFortis GroupPresidentShahin HasanHead CoachMasud Parvez KaisarLeagueBangladesh Premier League2023–24Premier League, 7th Home colours Away colours Current season Fortis Football Club (Bengali: ফর্টিস ফুটবল ক্লাব) is a Bangladeshi professional football club based in Ba...
Venezuelan cyclist In this Spanish name, the first or paternal surname is Guevara and the second or maternal family name is Reydtler. Manuel GuevaraPersonal informationFull nameManuel Enrique Guevara ReydtlerBorn (1969-07-15) 15 July 1969 (age 54)Villa de Cura, AraguaTeam informationCurrent teamRetiredDisciplineRoadRoleRiderAmateur teams2002–2005Lotería del Táchira2006–2007Gobernación Bolivariano Carabobo Manuel Enrique Guevara Reydtler (born July 15, 1969 in Vil...
Samoa-related events during 2023 ← 2022 2021 2020 2023 in Samoa → 2024 2025 2026 Decades: 2000s 2010s 2020s See also: Other events of 2023 Timeline of Samoan history Events in the year 2023 in Samoa. Incumbents O le Ao o le Malo: Tuimalealiʻifano Vaʻaletoʻa Sualauvi II Prime Minister: Fiamē Naomi Mataʻafa Events Ongoing – COVID-19 pandemic in Samoa 24 February – 2023 Vaimauga 3 by-election[1] 23 March – 2019 Samoa assassination plot: Two men are found guilty of ...
French actor You can help expand this article with text translated from the corresponding article in French. (January 2012) Click [show] for important translation instructions. View a machine-translated version of the French article. Machine translation, like DeepL or Google Translate, is a useful starting point for translations, but translators must revise errors as necessary and confirm that the translation is accurate, rather than simply copy-pasting machine-translated text into the E...