mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-04-05 17:00:58 +08:00
mips.md (div_trap): Split div_trap_mips16 from div_trap.
* config/mips/mips.md (div_trap): Split div_trap_mips16 from div_trap. (div_trap_normal,div_trap_mips16): Correct the length attributes. From-SVN: r24745
This commit is contained in:
parent
08c259de90
commit
aa7ecb4aa5
@ -1,3 +1,9 @@
|
||||
Mon Jan 18 12:03:08 1999 Gavin Romig-Koch <gavin@cygnus.com>
|
||||
|
||||
* config/mips/mips.md (div_trap): Split div_trap_mips16
|
||||
from div_trap.
|
||||
(div_trap_normal,div_trap_mips16): Correct the length attributes.
|
||||
|
||||
Mon Jan 18 11:48:28 1999 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
|
||||
|
||||
* cpplib.c (special_symbol): Qualify a char* with the `const' keyword.
|
||||
|
@ -2412,11 +2412,25 @@
|
||||
|
||||
;; Division trap
|
||||
|
||||
(define_insn "div_trap"
|
||||
(define_expand "div_trap"
|
||||
[(trap_if (eq (match_operand 0 "register_operand" "d")
|
||||
(match_operand 1 "reg_or_0_operand" "dJ"))
|
||||
(match_operand 2 "immediate_operand" ""))]
|
||||
""
|
||||
"
|
||||
{
|
||||
if (TARGET_MIPS16)
|
||||
emit_insn (gen_div_trap_mips16 (operands[0],operands[1],operands[2]));
|
||||
else
|
||||
emit_insn (gen_div_trap_normal (operands[0],operands[1],operands[2]));
|
||||
DONE;
|
||||
}")
|
||||
|
||||
(define_insn "div_trap_normal"
|
||||
[(trap_if (eq (match_operand 0 "register_operand" "d")
|
||||
(match_operand 1 "reg_or_0_operand" "dJ"))
|
||||
(match_operand 2 "immediate_operand" ""))]
|
||||
"!TARGET_MIPS16"
|
||||
"*
|
||||
{
|
||||
rtx link;
|
||||
@ -2450,7 +2464,41 @@
|
||||
return \"\";
|
||||
}"
|
||||
[(set_attr "type" "unknown")
|
||||
(set_attr "length" "2")])
|
||||
(set_attr "length" "3")])
|
||||
|
||||
|
||||
;; The mips16 bne insns is a macro which uses reg 24 as an intermediate.
|
||||
|
||||
(define_insn "div_trap_mips16"
|
||||
[(trap_if (eq (match_operand 0 "register_operand" "d")
|
||||
(match_operand 1 "reg_or_0_operand" "dJ"))
|
||||
(match_operand 2 "immediate_operand" ""))
|
||||
(clobber (reg:SI 24))]
|
||||
"TARGET_MIPS16"
|
||||
"*
|
||||
{
|
||||
rtx link;
|
||||
int have_dep_anti = 0;
|
||||
|
||||
/* For divmod if one division is not needed then we don't need an extra
|
||||
divide by zero trap, which is anti dependent on previous trap */
|
||||
for (link = LOG_LINKS (insn); link; link = XEXP (link, 1))
|
||||
|
||||
if ((int) REG_DEP_ANTI == (int) REG_NOTE_KIND (link)
|
||||
&& GET_CODE (PATTERN (XEXP (link, 0))) == TRAP_IF
|
||||
&& REGNO (operands[1]) == 0)
|
||||
have_dep_anti = 1;
|
||||
if (! have_dep_anti)
|
||||
{
|
||||
if (GET_CODE (operands[1]) == CONST_INT)
|
||||
return \"%(bnez\\t%0,1f\\n\\tnop\\n\\tbreak\\t%2\\n1:%)\";
|
||||
else
|
||||
return \"%(bne\\t%0,%1,1f\\n\\tnop\\n\\tbreak\\t%2\\n1:%)\";
|
||||
}
|
||||
return \"\";
|
||||
}"
|
||||
[(set_attr "type" "unknown")
|
||||
(set_attr "length" "4")])
|
||||
|
||||
(define_expand "divsi3"
|
||||
[(set (match_operand:SI 0 "register_operand" "=l")
|
||||
|
Loading…
x
Reference in New Issue
Block a user