invoke.texi (MIPS Options): Document -mfused-madd.

* doc/invoke.texi (MIPS Options): Document -mfused-madd.
	* config/mips/mips.h (MASK_NO_FUSED_MADD): New.
	(TARGET_FUSED_MADD): New.
	(TARGET_SWITCHES): Add -mfused-madd, -mno-fused-madd.
	* config/mips/mips.md: Add TARGET_FUSED_MADD as condition to
	the multiply-add instructions.

From-SVN: r45041
This commit is contained in:
Geoffrey Keating 2001-08-19 21:40:37 +00:00 committed by Geoffrey Keating
parent 915a17f667
commit 13fac94a68
4 changed files with 39 additions and 9 deletions

View File

@ -1,3 +1,12 @@
2001-08-19 Geoffrey Keating <geoffk@redhat.com>
* doc/invoke.texi (MIPS Options): Document -mfused-madd.
* config/mips/mips.h (MASK_NO_FUSED_MADD): New.
(TARGET_FUSED_MADD): New.
(TARGET_SWITCHES): Add -mfused-madd, -mno-fused-madd.
* config/mips/mips.md: Add TARGET_FUSED_MADD as condition to
the multiply-add instructions.
2001-08-19 Richard Henderson <rth@redhat.com> 2001-08-19 Richard Henderson <rth@redhat.com>
* dwarf2asm.c (dw2_output_indirect_constant_1): The symbol ref * dwarf2asm.c (dw2_output_indirect_constant_1): The symbol ref

View File

@ -223,6 +223,8 @@ extern void sbss_section PARAMS ((void));
#define MASK_UNINIT_CONST_IN_RODATA \ #define MASK_UNINIT_CONST_IN_RODATA \
0x00800000 /* Store uninitialized 0x00800000 /* Store uninitialized
consts in rodata */ consts in rodata */
#define MASK_NO_FUSED_MADD 0x01000000 /* Don't generate floating point
multiply-add operations. */
/* Debug switches, not documented */ /* Debug switches, not documented */
#define MASK_DEBUG 0 /* unused */ #define MASK_DEBUG 0 /* unused */
@ -311,6 +313,8 @@ extern void sbss_section PARAMS ((void));
#define TARGET_MAD (target_flags & MASK_MAD) #define TARGET_MAD (target_flags & MASK_MAD)
#define TARGET_FUSED_MADD (! (target_flags & MASK_NO_FUSED_MADD))
#define TARGET_4300_MUL_FIX (target_flags & MASK_4300_MUL_FIX) #define TARGET_4300_MUL_FIX (target_flags & MASK_4300_MUL_FIX)
#define TARGET_NO_CHECK_ZERO_DIV (target_flags & MASK_NO_CHECK_ZERO_DIV) #define TARGET_NO_CHECK_ZERO_DIV (target_flags & MASK_NO_CHECK_ZERO_DIV)
@ -439,6 +443,10 @@ extern void sbss_section PARAMS ((void));
N_("Use multiply accumulate")}, \ N_("Use multiply accumulate")}, \
{"no-mad", -MASK_MAD, \ {"no-mad", -MASK_MAD, \
N_("Don't use multiply accumulate")}, \ N_("Don't use multiply accumulate")}, \
{"no-fused-madd", MASK_NO_FUSED_MADD, \
N_("Don't generate fused multiply/add instructions")}, \
{"fused-madd", -MASK_NO_FUSED_MADD, \
N_("Generate fused multiply/add instructions")}, \
{"fix4300", MASK_4300_MUL_FIX, \ {"fix4300", MASK_4300_MUL_FIX, \
N_("Work around early 4300 hardware bug")}, \ N_("Work around early 4300 hardware bug")}, \
{"no-fix4300", -MASK_4300_MUL_FIX, \ {"no-fix4300", -MASK_4300_MUL_FIX, \

View File

@ -2138,7 +2138,7 @@
(plus:DF (mult:DF (match_operand:DF 1 "register_operand" "f") (plus:DF (mult:DF (match_operand:DF 1 "register_operand" "f")
(match_operand:DF 2 "register_operand" "f")) (match_operand:DF 2 "register_operand" "f"))
(match_operand:DF 3 "register_operand" "f")))] (match_operand:DF 3 "register_operand" "f")))]
"ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT" "ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT && TARGET_FUSED_MADD"
"madd.d\\t%0,%3,%1,%2" "madd.d\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "DF")]) (set_attr "mode" "DF")])
@ -2148,7 +2148,7 @@
(plus:SF (mult:SF (match_operand:SF 1 "register_operand" "f") (plus:SF (mult:SF (match_operand:SF 1 "register_operand" "f")
(match_operand:SF 2 "register_operand" "f")) (match_operand:SF 2 "register_operand" "f"))
(match_operand:SF 3 "register_operand" "f")))] (match_operand:SF 3 "register_operand" "f")))]
"ISA_HAS_FP4 && TARGET_HARD_FLOAT" "ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_FUSED_MADD"
"madd.s\\t%0,%3,%1,%2" "madd.s\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "SF")]) (set_attr "mode" "SF")])
@ -2158,7 +2158,7 @@
(minus:DF (mult:DF (match_operand:DF 1 "register_operand" "f") (minus:DF (mult:DF (match_operand:DF 1 "register_operand" "f")
(match_operand:DF 2 "register_operand" "f")) (match_operand:DF 2 "register_operand" "f"))
(match_operand:DF 3 "register_operand" "f")))] (match_operand:DF 3 "register_operand" "f")))]
"ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT" "ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT && TARGET_FUSED_MADD"
"msub.d\\t%0,%3,%1,%2" "msub.d\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "DF")]) (set_attr "mode" "DF")])
@ -2169,7 +2169,7 @@
(match_operand:SF 2 "register_operand" "f")) (match_operand:SF 2 "register_operand" "f"))
(match_operand:SF 3 "register_operand" "f")))] (match_operand:SF 3 "register_operand" "f")))]
"ISA_HAS_FP4 && TARGET_HARD_FLOAT" "ISA_HAS_FP4 && TARGET_HARD_FLOAT && TARGET_FUSED_MADD"
"msub.s\\t%0,%3,%1,%2" "msub.s\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "SF")]) (set_attr "mode" "SF")])
@ -2179,7 +2179,7 @@
(neg:DF (plus:DF (mult:DF (match_operand:DF 1 "register_operand" "f") (neg:DF (plus:DF (mult:DF (match_operand:DF 1 "register_operand" "f")
(match_operand:DF 2 "register_operand" "f")) (match_operand:DF 2 "register_operand" "f"))
(match_operand:DF 3 "register_operand" "f"))))] (match_operand:DF 3 "register_operand" "f"))))]
"ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT" "ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT && TARGET_FUSED_MADD"
"nmadd.d\\t%0,%3,%1,%2" "nmadd.d\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "DF")]) (set_attr "mode" "DF")])
@ -2189,7 +2189,7 @@
(neg:SF (plus:SF (mult:SF (match_operand:SF 1 "register_operand" "f") (neg:SF (plus:SF (mult:SF (match_operand:SF 1 "register_operand" "f")
(match_operand:SF 2 "register_operand" "f")) (match_operand:SF 2 "register_operand" "f"))
(match_operand:SF 3 "register_operand" "f"))))] (match_operand:SF 3 "register_operand" "f"))))]
"ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT" "ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_FUSED_MADD"
"nmadd.s\\t%0,%3,%1,%2" "nmadd.s\\t%0,%3,%1,%2"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "SF")]) (set_attr "mode" "SF")])
@ -2199,7 +2199,7 @@
(minus:DF (match_operand:DF 1 "register_operand" "f") (minus:DF (match_operand:DF 1 "register_operand" "f")
(mult:DF (match_operand:DF 2 "register_operand" "f") (mult:DF (match_operand:DF 2 "register_operand" "f")
(match_operand:DF 3 "register_operand" "f"))))] (match_operand:DF 3 "register_operand" "f"))))]
"ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT" "ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_DOUBLE_FLOAT && TARGET_FUSED_MADD"
"nmsub.d\\t%0,%1,%2,%3" "nmsub.d\\t%0,%1,%2,%3"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "DF")]) (set_attr "mode" "DF")])
@ -2209,7 +2209,7 @@
(minus:SF (match_operand:SF 1 "register_operand" "f") (minus:SF (match_operand:SF 1 "register_operand" "f")
(mult:SF (match_operand:SF 2 "register_operand" "f") (mult:SF (match_operand:SF 2 "register_operand" "f")
(match_operand:SF 3 "register_operand" "f"))))] (match_operand:SF 3 "register_operand" "f"))))]
"ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT" "ISA_HAS_NMADD_NMSUB && TARGET_HARD_FLOAT && TARGET_FUSED_MADD"
"nmsub.s\\t%0,%1,%2,%3" "nmsub.s\\t%0,%1,%2,%3"
[(set_attr "type" "fmadd") [(set_attr "type" "fmadd")
(set_attr "mode" "SF")]) (set_attr "mode" "SF")])

