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.

100 lines
4.3KB

  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-2020 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 6.5, http://www.gnu.org/software/texinfo/ -->
  13. <head>
  14. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  15. <title>GNU Assembler (Using as)</title>
  16. <meta name="description" content="GNU Assembler (Using as)">
  17. <meta name="keywords" content="GNU Assembler (Using as)">
  18. <meta name="resource-type" content="document">
  19. <meta name="distribution" content="global">
  20. <meta name="Generator" content="makeinfo">
  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="Overview.html#Overview" rel="up" title="Overview">
  25. <link href="Object-Formats.html#Object-Formats" rel="next" title="Object Formats">
  26. <link href="Manual.html#Manual" rel="prev" title="Manual">
  27. <style type="text/css">
  28. <!--
  29. a.summary-letter {text-decoration: none}
  30. blockquote.indentedblock {margin-right: 0em}
  31. blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
  32. blockquote.smallquotation {font-size: smaller}
  33. div.display {margin-left: 3.2em}
  34. div.example {margin-left: 3.2em}
  35. div.lisp {margin-left: 3.2em}
  36. div.smalldisplay {margin-left: 3.2em}
  37. div.smallexample {margin-left: 3.2em}
  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.nolinebreak {white-space: nowrap}
  49. span.roman {font-family: initial; font-weight: normal}
  50. span.sansserif {font-family: sans-serif; font-weight: normal}
  51. ul.no-bullet {list-style: none}
  52. -->
  53. </style>
  54. </head>
  55. <body lang="en">
  56. <a name="GNU-Assembler"></a>
  57. <div class="header">
  58. <p>
  59. Next: <a href="Object-Formats.html#Object-Formats" accesskey="n" rel="next">Object Formats</a>, Previous: <a href="Manual.html#Manual" accesskey="p" rel="prev">Manual</a>, Up: <a href="Overview.html#Overview" accesskey="u" rel="up">Overview</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>
  60. </div>
  61. <hr>
  62. <a name="The-GNU-Assembler"></a>
  63. <h3 class="section">1.2 The GNU Assembler</h3>
  64. <p><small>GNU</small> <code>as</code> is really a family of assemblers.
  65. If you use (or have used) the <small>GNU</small> assembler on one architecture, you
  66. should find a fairly similar environment when you use it on another
  67. architecture. Each version has much in common with the others,
  68. including object file formats, most assembler directives (often called
  69. <em>pseudo-ops</em>) and assembler syntax.
  70. </p>
  71. <a name="index-purpose-of-GNU-assembler"></a>
  72. <p><code>as</code> is primarily intended to assemble the output of the
  73. <small>GNU</small> C compiler <code>gcc</code> for use by the linker
  74. <code>ld</code>. Nevertheless, we&rsquo;ve tried to make <code>as</code>
  75. assemble correctly everything that other assemblers for the same
  76. machine would assemble.
  77. Any exceptions are documented explicitly (see <a href="Machine-Dependencies.html#Machine-Dependencies">Machine Dependencies</a>).
  78. This doesn&rsquo;t mean <code>as</code> always uses the same syntax as another
  79. assembler for the same architecture; for example, we know of several
  80. incompatible versions of 680x0 assembly language syntax.
  81. </p>
  82. <p>Unlike older assemblers, <code>as</code> is designed to assemble a source
  83. program in one pass of the source file. This has a subtle impact on the
  84. <kbd>.org</kbd> directive (see <a href="Org.html#Org"><code>.org</code></a>).
  85. </p>
  86. </body>
  87. </html>