| 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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
 | <div class="subsection-level-extent" id="Adapteva-Epiphany-Options"> <div class="nav-panel"> <p> Next: <a href="amd-gcn-options" accesskey="n" rel="next">AMD GCN Options</a>, Previous: <a href="aarch64-options" accesskey="p" rel="prev">AArch64 Options</a>, Up: <a href="submodel-options" accesskey="u" rel="up">Machine-Dependent Options</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="subsection" id="Adapteva-Epiphany-Options-1"><span>3.19.2 Adapteva Epiphany Options<a class="copiable-link" href="#Adapteva-Epiphany-Options-1"> ¶</a></span></h1> <p>These ‘<samp class="samp">-m</samp>’ options are defined for Adapteva Epiphany: </p> <dl class="table"> <dt>
<span><code class="code">-mhalf-reg-file</code><a class="copiable-link" href="#index-mhalf-reg-file"> ¶</a></span>
</dt> <dd>
<p>Don’t allocate any register in the range <code class="code">r32</code>…<code class="code">r63</code>. That allows code to run on hardware variants that lack these registers. </p> </dd> <dt>
<span><code class="code">-mprefer-short-insn-regs</code><a class="copiable-link" href="#index-mprefer-short-insn-regs"> ¶</a></span>
</dt> <dd>
<p>Preferentially allocate registers that allow short instruction generation. This can result in increased instruction count, so this may either reduce or increase overall code size. </p> </dd> <dt>
<span><code class="code">-mbranch-cost=<var class="var">num</var></code><a class="copiable-link" href="#index-mbranch-cost"> ¶</a></span>
</dt> <dd>
<p>Set the cost of branches to roughly <var class="var">num</var> “simple” instructions. This cost is only a heuristic and is not guaranteed to produce consistent results across releases. </p> </dd> <dt>
<span><code class="code">-mcmove</code><a class="copiable-link" href="#index-mcmove"> ¶</a></span>
</dt> <dd>
<p>Enable the generation of conditional moves. </p> </dd> <dt>
<span><code class="code">-mnops=<var class="var">num</var></code><a class="copiable-link" href="#index-mnops"> ¶</a></span>
</dt> <dd>
<p>Emit <var class="var">num</var> NOPs before every other generated instruction. </p> </dd> <dt>
 <span><code class="code">-mno-soft-cmpsf</code><a class="copiable-link" href="#index-mno-soft-cmpsf"> ¶</a></span>
</dt> <dd>
<p>For single-precision floating-point comparisons, emit an <code class="code">fsub</code> instruction and test the flags. This is faster than a software comparison, but can get incorrect results in the presence of NaNs, or when two different small numbers are compared such that their difference is calculated as zero. The default is <samp class="option">-msoft-cmpsf</samp>, which uses slower, but IEEE-compliant, software comparisons. </p> </dd> <dt>
<span><code class="code">-mstack-offset=<var class="var">num</var></code><a class="copiable-link" href="#index-mstack-offset"> ¶</a></span>
</dt> <dd>
<p>Set the offset between the top of the stack and the stack pointer. E.g., a value of 8 means that the eight bytes in the range <code class="code">sp+0…sp+7</code> can be used by leaf functions without stack allocation. Values other than ‘<samp class="samp">8</samp>’ or ‘<samp class="samp">16</samp>’ are untested and unlikely to work. Note also that this option changes the ABI; compiling a program with a different stack offset than the libraries have been compiled with generally does not work. This option can be useful if you want to evaluate if a different stack offset would give you better code, but to actually use a different stack offset to build working programs, it is recommended to configure the toolchain with the appropriate <samp class="option">--with-stack-offset=<var class="var">num</var></samp> option. </p> </dd> <dt>
 <span><code class="code">-mno-round-nearest</code><a class="copiable-link" href="#index-mno-round-nearest"> ¶</a></span>
