|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <!-- Copyright (C) 1988-2020 Free Software Foundation, Inc.
-
- Permission is granted to copy, distribute and/or modify this document
- under the terms of the GNU Free Documentation License, Version 1.3 or
- any later version published by the Free Software Foundation; with the
- Invariant Sections being "Funding Free Software", the Front-Cover
- Texts being (a) (see below), and with the Back-Cover Texts being (b)
- (see below). A copy of the license is included in the section entitled
- "GNU Free Documentation License".
-
- (a) The FSF's Front-Cover Text is:
-
- A GNU Manual
-
- (b) The FSF's Back-Cover Text is:
-
- You have freedom to copy and modify this GNU Manual, like GNU
- software. Copies published by the Free Software Foundation raise
- funds for GNU development. -->
- <!-- Created by GNU Texinfo 6.5, http://www.gnu.org/software/texinfo/ -->
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>Basic PowerPC Built-in Functions Available on ISA 3.0 (Using the GNU Compiler Collection (GCC))</title>
-
- <meta name="description" content="Basic PowerPC Built-in Functions Available on ISA 3.0 (Using the GNU Compiler Collection (GCC))">
- <meta name="keywords" content="Basic PowerPC Built-in Functions Available on ISA 3.0 (Using the GNU Compiler Collection (GCC))">
- <meta name="resource-type" content="document">
- <meta name="distribution" content="global">
- <meta name="Generator" content="makeinfo">
- <link href="index.html#Top" rel="start" title="Top">
- <link href="Option-Index.html#Option-Index" rel="index" title="Option Index">
- <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
- <link href="Basic-PowerPC-Built_002din-Functions.html#Basic-PowerPC-Built_002din-Functions" rel="up" title="Basic PowerPC Built-in Functions">
- <link href="PowerPC-AltiVec_002fVSX-Built_002din-Functions.html#PowerPC-AltiVec_002fVSX-Built_002din-Functions" rel="next" title="PowerPC AltiVec/VSX Built-in Functions">
- <link href="Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07.html#Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07" rel="prev" title="Basic PowerPC Built-in Functions Available on ISA 2.07">
- <style type="text/css">
- <!--
- a.summary-letter {text-decoration: none}
- blockquote.indentedblock {margin-right: 0em}
- blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
- blockquote.smallquotation {font-size: smaller}
- div.display {margin-left: 3.2em}
- div.example {margin-left: 3.2em}
- div.lisp {margin-left: 3.2em}
- div.smalldisplay {margin-left: 3.2em}
- div.smallexample {margin-left: 3.2em}
- div.smalllisp {margin-left: 3.2em}
- kbd {font-style: oblique}
- pre.display {font-family: inherit}
- pre.format {font-family: inherit}
- pre.menu-comment {font-family: serif}
- pre.menu-preformatted {font-family: serif}
- pre.smalldisplay {font-family: inherit; font-size: smaller}
- pre.smallexample {font-size: smaller}
- pre.smallformat {font-family: inherit; font-size: smaller}
- pre.smalllisp {font-size: smaller}
- span.nolinebreak {white-space: nowrap}
- span.roman {font-family: initial; font-weight: normal}
- span.sansserif {font-family: sans-serif; font-weight: normal}
- ul.no-bullet {list-style: none}
- -->
- </style>
-
-
- </head>
-
- <body lang="en">
- <a name="Basic-PowerPC-Built_002din-Functions-Available-on-ISA-3_002e0"></a>
- <div class="header">
- <p>
- Previous: <a href="Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07.html#Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07" accesskey="p" rel="prev">Basic PowerPC Built-in Functions Available on ISA 2.07</a>, Up: <a href="Basic-PowerPC-Built_002din-Functions.html#Basic-PowerPC-Built_002din-Functions" accesskey="u" rel="up">Basic PowerPC Built-in Functions</a> [<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>
- </div>
- <hr>
- <a name="Basic-PowerPC-Built_002din-Functions-Available-on-ISA-3_002e0-1"></a>
- <h4 class="subsubsection">6.60.22.5 Basic PowerPC Built-in Functions Available on ISA 3.0</h4>
-
- <p>The basic built-in functions described in this section are
- available on the PowerPC family of processors starting with ISA 3.0
- or later. Unless specific options are explicitly disabled on the
- command line, specifying option <samp>-mcpu=power9</samp> has the effect of
- enabling all the same options as for <samp>-mcpu=power8</samp> in
- addition to the <samp>-misel</samp> option.
- </p>
- <p>The following built-in functions are available on Linux 64-bit systems
- that use the ISA 3.0 instruction set (<samp>-mcpu=power9</samp>):
- </p>
- <dl compact="compact">
- <dt><code>__float128 __builtin_addf128_round_to_odd (__float128, __float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point add using round to odd as the
- rounding mode.
- <a name="index-_005f_005fbuiltin_005faddf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>__float128 __builtin_subf128_round_to_odd (__float128, __float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point subtract using round to odd as
- the rounding mode.
- <a name="index-_005f_005fbuiltin_005fsubf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>__float128 __builtin_mulf128_round_to_odd (__float128, __float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point multiply using round to odd as
- the rounding mode.
- <a name="index-_005f_005fbuiltin_005fmulf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>__float128 __builtin_divf128_round_to_odd (__float128, __float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point divide using round to odd as
- the rounding mode.
- <a name="index-_005f_005fbuiltin_005fdivf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>__float128 __builtin_sqrtf128_round_to_odd (__float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point square root using round to odd
- as the rounding mode.
- <a name="index-_005f_005fbuiltin_005fsqrtf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>__float128 __builtin_fmaf128_round_to_odd (__float128, __float128, __float128)</code></dt>
- <dd><p>Perform a 128-bit IEEE floating point fused multiply and add operation
- using round to odd as the rounding mode.
- <a name="index-_005f_005fbuiltin_005ffmaf128_005fround_005fto_005fodd"></a>
- </p>
- </dd>
- <dt><code>double __builtin_truncf128_round_to_odd (__float128)</code></dt>
- <dd><p>Convert a 128-bit IEEE floating point value to <code>double</code> using
- round to odd as the rounding mode.
- <a name="index-_005f_005fbuiltin_005ftruncf128_005fround_005fto_005fodd"></a>
- </p></dd>
- </dl>
-
- <p>The following additional built-in functions are also available for the
- PowerPC family of processors, starting with ISA 3.0 or later:
- </p><div class="smallexample">
- <pre class="smallexample">long long __builtin_darn (void);
- long long __builtin_darn_raw (void);
- int __builtin_darn_32 (void);
- </pre></div>
-
- <p>The <code>__builtin_darn</code> and <code>__builtin_darn_raw</code>
- functions require a
- 64-bit environment supporting ISA 3.0 or later.
- The <code>__builtin_darn</code> function provides a 64-bit conditioned
- random number. The <code>__builtin_darn_raw</code> function provides a
- 64-bit raw random number. The <code>__builtin_darn_32</code> function
- provides a 32-bit conditioned random number.
- </p>
- <p>The following additional built-in functions are also available for the
- PowerPC family of processors, starting with ISA 3.0 or later:
- </p>
- <div class="smallexample">
- <pre class="smallexample">int __builtin_byte_in_set (unsigned char u, unsigned long long set);
- int __builtin_byte_in_range (unsigned char u, unsigned int range);
- int __builtin_byte_in_either_range (unsigned char u, unsigned int ranges);
-
- int __builtin_dfp_dtstsfi_lt (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_lt (unsigned int comparison, _Decimal128 value);
- int __builtin_dfp_dtstsfi_lt_dd (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_lt_td (unsigned int comparison, _Decimal128 value);
-
- int __builtin_dfp_dtstsfi_gt (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_gt (unsigned int comparison, _Decimal128 value);
- int __builtin_dfp_dtstsfi_gt_dd (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_gt_td (unsigned int comparison, _Decimal128 value);
-
- int __builtin_dfp_dtstsfi_eq (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_eq (unsigned int comparison, _Decimal128 value);
- int __builtin_dfp_dtstsfi_eq_dd (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_eq_td (unsigned int comparison, _Decimal128 value);
-
- int __builtin_dfp_dtstsfi_ov (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_ov (unsigned int comparison, _Decimal128 value);
- int __builtin_dfp_dtstsfi_ov_dd (unsigned int comparison, _Decimal64 value);
- int __builtin_dfp_dtstsfi_ov_td (unsigned int comparison, _Decimal128 value);
-
- double __builtin_mffsl(void);
-
- </pre></div>
- <p>The <code>__builtin_byte_in_set</code> function requires a
- 64-bit environment supporting ISA 3.0 or later. This function returns
- a non-zero value if and only if its <code>u</code> argument exactly equals one of
- the eight bytes contained within its 64-bit <code>set</code> argument.
- </p>
- <p>The <code>__builtin_byte_in_range</code> and
- <code>__builtin_byte_in_either_range</code> require an environment
- supporting ISA 3.0 or later. For these two functions, the
- <code>range</code> argument is encoded as 4 bytes, organized as
- <code>hi_1:lo_1:hi_2:lo_2</code>.
- The <code>__builtin_byte_in_range</code> function returns a
- non-zero value if and only if its <code>u</code> argument is within the
- range bounded between <code>lo_2</code> and <code>hi_2</code> inclusive.
- The <code>__builtin_byte_in_either_range</code> function returns non-zero if
- and only if its <code>u</code> argument is within either the range bounded
- between <code>lo_1</code> and <code>hi_1</code> inclusive or the range bounded
- between <code>lo_2</code> and <code>hi_2</code> inclusive.
- </p>
- <p>The <code>__builtin_dfp_dtstsfi_lt</code> function returns a non-zero value
- if and only if the number of signficant digits of its <code>value</code> argument
- is less than its <code>comparison</code> argument. The
- <code>__builtin_dfp_dtstsfi_lt_dd</code> and
- <code>__builtin_dfp_dtstsfi_lt_td</code> functions behave similarly, but
- require that the type of the <code>value</code> argument be
- <code>__Decimal64</code> and <code>__Decimal128</code> respectively.
- </p>
- <p>The <code>__builtin_dfp_dtstsfi_gt</code> function returns a non-zero value
- if and only if the number of signficant digits of its <code>value</code> argument
- is greater than its <code>comparison</code> argument. The
- <code>__builtin_dfp_dtstsfi_gt_dd</code> and
- <code>__builtin_dfp_dtstsfi_gt_td</code> functions behave similarly, but
- require that the type of the <code>value</code> argument be
- <code>__Decimal64</code> and <code>__Decimal128</code> respectively.
- </p>
- <p>The <code>__builtin_dfp_dtstsfi_eq</code> function returns a non-zero value
- if and only if the number of signficant digits of its <code>value</code> argument
- equals its <code>comparison</code> argument. The
- <code>__builtin_dfp_dtstsfi_eq_dd</code> and
- <code>__builtin_dfp_dtstsfi_eq_td</code> functions behave similarly, but
- require that the type of the <code>value</code> argument be
- <code>__Decimal64</code> and <code>__Decimal128</code> respectively.
- </p>
- <p>The <code>__builtin_dfp_dtstsfi_ov</code> function returns a non-zero value
- if and only if its <code>value</code> argument has an undefined number of
- significant digits, such as when <code>value</code> is an encoding of <code>NaN</code>.
- The <code>__builtin_dfp_dtstsfi_ov_dd</code> and
- <code>__builtin_dfp_dtstsfi_ov_td</code> functions behave similarly, but
- require that the type of the <code>value</code> argument be
- <code>__Decimal64</code> and <code>__Decimal128</code> respectively.
- </p>
- <p>The <code>__builtin_mffsl</code> uses the ISA 3.0 <code>mffsl</code> instruction to read
- the FPSCR. The instruction is a lower latency version of the <code>mffs</code>
- instruction. If the <code>mffsl</code> instruction is not available, then the
- builtin uses the older <code>mffs</code> instruction to read the FPSCR.
- </p>
-
- <hr>
- <div class="header">
- <p>
- Previous: <a href="Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07.html#Basic-PowerPC-Built_002din-Functions-Available-on-ISA-2_002e07" accesskey="p" rel="prev">Basic PowerPC Built-in Functions Available on ISA 2.07</a>, Up: <a href="Basic-PowerPC-Built_002din-Functions.html#Basic-PowerPC-Built_002din-Functions" accesskey="u" rel="up">Basic PowerPC Built-in Functions</a> [<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>
- </div>
-
-
-
- </body>
- </html>
|