TILEPro-Syntax.html 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <!-- This file documents the GNU Assembler "as".
  4. Copyright (C) 1991-2017 Free Software Foundation, Inc.
  5. Permission is granted to copy, distribute and/or modify this document
  6. under the terms of the GNU Free Documentation License, Version 1.3
  7. or any later version published by the Free Software Foundation;
  8. with no Invariant Sections, with no Front-Cover Texts, and with no
  9. Back-Cover Texts. A copy of the license is included in the
  10. section entitled "GNU Free Documentation License".
  11. -->
  12. <!-- Created by GNU Texinfo 5.2, http://www.gnu.org/software/texinfo/ -->
  13. <head>
  14. <title>Using as: TILEPro Syntax</title>
  15. <meta name="description" content="Using as: TILEPro Syntax">
  16. <meta name="keywords" content="Using as: TILEPro Syntax">
  17. <meta name="resource-type" content="document">
  18. <meta name="distribution" content="global">
  19. <meta name="Generator" content="makeinfo">
  20. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  21. <link href="index.html#Top" rel="start" title="Top">
  22. <link href="AS-Index.html#AS-Index" rel="index" title="AS Index">
  23. <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
  24. <link href="TILEPro_002dDependent.html#TILEPro_002dDependent" rel="up" title="TILEPro-Dependent">
  25. <link href="TILEPro-Opcodes.html#TILEPro-Opcodes" rel="next" title="TILEPro Opcodes">
  26. <link href="TILEPro-Options.html#TILEPro-Options" rel="prev" title="TILEPro Options">
  27. <style type="text/css">
  28. <!--
  29. a.summary-letter {text-decoration: none}
  30. blockquote.smallquotation {font-size: smaller}
  31. div.display {margin-left: 3.2em}
  32. div.example {margin-left: 3.2em}
  33. div.indentedblock {margin-left: 3.2em}
  34. div.lisp {margin-left: 3.2em}
  35. div.smalldisplay {margin-left: 3.2em}
  36. div.smallexample {margin-left: 3.2em}
  37. div.smallindentedblock {margin-left: 3.2em; font-size: smaller}
  38. div.smalllisp {margin-left: 3.2em}
  39. kbd {font-style:oblique}
  40. pre.display {font-family: inherit}
  41. pre.format {font-family: inherit}
  42. pre.menu-comment {font-family: serif}
  43. pre.menu-preformatted {font-family: serif}
  44. pre.smalldisplay {font-family: inherit; font-size: smaller}
  45. pre.smallexample {font-size: smaller}
  46. pre.smallformat {font-family: inherit; font-size: smaller}
  47. pre.smalllisp {font-size: smaller}
  48. span.nocodebreak {white-space:nowrap}
  49. span.nolinebreak {white-space:nowrap}
  50. span.roman {font-family:serif; font-weight:normal}
  51. span.sansserif {font-family:sans-serif; font-weight:normal}
  52. ul.no-bullet {list-style: none}
  53. -->
  54. </style>
  55. </head>
  56. <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
  57. <a name="TILEPro-Syntax"></a>
  58. <div class="header">
  59. <p>
  60. Next: <a href="TILEPro-Directives.html#TILEPro-Directives" accesskey="n" rel="next">TILEPro Directives</a>, Previous: <a href="TILEPro-Options.html#TILEPro-Options" accesskey="p" rel="prev">TILEPro Options</a>, Up: <a href="TILEPro_002dDependent.html#TILEPro_002dDependent" accesskey="u" rel="up">TILEPro-Dependent</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="AS-Index.html#AS-Index" title="Index" rel="index">Index</a>]</p>
  61. </div>
  62. <hr>
  63. <a name="Syntax-27"></a>
  64. <h4 class="subsection">9.47.2 Syntax</h4>
  65. <a name="index-TILEPro-syntax"></a>
  66. <a name="index-syntax_002c-TILEPro"></a>
  67. <p>Block comments are delimited by &lsquo;<samp>/*</samp>&rsquo; and &lsquo;<samp>*/</samp>&rsquo;. End of line
  68. comments may be introduced by &lsquo;<samp>#</samp>&rsquo;.
  69. </p>
  70. <p>Instructions consist of a leading opcode or macro name followed by
  71. whitespace and an optional comma-separated list of operands:
  72. </p>
  73. <div class="smallexample">
  74. <pre class="smallexample"><var>opcode</var> [<var>operand</var>, &hellip;]
  75. </pre></div>
  76. <p>Instructions must be separated by a newline or semicolon.
  77. </p>
  78. <p>There are two ways to write code: either write naked instructions,
  79. which the assembler is free to combine into VLIW bundles, or specify
  80. the VLIW bundles explicitly.
  81. </p>
  82. <p>Bundles are specified using curly braces:
  83. </p>
  84. <div class="smallexample">
  85. <pre class="smallexample">{ <var>add</var> r3,r4,r5 ; <var>add</var> r7,r8,r9 ; <var>lw</var> r10,r11 }
  86. </pre></div>
  87. <p>A bundle can span multiple lines. If you want to put multiple
  88. instructions on a line, whether in a bundle or not, you need to
  89. separate them with semicolons as in this example.
  90. </p>
  91. <p>A bundle may contain one or more instructions, up to the limit
  92. specified by the ISA (currently three). If fewer instructions are
  93. specified than the hardware supports in a bundle, the assembler
  94. inserts <code>fnop</code> instructions automatically.
  95. </p>
  96. <p>The assembler will prefer to preserve the ordering of instructions
  97. within the bundle, putting the first instruction in a lower-numbered
  98. pipeline than the next one, etc. This fact, combined with the
  99. optional use of explicit <code>fnop</code> or <code>nop</code> instructions,
  100. allows precise control over which pipeline executes each instruction.
  101. </p>
  102. <p>If the instructions cannot be bundled in the listed order, the
  103. assembler will automatically try to find a valid pipeline
  104. assignment. If there is no way to bundle the instructions together,
  105. the assembler reports an error.
  106. </p>
  107. <p>The assembler does not yet auto-bundle (automatically combine multiple
  108. instructions into one bundle), but it reserves the right to do so in
  109. the future. If you want to force an instruction to run by itself, put
  110. it in a bundle explicitly with curly braces and use <code>nop</code>
  111. instructions (not <code>fnop</code>) to fill the remaining pipeline slots in
  112. that bundle.
  113. </p>
  114. <table class="menu" border="0" cellspacing="0">
  115. <tr><td align="left" valign="top">&bull; <a href="TILEPro-Opcodes.html#TILEPro-Opcodes" accesskey="1">TILEPro Opcodes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Opcode Naming Conventions.
  116. </td></tr>
  117. <tr><td align="left" valign="top">&bull; <a href="TILEPro-Registers.html#TILEPro-Registers" accesskey="2">TILEPro Registers</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Register Naming.
  118. </td></tr>
  119. <tr><td align="left" valign="top">&bull; <a href="TILEPro-Modifiers.html#TILEPro-Modifiers" accesskey="3">TILEPro Modifiers</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Symbolic Operand Modifiers.
  120. </td></tr>
  121. </table>
  122. <hr>
  123. <div class="header">
  124. <p>
  125. Next: <a href="TILEPro-Directives.html#TILEPro-Directives" accesskey="n" rel="next">TILEPro Directives</a>, Previous: <a href="TILEPro-Options.html#TILEPro-Options" accesskey="p" rel="prev">TILEPro Options</a>, Up: <a href="TILEPro_002dDependent.html#TILEPro_002dDependent" accesskey="u" rel="up">TILEPro-Dependent</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="AS-Index.html#AS-Index" title="Index" rel="index">Index</a>]</p>
  126. </div>
  127. </body>
  128. </html>