| <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> |
| <html> |
| <!-- Copyright (C) 1988-2015 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 5.2, http://www.gnu.org/software/texinfo/ --> |
| <head> |
| <title>Using the GNU Compiler Collection (GCC): ARM Options</title> |
| |
| <meta name="description" content="Using the GNU Compiler Collection (GCC): ARM Options"> |
| <meta name="keywords" content="Using the GNU Compiler Collection (GCC): ARM Options"> |
| <meta name="resource-type" content="document"> |
| <meta name="distribution" content="global"> |
| <meta name="Generator" content="makeinfo"> |
| <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> |
| <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="Submodel-Options.html#Submodel-Options" rel="up" title="Submodel Options"> |
| <link href="AVR-Options.html#AVR-Options" rel="next" title="AVR Options"> |
| <link href="ARC-Options.html#ARC-Options" rel="prev" title="ARC Options"> |
| <style type="text/css"> |
| <!-- |
| a.summary-letter {text-decoration: none} |
| blockquote.smallquotation {font-size: smaller} |
| div.display {margin-left: 3.2em} |
| div.example {margin-left: 3.2em} |
| div.indentedblock {margin-left: 3.2em} |
| div.lisp {margin-left: 3.2em} |
| div.smalldisplay {margin-left: 3.2em} |
| div.smallexample {margin-left: 3.2em} |
| div.smallindentedblock {margin-left: 3.2em; font-size: smaller} |
| 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.nocodebreak {white-space:nowrap} |
| span.nolinebreak {white-space:nowrap} |
| span.roman {font-family:serif; font-weight:normal} |
| span.sansserif {font-family:sans-serif; font-weight:normal} |
| ul.no-bullet {list-style: none} |
| --> |
| </style> |
| |
| |
| </head> |
| |
| <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000"> |
| <a name="ARM-Options"></a> |
| <div class="header"> |
| <p> |
| Next: <a href="AVR-Options.html#AVR-Options" accesskey="n" rel="next">AVR Options</a>, Previous: <a href="ARC-Options.html#ARC-Options" accesskey="p" rel="prev">ARC Options</a>, Up: <a href="Submodel-Options.html#Submodel-Options" accesskey="u" rel="up">Submodel Options</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="ARM-Options-1"></a> |
| <h4 class="subsection">3.17.4 ARM Options</h4> |
| <a name="index-ARM-options"></a> |
| |
| <p>These ‘<samp>-m</samp>’ options are defined for the ARM port: |
| </p> |
| <dl compact="compact"> |
| <dt><code>-mabi=<var>name</var></code></dt> |
| <dd><a name="index-mabi-1"></a> |
| <p>Generate code for the specified ABI. Permissible values are: ‘<samp>apcs-gnu</samp>’, |
| ‘<samp>atpcs</samp>’, ‘<samp>aapcs</samp>’, ‘<samp>aapcs-linux</samp>’ and ‘<samp>iwmmxt</samp>’. |
| </p> |
| </dd> |
| <dt><code>-mapcs-frame</code></dt> |
| <dd><a name="index-mapcs_002dframe"></a> |
| <p>Generate a stack frame that is compliant with the ARM Procedure Call |
| Standard for all functions, even if this is not strictly necessary for |
| correct execution of the code. Specifying <samp>-fomit-frame-pointer</samp> |
| with this option causes the stack frames not to be generated for |
| leaf functions. The default is <samp>-mno-apcs-frame</samp>. |
| </p> |
| </dd> |
| <dt><code>-mapcs</code></dt> |
| <dd><a name="index-mapcs"></a> |
| <p>This is a synonym for <samp>-mapcs-frame</samp>. |
| </p> |
| |
| </dd> |
| <dt><code>-mthumb-interwork</code></dt> |
| <dd><a name="index-mthumb_002dinterwork"></a> |
| <p>Generate code that supports calling between the ARM and Thumb |
| instruction sets. Without this option, on pre-v5 architectures, the |
| two instruction sets cannot be reliably used inside one program. The |
| default is <samp>-mno-thumb-interwork</samp>, since slightly larger code |
| is generated when <samp>-mthumb-interwork</samp> is specified. In AAPCS |
| configurations this option is meaningless. |
| </p> |
| </dd> |
| <dt><code>-mno-sched-prolog</code></dt> |
| <dd><a name="index-mno_002dsched_002dprolog"></a> |
| <p>Prevent the reordering of instructions in the function prologue, or the |
| merging of those instruction with the instructions in the function’s |
| body. This means that all functions start with a recognizable set |
| of instructions (or in fact one of a choice from a small set of |
| different function prologues), and this information can be used to |
| locate the start of functions inside an executable piece of code. The |
| default is <samp>-msched-prolog</samp>. |
| </p> |
| </dd> |
| <dt><code>-mfloat-abi=<var>name</var></code></dt> |
| <dd><a name="index-mfloat_002dabi"></a> |
| <p>Specifies which floating-point ABI to use. Permissible values |
| are: ‘<samp>soft</samp>’, ‘<samp>softfp</samp>’ and ‘<samp>hard</samp>’. |
| </p> |
| <p>Specifying ‘<samp>soft</samp>’ causes GCC to generate output containing |
| library calls for floating-point operations. |
| ‘<samp>softfp</samp>’ allows the generation of code using hardware floating-point |
| instructions, but still uses the soft-float calling conventions. |
| ‘<samp>hard</samp>’ allows generation of floating-point instructions |
| and uses FPU-specific calling conventions. |
| </p> |
| <p>The default depends on the specific target configuration. Note that |
| the hard-float and soft-float ABIs are not link-compatible; you must |
| compile your entire program with the same ABI, and link with a |
| compatible set of libraries. |
| </p> |
| </dd> |
| <dt><code>-mlittle-endian</code></dt> |
| <dd><a name="index-mlittle_002dendian-2"></a> |
| <p>Generate code for a processor running in little-endian mode. This is |
| the default for all standard configurations. |
| </p> |
| </dd> |
| <dt><code>-mbig-endian</code></dt> |
| <dd><a name="index-mbig_002dendian-2"></a> |
| <p>Generate code for a processor running in big-endian mode; the default is |
| to compile code for a little-endian processor. |
| </p> |
| </dd> |
| <dt><code>-mwords-little-endian</code></dt> |
| <dd><a name="index-mwords_002dlittle_002dendian"></a> |
| <p>This option only applies when generating code for big-endian processors. |
| Generate code for a little-endian word order but a big-endian byte |
| order. That is, a byte order of the form ‘<samp>32107654</samp>’. Note: this |
| option should only be used if you require compatibility with code for |
| big-endian ARM processors generated by versions of the compiler prior to |
| 2.8. This option is now deprecated. |
| </p> |
| </dd> |
| <dt><code>-march=<var>name</var></code></dt> |
| <dd><a name="index-march-1"></a> |
| <p>This specifies the name of the target ARM architecture. GCC uses this |
| name to determine what kind of instructions it can emit when generating |
| assembly code. This option can be used in conjunction with or instead |
| of the <samp>-mcpu=</samp> option. Permissible names are: ‘<samp>armv2</samp>’, |
| ‘<samp>armv2a</samp>’, ‘<samp>armv3</samp>’, ‘<samp>armv3m</samp>’, ‘<samp>armv4</samp>’, ‘<samp>armv4t</samp>’, |
| ‘<samp>armv5</samp>’, ‘<samp>armv5t</samp>’, ‘<samp>armv5e</samp>’, ‘<samp>armv5te</samp>’, |
| ‘<samp>armv6</samp>’, ‘<samp>armv6j</samp>’, |
| ‘<samp>armv6t2</samp>’, ‘<samp>armv6z</samp>’, ‘<samp>armv6zk</samp>’, ‘<samp>armv6-m</samp>’, |
| ‘<samp>armv7</samp>’, ‘<samp>armv7-a</samp>’, ‘<samp>armv7-r</samp>’, ‘<samp>armv7-m</samp>’, ‘<samp>armv7e-m</samp>’, |
| ‘<samp>armv7ve</samp>’, ‘<samp>armv8-a</samp>’, ‘<samp>armv8-a+crc</samp>’, |
| ‘<samp>iwmmxt</samp>’, ‘<samp>iwmmxt2</samp>’, ‘<samp>ep9312</samp>’. |
| </p> |
| <p><samp>-march=armv7ve</samp> is the armv7-a architecture with virtualization |
| extensions. |
| </p> |
| <p><samp>-march=armv8-a+crc</samp> enables code generation for the ARMv8-A |
| architecture together with the optional CRC32 extensions. |
| </p> |
| <p><samp>-march=native</samp> causes the compiler to auto-detect the architecture |
| of the build computer. At present, this feature is only supported on |
| GNU/Linux, and not all architectures are recognized. If the auto-detect |
| is unsuccessful the option has no effect. |
| </p> |
| </dd> |
| <dt><code>-mtune=<var>name</var></code></dt> |
| <dd><a name="index-mtune-3"></a> |
| <p>This option specifies the name of the target ARM processor for |
| which GCC should tune the performance of the code. |
| For some ARM implementations better performance can be obtained by using |
| this option. |
| Permissible names are: ‘<samp>arm2</samp>’, ‘<samp>arm250</samp>’, |
| ‘<samp>arm3</samp>’, ‘<samp>arm6</samp>’, ‘<samp>arm60</samp>’, ‘<samp>arm600</samp>’, ‘<samp>arm610</samp>’, |
| ‘<samp>arm620</samp>’, ‘<samp>arm7</samp>’, ‘<samp>arm7m</samp>’, ‘<samp>arm7d</samp>’, ‘<samp>arm7dm</samp>’, |
| ‘<samp>arm7di</samp>’, ‘<samp>arm7dmi</samp>’, ‘<samp>arm70</samp>’, ‘<samp>arm700</samp>’, |
| ‘<samp>arm700i</samp>’, ‘<samp>arm710</samp>’, ‘<samp>arm710c</samp>’, ‘<samp>arm7100</samp>’, |
| ‘<samp>arm720</samp>’, |
| ‘<samp>arm7500</samp>’, ‘<samp>arm7500fe</samp>’, ‘<samp>arm7tdmi</samp>’, ‘<samp>arm7tdmi-s</samp>’, |
| ‘<samp>arm710t</samp>’, ‘<samp>arm720t</samp>’, ‘<samp>arm740t</samp>’, |
| ‘<samp>strongarm</samp>’, ‘<samp>strongarm110</samp>’, ‘<samp>strongarm1100</samp>’, |
| ‘<samp>strongarm1110</samp>’, |
| ‘<samp>arm8</samp>’, ‘<samp>arm810</samp>’, ‘<samp>arm9</samp>’, ‘<samp>arm9e</samp>’, ‘<samp>arm920</samp>’, |
| ‘<samp>arm920t</samp>’, ‘<samp>arm922t</samp>’, ‘<samp>arm946e-s</samp>’, ‘<samp>arm966e-s</samp>’, |
| ‘<samp>arm968e-s</samp>’, ‘<samp>arm926ej-s</samp>’, ‘<samp>arm940t</samp>’, ‘<samp>arm9tdmi</samp>’, |
| ‘<samp>arm10tdmi</samp>’, ‘<samp>arm1020t</samp>’, ‘<samp>arm1026ej-s</samp>’, |
| ‘<samp>arm10e</samp>’, ‘<samp>arm1020e</samp>’, ‘<samp>arm1022e</samp>’, |
| ‘<samp>arm1136j-s</samp>’, ‘<samp>arm1136jf-s</samp>’, ‘<samp>mpcore</samp>’, ‘<samp>mpcorenovfp</samp>’, |
| ‘<samp>arm1156t2-s</samp>’, ‘<samp>arm1156t2f-s</samp>’, ‘<samp>arm1176jz-s</samp>’, ‘<samp>arm1176jzf-s</samp>’, |
| ‘<samp>cortex-a5</samp>’, ‘<samp>cortex-a7</samp>’, ‘<samp>cortex-a8</samp>’, ‘<samp>cortex-a9</samp>’, |
| ‘<samp>cortex-a12</samp>’, ‘<samp>cortex-a15</samp>’, ‘<samp>cortex-a53</samp>’, |
| ‘<samp>cortex-a57</samp>’, ‘<samp>cortex-a72</samp>’, |
| ‘<samp>cortex-r4</samp>’, |
| ‘<samp>cortex-r4f</samp>’, ‘<samp>cortex-r5</samp>’, ‘<samp>cortex-r7</samp>’, ‘<samp>cortex-m7</samp>’, |
| ‘<samp>cortex-m4</samp>’, |
| ‘<samp>cortex-m3</samp>’, |
| ‘<samp>cortex-m1</samp>’, |
| ‘<samp>cortex-m0</samp>’, |
| ‘<samp>cortex-m0plus</samp>’, |
| ‘<samp>cortex-m1.small-multiply</samp>’, |
| ‘<samp>cortex-m0.small-multiply</samp>’, |
| ‘<samp>cortex-m0plus.small-multiply</samp>’, |
| ‘<samp>marvell-pj4</samp>’, |
| ‘<samp>xscale</samp>’, ‘<samp>iwmmxt</samp>’, ‘<samp>iwmmxt2</samp>’, ‘<samp>ep9312</samp>’, |
| ‘<samp>fa526</samp>’, ‘<samp>fa626</samp>’, |
| ‘<samp>fa606te</samp>’, ‘<samp>fa626te</samp>’, ‘<samp>fmp626</samp>’, ‘<samp>fa726te</samp>’, |
| ‘<samp>xgene1</samp>’. |
| </p> |
| <p>Additionally, this option can specify that GCC should tune the performance |
| of the code for a big.LITTLE system. Permissible names are: |
| ‘<samp>cortex-a15.cortex-a7</samp>’, ‘<samp>cortex-a57.cortex-a53</samp>’, |
| ‘<samp>cortex-a72.cortex-a53</samp>’. |
| </p> |
| <p><samp>-mtune=generic-<var>arch</var></samp> specifies that GCC should tune the |
| performance for a blend of processors within architecture <var>arch</var>. |
| The aim is to generate code that run well on the current most popular |
| processors, balancing between optimizations that benefit some CPUs in the |
| range, and avoiding performance pitfalls of other CPUs. The effects of |
| this option may change in future GCC versions as CPU models come and go. |
| </p> |
| <p><samp>-mtune=native</samp> causes the compiler to auto-detect the CPU |
| of the build computer. At present, this feature is only supported on |
| GNU/Linux, and not all architectures are recognized. If the auto-detect is |
| unsuccessful the option has no effect. |
| </p> |
| </dd> |
| <dt><code>-mcpu=<var>name</var></code></dt> |
| <dd><a name="index-mcpu-2"></a> |
| <p>This specifies the name of the target ARM processor. GCC uses this name |
| to derive the name of the target ARM architecture (as if specified |
| by <samp>-march</samp>) and the ARM processor type for which to tune for |
| performance (as if specified by <samp>-mtune</samp>). Where this option |
| is used in conjunction with <samp>-march</samp> or <samp>-mtune</samp>, |
| those options take precedence over the appropriate part of this option. |
| </p> |
| <p>Permissible names for this option are the same as those for |
| <samp>-mtune</samp>. |
| </p> |
| <p><samp>-mcpu=generic-<var>arch</var></samp> is also permissible, and is |
| equivalent to <samp>-march=<var>arch</var> -mtune=generic-<var>arch</var></samp>. |
| See <samp>-mtune</samp> for more information. |
| </p> |
| <p><samp>-mcpu=native</samp> causes the compiler to auto-detect the CPU |
| of the build computer. At present, this feature is only supported on |
| GNU/Linux, and not all architectures are recognized. If the auto-detect |
| is unsuccessful the option has no effect. |
| </p> |
| </dd> |
| <dt><code>-mfpu=<var>name</var></code></dt> |
| <dd><a name="index-mfpu"></a> |
| <p>This specifies what floating-point hardware (or hardware emulation) is |
| available on the target. Permissible names are: ‘<samp>vfp</samp>’, ‘<samp>vfpv3</samp>’, |
| ‘<samp>vfpv3-fp16</samp>’, ‘<samp>vfpv3-d16</samp>’, ‘<samp>vfpv3-d16-fp16</samp>’, ‘<samp>vfpv3xd</samp>’, |
| ‘<samp>vfpv3xd-fp16</samp>’, ‘<samp>neon</samp>’, ‘<samp>neon-fp16</samp>’, ‘<samp>vfpv4</samp>’, |
| ‘<samp>vfpv4-d16</samp>’, ‘<samp>fpv4-sp-d16</samp>’, ‘<samp>neon-vfpv4</samp>’, |
| ‘<samp>fpv5-d16</samp>’, ‘<samp>fpv5-sp-d16</samp>’, |
| ‘<samp>fp-armv8</samp>’, ‘<samp>neon-fp-armv8</samp>’, and ‘<samp>crypto-neon-fp-armv8</samp>’. |
| </p> |
| <p>If <samp>-msoft-float</samp> is specified this specifies the format of |
| floating-point values. |
| </p> |
| <p>If the selected floating-point hardware includes the NEON extension |
| (e.g. <samp>-mfpu</samp>=‘<samp>neon</samp>’), note that floating-point |
| operations are not generated by GCC’s auto-vectorization pass unless |
| <samp>-funsafe-math-optimizations</samp> is also specified. This is |
| because NEON hardware does not fully implement the IEEE 754 standard for |
| floating-point arithmetic (in particular denormal values are treated as |
| zero), so the use of NEON instructions may lead to a loss of precision. |
| </p> |
| </dd> |
| <dt><code>-mfp16-format=<var>name</var></code></dt> |
| <dd><a name="index-mfp16_002dformat"></a> |
| <p>Specify the format of the <code>__fp16</code> half-precision floating-point type. |
| Permissible names are ‘<samp>none</samp>’, ‘<samp>ieee</samp>’, and ‘<samp>alternative</samp>’; |
| the default is ‘<samp>none</samp>’, in which case the <code>__fp16</code> type is not |
| defined. See <a href="Half_002dPrecision.html#Half_002dPrecision">Half-Precision</a>, for more information. |
| </p> |
| </dd> |
| <dt><code>-mstructure-size-boundary=<var>n</var></code></dt> |
| <dd><a name="index-mstructure_002dsize_002dboundary"></a> |
| <p>The sizes of all structures and unions are rounded up to a multiple |
| of the number of bits set by this option. Permissible values are 8, 32 |
| and 64. The default value varies for different toolchains. For the COFF |
| targeted toolchain the default value is 8. A value of 64 is only allowed |
| if the underlying ABI supports it. |
| </p> |
| <p>Specifying a larger number can produce faster, more efficient code, but |
| can also increase the size of the program. Different values are potentially |
| incompatible. Code compiled with one value cannot necessarily expect to |
| work with code or libraries compiled with another value, if they exchange |
| information using structures or unions. |
| </p> |
| </dd> |
| <dt><code>-mabort-on-noreturn</code></dt> |
| <dd><a name="index-mabort_002don_002dnoreturn"></a> |
| <p>Generate a call to the function <code>abort</code> at the end of a |
| <code>noreturn</code> function. It is executed if the function tries to |
| return. |
| </p> |
| </dd> |
| <dt><code>-mlong-calls</code></dt> |
| <dt><code>-mno-long-calls</code></dt> |
| <dd><a name="index-mlong_002dcalls-2"></a> |
| <a name="index-mno_002dlong_002dcalls"></a> |
| <p>Tells the compiler to perform function calls by first loading the |
| address of the function into a register and then performing a subroutine |
| call on this register. This switch is needed if the target function |
| lies outside of the 64-megabyte addressing range of the offset-based |
| version of subroutine call instruction. |
| </p> |
| <p>Even if this switch is enabled, not all function calls are turned |
| into long calls. The heuristic is that static functions, functions |
| that have the ‘<samp>short-call</samp>’ attribute, functions that are inside |
| the scope of a ‘<samp>#pragma no_long_calls</samp>’ directive, and functions whose |
| definitions have already been compiled within the current compilation |
| unit are not turned into long calls. The exceptions to this rule are |
| that weak function definitions, functions with the ‘<samp>long-call</samp>’ |
| attribute or the ‘<samp>section</samp>’ attribute, and functions that are within |
| the scope of a ‘<samp>#pragma long_calls</samp>’ directive are always |
| turned into long calls. |
| </p> |
| <p>This feature is not enabled by default. Specifying |
| <samp>-mno-long-calls</samp> restores the default behavior, as does |
| placing the function calls within the scope of a ‘<samp>#pragma |
| long_calls_off</samp>’ directive. Note these switches have no effect on how |
| the compiler generates code to handle function calls via function |
| pointers. |
| </p> |
| </dd> |
| <dt><code>-msingle-pic-base</code></dt> |
| <dd><a name="index-msingle_002dpic_002dbase"></a> |
| <p>Treat the register used for PIC addressing as read-only, rather than |
| loading it in the prologue for each function. The runtime system is |
| responsible for initializing this register with an appropriate value |
| before execution begins. |
| </p> |
| </dd> |
| <dt><code>-mpic-register=<var>reg</var></code></dt> |
| <dd><a name="index-mpic_002dregister"></a> |
| <p>Specify the register to be used for PIC addressing. |
| For standard PIC base case, the default will be any suitable register |
| determined by compiler. For single PIC base case, the default is |
| ‘<samp>R9</samp>’ if target is EABI based or stack-checking is enabled, |
| otherwise the default is ‘<samp>R10</samp>’. |
| </p> |
| </dd> |
| <dt><code>-mpic-data-is-text-relative</code></dt> |
| <dd><a name="index-mpic_002ddata_002dis_002dtext_002drelative"></a> |
| <p>Assume that each data segments are relative to text segment at load time. |
| Therefore, it permits addressing data using PC-relative operations. |
| This option is on by default for targets other than VxWorks RTP. |
| </p> |
| </dd> |
| <dt><code>-mpoke-function-name</code></dt> |
| <dd><a name="index-mpoke_002dfunction_002dname"></a> |
| <p>Write the name of each function into the text section, directly |
| preceding the function prologue. The generated code is similar to this: |
| </p> |
| <div class="smallexample"> |
| <pre class="smallexample"> t0 |
| .ascii "arm_poke_function_name", 0 |
| .align |
| t1 |
| .word 0xff000000 + (t1 - t0) |
| arm_poke_function_name |
| mov ip, sp |
| stmfd sp!, {fp, ip, lr, pc} |
| sub fp, ip, #4 |
| </pre></div> |
| |
| <p>When performing a stack backtrace, code can inspect the value of |
| <code>pc</code> stored at <code>fp + 0</code>. If the trace function then looks at |
| location <code>pc - 12</code> and the top 8 bits are set, then we know that |
| there is a function name embedded immediately preceding this location |
| and has length <code>((pc[-3]) & 0xff000000)</code>. |
| </p> |
| </dd> |
| <dt><code>-mthumb</code></dt> |
| <dt><code>-marm</code></dt> |
| <dd><a name="index-marm"></a> |
| <a name="index-mthumb"></a> |
| |
| <p>Select between generating code that executes in ARM and Thumb |
| states. The default for most configurations is to generate code |
| that executes in ARM state, but the default can be changed by |
| configuring GCC with the <samp>--with-mode=</samp><var>state</var> |
| configure option. |
| </p> |
| </dd> |
| <dt><code>-mtpcs-frame</code></dt> |
| <dd><a name="index-mtpcs_002dframe"></a> |
| <p>Generate a stack frame that is compliant with the Thumb Procedure Call |
| Standard for all non-leaf functions. (A leaf function is one that does |
| not call any other functions.) The default is <samp>-mno-tpcs-frame</samp>. |
| </p> |
| </dd> |
| <dt><code>-mtpcs-leaf-frame</code></dt> |
| <dd><a name="index-mtpcs_002dleaf_002dframe"></a> |
| <p>Generate a stack frame that is compliant with the Thumb Procedure Call |
| Standard for all leaf functions. (A leaf function is one that does |
| not call any other functions.) The default is <samp>-mno-apcs-leaf-frame</samp>. |
| </p> |
| </dd> |
| <dt><code>-mcallee-super-interworking</code></dt> |
| <dd><a name="index-mcallee_002dsuper_002dinterworking"></a> |
| <p>Gives all externally visible functions in the file being compiled an ARM |
| instruction set header which switches to Thumb mode before executing the |
| rest of the function. This allows these functions to be called from |
| non-interworking code. This option is not valid in AAPCS configurations |
| because interworking is enabled by default. |
| </p> |
| </dd> |
| <dt><code>-mcaller-super-interworking</code></dt> |
| <dd><a name="index-mcaller_002dsuper_002dinterworking"></a> |
| <p>Allows calls via function pointers (including virtual functions) to |
| execute correctly regardless of whether the target code has been |
| compiled for interworking or not. There is a small overhead in the cost |
| of executing a function pointer if this option is enabled. This option |
| is not valid in AAPCS configurations because interworking is enabled |
| by default. |
| </p> |
| </dd> |
| <dt><code>-mtp=<var>name</var></code></dt> |
| <dd><a name="index-mtp"></a> |
| <p>Specify the access model for the thread local storage pointer. The valid |
| models are <samp>soft</samp>, which generates calls to <code>__aeabi_read_tp</code>, |
| <samp>cp15</samp>, which fetches the thread pointer from <code>cp15</code> directly |
| (supported in the arm6k architecture), and <samp>auto</samp>, which uses the |
| best available method for the selected processor. The default setting is |
| <samp>auto</samp>. |
| </p> |
| </dd> |
| <dt><code>-mtls-dialect=<var>dialect</var></code></dt> |
| <dd><a name="index-mtls_002ddialect"></a> |
| <p>Specify the dialect to use for accessing thread local storage. Two |
| <var>dialect</var>s are supported—‘<samp>gnu</samp>’ and ‘<samp>gnu2</samp>’. The |
| ‘<samp>gnu</samp>’ dialect selects the original GNU scheme for supporting |
| local and global dynamic TLS models. The ‘<samp>gnu2</samp>’ dialect |
| selects the GNU descriptor scheme, which provides better performance |
| for shared libraries. The GNU descriptor scheme is compatible with |
| the original scheme, but does require new assembler, linker and |
| library support. Initial and local exec TLS models are unaffected by |
| this option and always use the original scheme. |
| </p> |
| </dd> |
| <dt><code>-mword-relocations</code></dt> |
| <dd><a name="index-mword_002drelocations"></a> |
| <p>Only generate absolute relocations on word-sized values (i.e. R_ARM_ABS32). |
| This is enabled by default on targets (uClinux, SymbianOS) where the runtime |
| loader imposes this restriction, and when <samp>-fpic</samp> or <samp>-fPIC</samp> |
| is specified. |
| </p> |
| </dd> |
| <dt><code>-mfix-cortex-m3-ldrd</code></dt> |
| <dd><a name="index-mfix_002dcortex_002dm3_002dldrd"></a> |
| <p>Some Cortex-M3 cores can cause data corruption when <code>ldrd</code> instructions |
| with overlapping destination and base registers are used. This option avoids |
| generating these instructions. This option is enabled by default when |
| <samp>-mcpu=cortex-m3</samp> is specified. |
| </p> |
| </dd> |
| <dt><code>-munaligned-access</code></dt> |
| <dt><code>-mno-unaligned-access</code></dt> |
| <dd><a name="index-munaligned_002daccess"></a> |
| <a name="index-mno_002dunaligned_002daccess"></a> |
| <p>Enables (or disables) reading and writing of 16- and 32- bit values |
| from addresses that are not 16- or 32- bit aligned. By default |
| unaligned access is disabled for all pre-ARMv6 and all ARMv6-M |
| architectures, and enabled for all other architectures. If unaligned |
| access is not enabled then words in packed data structures will be |
| accessed a byte at a time. |
| </p> |
| <p>The ARM attribute <code>Tag_CPU_unaligned_access</code> will be set in the |
| generated object file to either true or false, depending upon the |
| setting of this option. If unaligned access is enabled then the |
| preprocessor symbol <code>__ARM_FEATURE_UNALIGNED</code> will also be |
| defined. |
| </p> |
| </dd> |
| <dt><code>-mneon-for-64bits</code></dt> |
| <dd><a name="index-mneon_002dfor_002d64bits"></a> |
| <p>Enables using Neon to handle scalar 64-bits operations. This is |
| disabled by default since the cost of moving data from core registers |
| to Neon is high. |
| </p> |
| </dd> |
| <dt><code>-mslow-flash-data</code></dt> |
| <dd><a name="index-mslow_002dflash_002ddata"></a> |
| <p>Assume loading data from flash is slower than fetching instruction. |
| Therefore literal load is minimized for better performance. |
| This option is only supported when compiling for ARMv7 M-profile and |
| off by default. |
| </p> |
| </dd> |
| <dt><code>-mrestrict-it</code></dt> |
| <dd><a name="index-mrestrict_002dit"></a> |
| <p>Restricts generation of IT blocks to conform to the rules of ARMv8. |
| IT blocks can only contain a single 16-bit instruction from a select |
| set of instructions. This option is on by default for ARMv8 Thumb mode. |
| </p></dd> |
| </dl> |
| |
| <hr> |
| <div class="header"> |
| <p> |
| Next: <a href="AVR-Options.html#AVR-Options" accesskey="n" rel="next">AVR Options</a>, Previous: <a href="ARC-Options.html#ARC-Options" accesskey="p" rel="prev">ARC Options</a>, Up: <a href="Submodel-Options.html#Submodel-Options" accesskey="u" rel="up">Submodel Options</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> |