</dt> <dd>
<p>Make the scheduler assume that the rounding mode has been set to truncating. The default is <samp class="option">-mround-nearest</samp>. </p> </dd> <dt>
<span><code class="code">-mlong-calls</code><a class="copiable-link" href="#index-mlong-calls"> ¶</a></span>
</dt> <dd>
<p>If not otherwise specified by an attribute, assume all calls might be beyond the offset range of the <code class="code">b</code> / <code class="code">bl</code> instructions, and therefore load the function address into a register before performing a (otherwise direct) call. This is the default. </p> </dd> <dt>
<span><code class="code">-mshort-calls</code><a class="copiable-link" href="#index-short-calls"> ¶</a></span>
</dt> <dd>
<p>If not otherwise specified by an attribute, assume all direct calls are in the range of the <code class="code">b</code> / <code class="code">bl</code> instructions, so use these instructions for direct calls. The default is <samp class="option">-mlong-calls</samp>. </p> </dd> <dt>
<span><code class="code">-msmall16</code><a class="copiable-link" href="#index-msmall16"> ¶</a></span>
</dt> <dd>
<p>Assume addresses can be loaded as 16-bit unsigned values. This does not apply to function addresses for which <samp class="option">-mlong-calls</samp> semantics are in effect. </p> </dd> <dt>
<span><code class="code">-mfp-mode=<var class="var">mode</var></code><a class="copiable-link" href="#index-mfp-mode"> ¶</a></span>
</dt> <dd>
<p>Set the prevailing mode of the floating-point unit. This determines the floating-point mode that is provided and expected at function call and return time. Making this mode match the mode you predominantly need at function start can make your programs smaller and faster by avoiding unnecessary mode switches. </p> <p><var class="var">mode</var> can be set to one the following values: </p> <dl class="table"> <dt>‘<samp class="samp">caller</samp>’</dt> <dd>
<p>Any mode at function entry is valid, and retained or restored when the function returns, and when it calls other functions. This mode is useful for compiling libraries or other compilation units you might want to incorporate into different programs with different prevailing FPU modes, and the convenience of being able to use a single object file outweighs the size and speed overhead for any extra mode switching that might be needed, compared with what would be needed with a more specific choice of prevailing FPU mode. </p> </dd> <dt>‘<samp class="samp">truncate</samp>’</dt> <dd>
<p>This is the mode used for floating-point calculations with truncating (i.e. round towards zero) rounding mode. That includes conversion from floating point to integer. </p> </dd> <dt>‘<samp class="samp">round-nearest</samp>’</dt> <dd>
<p>This is the mode used for floating-point calculations with round-to-nearest-or-even rounding mode. </p> </dd> <dt>‘<samp class="samp">int</samp>’</dt> <dd><p>This is the mode used to perform integer calculations in the FPU, e.g. integer multiply, or integer multiply-and-accumulate. </p></dd> </dl> <p>The default is <samp class="option">-mfp-mode=caller</samp> </p> </dd> <dt>
     <span><code class="code">-mno-split-lohi</code><a class="copiable-link" href="#index-mno-split-lohi"> ¶</a></span>
</dt> <dt><code class="code">-mno-postinc</code></dt> <dt><code class="code">-mno-postmodify</code></dt> <dd>
<p>Code generation tweaks that disable, respectively, splitting of 32-bit loads, generation of post-increment addresses, and generation of post-modify addresses. The defaults are <samp class="option">msplit-lohi</samp>, <samp class="option">-mpost-inc</samp>, and <samp class="option">-mpost-modify</samp>. </p> </dd> <dt>
 <span><code class="code">-mnovect-double</code><a class="copiable-link" href="#index-mno-vect-double"> ¶</a></span>
</dt> <dd>
<p>Change the preferred SIMD mode to SImode. The default is <samp class="option">-mvect-double</samp>, which uses DImode as preferred SIMD mode. </p> </dd> <dt>
<span><code class="code">-max-vect-align=<var class="var">num</var></code><a class="copiable-link" href="#index-max-vect-align"> ¶</a></span>
</dt> <dd>
<p>The maximum alignment for SIMD vector mode types. <var class="var">num</var> may be 4 or 8. The default is 8. Note that this is an ABI change, even though many library function interfaces are unaffected if they don’t use SIMD vector modes in places that affect size and/or alignment of relevant types. </p> </dd> <dt>
<span><code class="code">-msplit-vecmove-early</code><a class="copiable-link" href="#index-msplit-vecmove-early"> ¶</a></span>
</dt> <dd>
<p>Split vector moves into single word moves before reload. In theory this can give better register allocation, but so far the reverse seems to be generally the case. </p> </dd> <dt>
<span><code class="code">-m1reg-<var class="var">reg</var></code><a class="copiable-link" href="#index-m1reg-"> ¶</a></span>
</dt> <dd>
<p>Specify a register to hold the constant −1, which makes loading small negative constants and certain bitmasks faster. Allowable values for <var class="var">reg</var> are ‘<samp class="samp">r43</samp>’ and ‘<samp class="samp">r63</samp>’, which specify use of that register as a fixed register, and ‘<samp class="samp">none</samp>’, which means that no register is used for this purpose. The default is <samp class="option">-m1reg-none</samp>. </p> </dd> </dl> </div>  <div class="nav-panel"> <p> Next: <a href="amd-gcn-options">AMD GCN Options</a>, Previous: <a href="aarch64-options">AArch64 Options</a>, Up: <a href="submodel-options">Machine-Dependent Options</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><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/Adapteva-Epiphany-Options.html" class="_attribution-link">https://gcc.gnu.org/onlinedocs/gcc-13.1.0/gcc/Adapteva-Epiphany-Options.html</a>
  </p>
</div>
 |