Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.

Dependent-Patterns.html 5.1KB

3 år sedan
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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>Dependent Patterns (GNU Compiler Collection (GCC) Internals)</title>
  21. <meta name="description" content="Dependent Patterns (GNU Compiler Collection (GCC) Internals)">
  22. <meta name="keywords" content="Dependent Patterns (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="Machine-Desc.html#Machine-Desc" rel="up" title="Machine Desc">
  30. <link href="Jump-Patterns.html#Jump-Patterns" rel="next" title="Jump Patterns">
  31. <link href="Pattern-Ordering.html#Pattern-Ordering" rel="prev" title="Pattern Ordering">
  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="Dependent-Patterns"></a>
  62. <div class="header">
  63. <p>
  64. Next: <a href="Jump-Patterns.html#Jump-Patterns" accesskey="n" rel="next">Jump Patterns</a>, Previous: <a href="Pattern-Ordering.html#Pattern-Ordering" accesskey="p" rel="prev">Pattern Ordering</a>, Up: <a href="Machine-Desc.html#Machine-Desc" accesskey="u" rel="up">Machine Desc</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="Interdependence-of-Patterns"></a>
  68. <h3 class="section">17.11 Interdependence of Patterns</h3>
  69. <a name="index-Dependent-Patterns"></a>
  70. <a name="index-Interdependence-of-Patterns"></a>
  71. <p>In some cases machines support instructions identical except for the
  72. machine mode of one or more operands. For example, there may be
  73. &ldquo;sign-extend halfword&rdquo; and &ldquo;sign-extend byte&rdquo; instructions whose
  74. patterns are
  75. </p>
  76. <div class="smallexample">
  77. <pre class="smallexample">(set (match_operand:SI 0 &hellip;)
  78. (extend:SI (match_operand:HI 1 &hellip;)))
  79. (set (match_operand:SI 0 &hellip;)
  80. (extend:SI (match_operand:QI 1 &hellip;)))
  81. </pre></div>
  82. <p>Constant integers do not specify a machine mode, so an instruction to
  83. extend a constant value could match either pattern. The pattern it
  84. actually will match is the one that appears first in the file. For correct
  85. results, this must be the one for the widest possible mode (<code>HImode</code>,
  86. here). If the pattern matches the <code>QImode</code> instruction, the results
  87. will be incorrect if the constant value does not actually fit that mode.
  88. </p>
  89. <p>Such instructions to extend constants are rarely generated because they are
  90. optimized away, but they do occasionally happen in nonoptimized
  91. compilations.
  92. </p>
  93. <p>If a constraint in a pattern allows a constant, the reload pass may
  94. replace a register with a constant permitted by the constraint in some
  95. cases. Similarly for memory references. Because of this substitution,
  96. you should not provide separate patterns for increment and decrement
  97. instructions. Instead, they should be generated from the same pattern
  98. that supports register-register add insns by examining the operands and
  99. generating the appropriate machine instruction.
  100. </p>
  101. </body>
  102. </html>