1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
<div class="subsubsection-level-extent" id="Basic-PowerPC-Built-in-Functions-Available-on-ISA-2_002e06"> <div class="nav-panel"> <p> Next: <a href="basic-powerpc-built-in-functions-available-on-isa-2_002e07" accesskey="n" rel="next">Basic PowerPC Built-in Functions Available on ISA 2.07</a>, Previous: <a href="basic-powerpc-built-in-functions-available-on-isa-2_002e05" accesskey="p" rel="prev">Basic PowerPC Built-in Functions Available on ISA 2.05</a>, Up: <a href="basic-powerpc-built-in-functions" accesskey="u" rel="up">Basic PowerPC Built-in Functions</a> [<a href="index#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="indices" title="Index" rel="index">Index</a>]</p> </div> <h1 class="subsubsection" id="Basic-PowerPC-Built-in-Functions-Available-on-ISA-2_002e06-1"><span>6.60.22.3 Basic PowerPC Built-in Functions Available on ISA 2.06<a class="copiable-link" href="#Basic-PowerPC-Built-in-Functions-Available-on-ISA-2_002e06-1"> ¶</a></span></h1> <p>The basic built-in functions described in this section are available on the PowerPC family of processors starting with ISA 2.05 or later. Unless specific options are explicitly disabled on the command line, specifying option <samp class="option">-mcpu=power7</samp> has the effect of enabling all the same options as for <samp class="option">-mcpu=power6</samp> in addition to the <samp class="option">-maltivec</samp>, <samp class="option">-mpopcntd</samp>, and <samp class="option">-mvsx</samp> options. </p> <p>The following basic built-in functions require <samp class="option">-mpopcntd</samp>: </p>
<div class="example smallexample"> <pre class="example-preformatted" data-language="cpp">unsigned int __builtin_addg6s (unsigned int, unsigned int);
long long __builtin_bpermd (long long, long long);
unsigned int __builtin_cbcdtd (unsigned int);
unsigned int __builtin_cdtbcd (unsigned int);
long long __builtin_divde (long long, long long);
unsigned long long __builtin_divdeu (unsigned long long, unsigned long long);
int __builtin_divwe (int, int);
unsigned int __builtin_divweu (unsigned int, unsigned int);
vector __int128 __builtin_pack_vector_int128 (long long, long long);
void __builtin_rs6000_speculation_barrier (void);
long long __builtin_unpack_vector_int128 (vector __int128, signed char);</pre>
</div> <p>Of these, the <code class="code">__builtin_divde</code> and <code class="code">__builtin_divdeu</code> functions require a 64-bit environment. </p> <p>The following basic built-in functions, which are also supported on x86 targets, require <samp class="option">-mfloat128</samp>. </p>
<div class="example smallexample"> <pre class="example-preformatted" data-language="cpp">__float128 __builtin_fabsq (__float128);
__float128 __builtin_copysignq (__float128, __float128);
__float128 __builtin_infq (void);
__float128 __builtin_huge_valq (void);
__float128 __builtin_nanq (void);
__float128 __builtin_nansq (void);
__float128 __builtin_sqrtf128 (__float128);
__float128 __builtin_fmaf128 (__float128, __float128, __float128);</pre>
</div> </div><div class="_attribution">
<p class="_attribution-p">
© Free Software Foundation<br>Licensed under the GNU Free Documentation License, Version 1.3.<br>
<a href="https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Basic-PowerPC-Built-in-Functions-Available-on-ISA-2_002e06.html" class="_attribution-link">https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Basic-PowerPC-Built-in-Functions-Available-on-ISA-2_002e06.html</a>
</p>
</div>
|