CRIS Options#

These options are defined specifically for the CRIS ports.

-march=architecture-type#

Generate code for the specified architecture. The choices for architecture-type are v3, v8 and v10 for respectively ETRAX4, ETRAX100, and ETRAX100LX. Default is v0.

-mtune=architecture-type#

Tune to architecture-type everything applicable about the generated code, except for the ABI and the set of available instructions. The choices for architecture-type are the same as for -march=architecture-type.

-mmax-stack-frame=n#

Warn when the stack frame of a function exceeds n bytes.

-metrax4, -metrax100#

The options -metrax4 and -metrax100 are synonyms for -march=v3 and -march=v8 respectively.

-mmul-bug-workaround, -mno-mul-bug-workaround#

Work around a bug in the muls and mulu instructions for CPU models where it applies. This option is disabled by default.

-mpdebug#

Enable CRIS-specific verbose debug-related information in the assembly code. This option also has the effect of turning off the #NO_APP formatted-code indicator to the assembler at the beginning of the assembly file.

-mcc-init#

Do not use condition-code results from previous instruction; always emit compare and test instructions before use of condition codes.

-mno-side-effects#

Do not emit instructions with side effects in addressing modes other than post-increment.

-mside-effects#

Default setting; overrides -mno-side-effects.

-mstack-align, -mno-stack-align, -mdata-align, -mno-data-align, -mconst-align, -mno-const-align#

These options (no- options) arrange (eliminate arrangements) for the stack frame, individual data and constants to be aligned for the maximum single data access size for the chosen CPU model. The default is to arrange for 32-bit alignment. ABI details such as structure layout are not affected by these options.

-m32-bit, -m16-bit, -m8-bit#

Similar to the stack- data- and const-align options above, these options arrange for stack frame, writable data and constants to all be 32-bit, 16-bit or 8-bit aligned. The default is 32-bit alignment.

-mno-prologue-epilogue, -mprologue-epilogue#

With -mno-prologue-epilogue, the normal function prologue and epilogue which set up the stack frame are omitted and no return instructions or return sequences are generated in the code. Use this option only together with visual inspection of the compiled code: no warnings or errors are generated when call-saved registers must be saved, or storage for local variables needs to be allocated.

-melf#

Legacy no-op option.

-sim#

This option arranges to link with input-output functions from a simulator library. Code, initialized data and zero-initialized data are allocated consecutively.

-sim2#

Like -sim, but pass linker options to locate initialized data at 0x40000000 and zero-initialized data at 0x80000000.