RX-Function-Attributes.html 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  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-2017 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 5.2, http://www.gnu.org/software/texinfo/ -->
  18. <head>
  19. <title>Using the GNU Compiler Collection (GCC): RX Function Attributes</title>
  20. <meta name="description" content="Using the GNU Compiler Collection (GCC): RX Function Attributes">
  21. <meta name="keywords" content="Using the GNU Compiler Collection (GCC): RX Function Attributes">
  22. <meta name="resource-type" content="document">
  23. <meta name="distribution" content="global">
  24. <meta name="Generator" content="makeinfo">
  25. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  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="Function-Attributes.html#Function-Attributes" rel="up" title="Function Attributes">
  30. <link href="S_002f390-Function-Attributes.html#S_002f390-Function-Attributes" rel="next" title="S/390 Function Attributes">
  31. <link href="RL78-Function-Attributes.html#RL78-Function-Attributes" rel="prev" title="RL78 Function Attributes">
  32. <style type="text/css">
  33. <!--
  34. a.summary-letter {text-decoration: none}
  35. blockquote.smallquotation {font-size: smaller}
  36. div.display {margin-left: 3.2em}
  37. div.example {margin-left: 3.2em}
  38. div.indentedblock {margin-left: 3.2em}
  39. div.lisp {margin-left: 3.2em}
  40. div.smalldisplay {margin-left: 3.2em}
  41. div.smallexample {margin-left: 3.2em}
  42. div.smallindentedblock {margin-left: 3.2em; font-size: smaller}
  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.nocodebreak {white-space:nowrap}
  54. span.nolinebreak {white-space:nowrap}
  55. span.roman {font-family:serif; font-weight:normal}
  56. span.sansserif {font-family:sans-serif; font-weight:normal}
  57. ul.no-bullet {list-style: none}
  58. -->
  59. </style>
  60. </head>
  61. <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
  62. <a name="RX-Function-Attributes"></a>
  63. <div class="header">
  64. <p>
  65. Next: <a href="S_002f390-Function-Attributes.html#S_002f390-Function-Attributes" accesskey="n" rel="next">S/390 Function Attributes</a>, Previous: <a href="RL78-Function-Attributes.html#RL78-Function-Attributes" accesskey="p" rel="prev">RL78 Function Attributes</a>, Up: <a href="Function-Attributes.html#Function-Attributes" accesskey="u" rel="up">Function Attributes</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>
  66. </div>
  67. <hr>
  68. <a name="RX-Function-Attributes-1"></a>
  69. <h4 class="subsection">6.31.25 RX Function Attributes</h4>
  70. <p>These function attributes are supported by the RX back end:
  71. </p>
  72. <dl compact="compact">
  73. <dt><code>fast_interrupt</code></dt>
  74. <dd><a name="index-fast_005finterrupt-function-attribute_002c-RX"></a>
  75. <p>Use this attribute on the RX port to indicate that the specified
  76. function is a fast interrupt handler. This is just like the
  77. <code>interrupt</code> attribute, except that <code>freit</code> is used to return
  78. instead of <code>reit</code>.
  79. </p>
  80. </dd>
  81. <dt><code>interrupt</code></dt>
  82. <dd><a name="index-interrupt-function-attribute_002c-RX"></a>
  83. <p>Use this attribute to indicate
  84. that the specified function is an interrupt handler. The compiler generates
  85. function entry and exit sequences suitable for use in an interrupt handler
  86. when this attribute is present.
  87. </p>
  88. <p>On RX targets, you may specify one or more vector numbers as arguments
  89. to the attribute, as well as naming an alternate table name.
  90. Parameters are handled sequentially, so one handler can be assigned to
  91. multiple entries in multiple tables. One may also pass the magic
  92. string <code>&quot;$default&quot;</code> which causes the function to be used for any
  93. unfilled slots in the current table.
  94. </p>
  95. <p>This example shows a simple assignment of a function to one vector in
  96. the default table (note that preprocessor macros may be used for
  97. chip-specific symbolic vector names):
  98. </p><div class="smallexample">
  99. <pre class="smallexample">void __attribute__ ((interrupt (5))) txd1_handler ();
  100. </pre></div>
  101. <p>This example assigns a function to two slots in the default table
  102. (using preprocessor macros defined elsewhere) and makes it the default
  103. for the <code>dct</code> table:
  104. </p><div class="smallexample">
  105. <pre class="smallexample">void __attribute__ ((interrupt (RXD1_VECT,RXD2_VECT,&quot;dct&quot;,&quot;$default&quot;)))
  106. txd1_handler ();
  107. </pre></div>
  108. </dd>
  109. <dt><code>naked</code></dt>
  110. <dd><a name="index-naked-function-attribute_002c-RX"></a>
  111. <p>This attribute allows the compiler to construct the
  112. requisite function declaration, while allowing the body of the
  113. function to be assembly code. The specified function will not have
  114. prologue/epilogue sequences generated by the compiler. Only basic
  115. <code>asm</code> statements can safely be included in naked functions
  116. (see <a href="Basic-Asm.html#Basic-Asm">Basic Asm</a>). While using extended <code>asm</code> or a mixture of
  117. basic <code>asm</code> and C code may appear to work, they cannot be
  118. depended upon to work reliably and are not supported.
  119. </p>
  120. </dd>
  121. <dt><code>vector</code></dt>
  122. <dd><a name="index-vector-function-attribute_002c-RX"></a>
  123. <p>This RX attribute is similar to the <code>interrupt</code> attribute, including its
  124. parameters, but does not make the function an interrupt-handler type
  125. function (i.e. it retains the normal C function calling ABI). See the
  126. <code>interrupt</code> attribute for a description of its arguments.
  127. </p></dd>
  128. </dl>
  129. <hr>
  130. <div class="header">
  131. <p>
  132. Next: <a href="S_002f390-Function-Attributes.html#S_002f390-Function-Attributes" accesskey="n" rel="next">S/390 Function Attributes</a>, Previous: <a href="RL78-Function-Attributes.html#RL78-Function-Attributes" accesskey="p" rel="prev">RL78 Function Attributes</a>, Up: <a href="Function-Attributes.html#Function-Attributes" accesskey="u" rel="up">Function Attributes</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>
  133. </div>
  134. </body>
  135. </html>