blob: 0b9b50e3ae7f2f93e9d3bfa336f2ec4a97cd4093 [file] [log] [blame]
; Options for the FR-V port of the compiler.
; Copyright (C) 2005-2022 Free Software Foundation, Inc.
;
; This file is part of GCC.
;
; GCC is free software; you can redistribute it and/or modify it under
; the terms of the GNU General Public License as published by the Free
; Software Foundation; either version 3, or (at your option) any later
; version.
;
; GCC is distributed in the hope that it will be useful, but WITHOUT ANY
; WARRANTY; without even the implied warranty of MERCHANTABILITY or
; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
; for more details.
;
; You should have received a copy of the GNU General Public License
; along with GCC; see the file COPYING3. If not see
; <http://www.gnu.org/licenses/>.
HeaderInclude
config/frv/frv-opts.h
; Value of -mcpu=.
Variable
frv_cpu_t frv_cpu_type = CPU_TYPE
macc-4
Target RejectNegative Mask(ACC_4)
Use 4 media accumulators.
macc-8
Target RejectNegative InverseMask(ACC_4, ACC_8)
Use 8 media accumulators.
malign-labels
Target Mask(ALIGN_LABELS)
Enable label alignment optimizations.
malloc-cc
Target RejectNegative Mask(ALLOC_CC)
Dynamically allocate cc registers.
; We used to default the branch cost to 2, but it was changed it to 1 to avoid
; generating SCC instructions and or/and-ing them together, and then doing the
; branch on the result, which collectively generate much worse code.
mbranch-cost=
Target RejectNegative Joined UInteger Var(frv_branch_cost_int) Init(1)
Set the cost of branches.
mcond-exec
Target Mask(COND_EXEC)
Enable conditional execution other than moves/scc.
mcond-exec-insns=
Target RejectNegative Joined UInteger Var(frv_condexec_insns) Init(8)
Change the maximum length of conditionally-executed sequences.
mcond-exec-temps=
Target RejectNegative Joined UInteger Var(frv_condexec_temps) Init(4)
Change the number of temporary registers that are available to conditionally-executed sequences.
mcond-move
Target Mask(COND_MOVE)
Enable conditional moves.
mcpu=
Target RejectNegative Joined Enum(frv_cpu) Var(frv_cpu_type)
Set the target CPU type.
Enum
Name(frv_cpu) Type(frv_cpu_t)
Known FR-V CPUs (for use with the -mcpu= option):
EnumValue
Enum(frv_cpu) String(simple) Value(FRV_CPU_SIMPLE)
EnumValue
Enum(frv_cpu) String(tomcat) Value(FRV_CPU_TOMCAT)
EnumValue
Enum(frv_cpu) String(fr550) Value(FRV_CPU_FR550)
EnumValue
Enum(frv_cpu) String(fr500) Value(FRV_CPU_FR500)
EnumValue
Enum(frv_cpu) String(fr450) Value(FRV_CPU_FR450)
EnumValue
Enum(frv_cpu) String(fr405) Value(FRV_CPU_FR405)
EnumValue
Enum(frv_cpu) String(fr400) Value(FRV_CPU_FR400)
EnumValue
Enum(frv_cpu) String(fr300) Value(FRV_CPU_FR300)
EnumValue
Enum(frv_cpu) String(frv) Value(FRV_CPU_GENERIC)
mdebug
Target Undocumented Var(TARGET_DEBUG)
mdebug-arg
Target Undocumented Var(TARGET_DEBUG_ARG)
mdebug-addr
Target Undocumented Var(TARGET_DEBUG_ADDR)
mdebug-cond-exec
Target Undocumented Var(TARGET_DEBUG_COND_EXEC)
mdebug-loc
Target Undocumented Var(TARGET_DEBUG_LOC)
mdebug-stack
Target Undocumented Var(TARGET_DEBUG_STACK)
mdouble
Target Mask(DOUBLE)
Use fp double instructions.
mdword
Target Mask(DWORD)
Change the ABI to allow double word insns.
mfdpic
Target Mask(FDPIC)
Enable Function Descriptor PIC mode.
mfixed-cc
Target RejectNegative InverseMask(ALLOC_CC, FIXED_CC)
Just use icc0/fcc0.
mfpr-32
Target RejectNegative Mask(FPR_32)
Only use 32 FPRs.
mfpr-64
Target RejectNegative InverseMask(FPR_32, FPR_64)
Use 64 FPRs.
mgpr-32
Target RejectNegative Mask(GPR_32)
Only use 32 GPRs.
mgpr-64
Target RejectNegative InverseMask(GPR_32, GPR_64)
Use 64 GPRs.
mgprel-ro
Target Mask(GPREL_RO)
Enable use of GPREL for read-only data in FDPIC.
mhard-float
Target RejectNegative InverseMask(SOFT_FLOAT, HARD_FLOAT)
Use hardware floating point.
minline-plt
Target Mask(INLINE_PLT)
Enable inlining of PLT in function calls.
mlibrary-pic
Target Mask(LIBPIC)
Enable PIC support for building libraries.
mlinked-fp
Target Mask(LINKED_FP)
Follow the EABI linkage requirements.
mlong-calls
Target Mask(LONG_CALLS)
Disallow direct calls to global functions.
mmedia
Target Mask(MEDIA)
Use media instructions.
mmuladd
Target Mask(MULADD)
Use multiply add/subtract instructions.
mmulti-cond-exec
Target Mask(MULTI_CE)
Enable optimizing &&/|| in conditional execution.
mnested-cond-exec
Target Mask(NESTED_CE)
Enable nested conditional execution optimizations.
; Not used by the compiler proper.
mno-eflags
Target RejectNegative
Do not mark ABI switches in e_flags.
moptimize-membar
Target Mask(OPTIMIZE_MEMBAR)
Remove redundant membars.
mpack
Target Mask(PACK)
Pack VLIW instructions.
mscc
Target Mask(SCC)
Enable setting GPRs to the result of comparisons.
msched-lookahead=
Target RejectNegative Joined UInteger Var(frv_sched_lookahead) Init(4)
Change the amount of scheduler lookahead.
msoft-float
Target RejectNegative Mask(SOFT_FLOAT)
Use software floating point.
mTLS
Target RejectNegative Mask(BIG_TLS)
Assume a large TLS segment.
mtls
Target RejectNegative InverseMask(BIG_TLS)
Do not assume a large TLS segment.
; Not used by the compiler proper.
mtomcat-stats
Target
Cause gas to print tomcat statistics.
; Not used by the compiler proper.
multilib-library-pic
Target RejectNegative
Link with the library-pic libraries.
mvliw-branch
Target Mask(VLIW_BRANCH)
Allow branches to be packed with other instructions.