View File

@ -450,7 +450,8 @@ in the following sections.
@gccoptlist{ @gccoptlist{
-mabicalls -march=@var{cpu-type} -mtune=@var{cpu=type} @gol -mabicalls -march=@var{cpu-type} -mtune=@var{cpu=type} @gol
-mcpu=@var{cpu-type} -membedded-data -muninit-const-in-rodata @gol -mcpu=@var{cpu-type} -membedded-data -muninit-const-in-rodata @gol
-membedded-pic -mfp32 -mfp64 -mgas -mgp32 -mgp64 @gol -membedded-pic -mfp32 -mfp64 -mfused-madd -mno-fused-madd @gol
-mgas -mgp32 -mgp64 @gol
-mgpopt -mhalf-pic -mhard-float -mint64 -mips1 @gol -mgpopt -mhalf-pic -mhard-float -mint64 -mips1 @gol
-mips2 -mips3 -mips4 -mlong64 -mlong32 -mlong-calls -mmemcpy @gol -mips2 -mips3 -mips4 -mlong64 -mlong32 -mlong-calls -mmemcpy @gol
-mmips-as -mmips-tfile -mno-abicalls @gol -mmips-as -mmips-tfile -mno-abicalls @gol
@ -7080,6 +7081,18 @@ the default.
Assume that 32 64-bit floating point registers are available. This is Assume that 32 64-bit floating point registers are available. This is
the default when the @option{-mips3} option is used. the default when the @option{-mips3} option is used.
@item -mfused-madd
@itemx -mno-fused-madd
@opindex mfused-madd
@opindex mno-fused-madd
Generate code that uses (does not use) the floating point multiply and
accumulate instructions, when they are available. These instructions
are generated by default if they are available, but this may be
undesirable if the extra precision causes problems or on certain chips
in the mode where denormals are rounded to zero where denormals
generated by multiply and accumulate instructions cause exceptions
anyway.
@item -mgp32 @item -mgp32
@opindex mgp32 @opindex mgp32
Assume that 32 32-bit general purpose registers are available. This is Assume that 32 32-bit general purpose registers are available. This is