You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

128 line
6.3KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <!-- Copyright (C) 1988-2020 Free Software Foundation, Inc.
  4. Permission is granted to copy, distribute and/or modify this document
  5. under the terms of the GNU Free Documentation License, Version 1.3 or
  6. any later version published by the Free Software Foundation; with the
  7. Invariant Sections being "Funding Free Software", the Front-Cover
  8. Texts being (a) (see below), and with the Back-Cover Texts being (b)
  9. (see below). A copy of the license is included in the section entitled
  10. "GNU Free Documentation License".
  11. (a) The FSF's Front-Cover Text is:
  12. A GNU Manual
  13. (b) The FSF's Back-Cover Text is:
  14. You have freedom to copy and modify this GNU Manual, like GNU
  15. software. Copies published by the Free Software Foundation raise
  16. funds for GNU development. -->
  17. <!-- Created by GNU Texinfo 6.5, http://www.gnu.org/software/texinfo/ -->
  18. <head>
  19. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  20. <title>Tree SSA (GNU Compiler Collection (GCC) Internals)</title>
  21. <meta name="description" content="Tree SSA (GNU Compiler Collection (GCC) Internals)">
  22. <meta name="keywords" content="Tree SSA (GNU Compiler Collection (GCC) Internals)">
  23. <meta name="resource-type" content="document">
  24. <meta name="distribution" content="global">
  25. <meta name="Generator" content="makeinfo">
  26. <link href="index.html#Top" rel="start" title="Top">
  27. <link href="Option-Index.html#Option-Index" rel="index" title="Option Index">
  28. <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
  29. <link href="index.html#Top" rel="up" title="Top">
  30. <link href="Annotations.html#Annotations" rel="next" title="Annotations">
  31. <link href="Statement-and-operand-traversals.html#Statement-and-operand-traversals" rel="prev" title="Statement and operand traversals">
  32. <style type="text/css">
  33. <!--
  34. a.summary-letter {text-decoration: none}
  35. blockquote.indentedblock {margin-right: 0em}
  36. blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
  37. blockquote.smallquotation {font-size: smaller}
  38. div.display {margin-left: 3.2em}
  39. div.example {margin-left: 3.2em}
  40. div.lisp {margin-left: 3.2em}
  41. div.smalldisplay {margin-left: 3.2em}
  42. div.smallexample {margin-left: 3.2em}
  43. div.smalllisp {margin-left: 3.2em}
  44. kbd {font-style: oblique}
  45. pre.display {font-family: inherit}
  46. pre.format {font-family: inherit}
  47. pre.menu-comment {font-family: serif}
  48. pre.menu-preformatted {font-family: serif}
  49. pre.smalldisplay {font-family: inherit; font-size: smaller}
  50. pre.smallexample {font-size: smaller}
  51. pre.smallformat {font-family: inherit; font-size: smaller}
  52. pre.smalllisp {font-size: smaller}
  53. span.nolinebreak {white-space: nowrap}
  54. span.roman {font-family: initial; font-weight: normal}
  55. span.sansserif {font-family: sans-serif; font-weight: normal}
  56. ul.no-bullet {list-style: none}
  57. -->
  58. </style>
  59. </head>
  60. <body lang="en">
  61. <a name="Tree-SSA"></a>
  62. <div class="header">
  63. <p>
  64. Next: <a href="RTL.html#RTL" accesskey="n" rel="next">RTL</a>, Previous: <a href="GIMPLE.html#GIMPLE" accesskey="p" rel="prev">GIMPLE</a>, Up: <a href="index.html#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Option-Index.html#Option-Index" title="Index" rel="index">Index</a>]</p>
  65. </div>
  66. <hr>
  67. <a name="Analysis-and-Optimization-of-GIMPLE-tuples"></a>
  68. <h2 class="chapter">13 Analysis and Optimization of GIMPLE tuples</h2>
  69. <a name="index-Tree-SSA"></a>
  70. <a name="index-Optimization-infrastructure-for-GIMPLE"></a>
  71. <p>GCC uses three main intermediate languages to represent the program
  72. during compilation: GENERIC, GIMPLE and RTL. GENERIC is a
  73. language-independent representation generated by each front end. It
  74. is used to serve as an interface between the parser and optimizer.
  75. GENERIC is a common representation that is able to represent programs
  76. written in all the languages supported by GCC.
  77. </p>
  78. <p>GIMPLE and RTL are used to optimize the program. GIMPLE is used for
  79. target and language independent optimizations (e.g., inlining,
  80. constant propagation, tail call elimination, redundancy elimination,
  81. etc). Much like GENERIC, GIMPLE is a language independent, tree based
  82. representation. However, it differs from GENERIC in that the GIMPLE
  83. grammar is more restrictive: expressions contain no more than 3
  84. operands (except function calls), it has no control flow structures
  85. and expressions with side effects are only allowed on the right hand
  86. side of assignments. See the chapter describing GENERIC and GIMPLE
  87. for more details.
  88. </p>
  89. <p>This chapter describes the data structures and functions used in the
  90. GIMPLE optimizers (also known as &ldquo;tree optimizers&rdquo; or &ldquo;middle
  91. end&rdquo;). In particular, it focuses on all the macros, data structures,
  92. functions and programming constructs needed to implement optimization
  93. passes for GIMPLE.
  94. </p>
  95. <table class="menu" border="0" cellspacing="0">
  96. <tr><td align="left" valign="top">&bull; <a href="Annotations.html#Annotations" accesskey="1">Annotations</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Attributes for variables.
  97. </td></tr>
  98. <tr><td align="left" valign="top">&bull; <a href="SSA-Operands.html#SSA-Operands" accesskey="2">SSA Operands</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">SSA names referenced by GIMPLE statements.
  99. </td></tr>
  100. <tr><td align="left" valign="top">&bull; <a href="SSA.html#SSA" accesskey="3">SSA</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Static Single Assignment representation.
  101. </td></tr>
  102. <tr><td align="left" valign="top">&bull; <a href="Alias-analysis.html#Alias-analysis" accesskey="4">Alias analysis</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Representing aliased loads and stores.
  103. </td></tr>
  104. <tr><td align="left" valign="top">&bull; <a href="Memory-model.html#Memory-model" accesskey="5">Memory model</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Memory model used by the middle-end.
  105. </td></tr>
  106. </table>
  107. <hr>
  108. <div class="header">
  109. <p>
  110. Next: <a href="RTL.html#RTL" accesskey="n" rel="next">RTL</a>, Previous: <a href="GIMPLE.html#GIMPLE" accesskey="p" rel="prev">GIMPLE</a>, Up: <a href="index.html#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Option-Index.html#Option-Index" title="Index" rel="index">Index</a>]</p>
  111. </div>
  112. </body>
  113. </html>