]> gcc.gnu.org Git - gcc.git/commitdiff
cse.c (exp_equiv_p): Special case CONST_DOUBLE.
authorRichard Henderson <rth@redhat.com>
Fri, 29 Jul 2005 05:57:44 +0000 (22:57 -0700)
committerRichard Henderson <rth@gcc.gnu.org>
Fri, 29 Jul 2005 05:57:44 +0000 (22:57 -0700)
        * cse.c (exp_equiv_p): Special case CONST_DOUBLE.
        * cselib.c (rtx_equal_for_cselib_p): Likewise.
        * jump.c (rtx_renumbered_equal_p): Likewise.
        * loop.c (rtx_equal_for_loop_p): Tidy and special case PC, CC0,
        CONST_INT and CONST_DOUBLE.
        (rtx_equal_for_prefetch_p): Likewise, plus LABEL_REF.
        * reload.c (operands_match_p): Special case CONST_INT and
        CONST_DOUBLE; check mode earlier.

From-SVN: r102548

gcc/ChangeLog
gcc/cse.c
gcc/cselib.c
gcc/jump.c
gcc/loop.c
gcc/reload.c

index 86664bab127cbae3c5bc5526964f3ff07d618fb7..07e31b4bf42e8fefc068f7d7c9ce0548f7e1e26a 100644 (file)
@@ -1,3 +1,14 @@
+2005-07-28  Richard Henderson  <rth@redhat.com>
+
+       * cse.c (exp_equiv_p): Special case CONST_DOUBLE.
+       * cselib.c (rtx_equal_for_cselib_p): Likewise.
+       * jump.c (rtx_renumbered_equal_p): Likewise.
+       * loop.c (rtx_equal_for_loop_p): Tidy and special case PC, CC0,
+       CONST_INT and CONST_DOUBLE.
+       (rtx_equal_for_prefetch_p): Likewise, plus LABEL_REF.
+       * reload.c (operands_match_p): Special case CONST_INT and
+       CONST_DOUBLE; check mode earlier.
+
 2005-07-29  Joseph S. Myers  <joseph@codesourcery.com>
 
        PR c/22240
index 9cade945e4e16fc0a3647bb4fb68017d091a6ef4..1efcf308ae4ced72e6314dae719ca3749cd900ef 100644 (file)
--- a/gcc/cse.c
+++ b/gcc/cse.c
@@ -2498,6 +2498,7 @@ exp_equiv_p (rtx x, rtx y, int validate, bool for_gcse)
     case PC:
     case CC0:
     case CONST_INT:
+    case CONST_DOUBLE:
       return x == y;
 
     case LABEL_REF:
index 5d36be9182937380ac1c31bc4362b82bd365ffb0..13fc5326dc0210dea6a2323bccb0faec94568f02 100644 (file)
@@ -462,9 +462,18 @@ rtx_equal_for_cselib_p (rtx x, rtx y)
   if (GET_CODE (x) != GET_CODE (y) || GET_MODE (x) != GET_MODE (y))
     return 0;
 
-  /* This won't be handled correctly by the code below.  */
-  if (GET_CODE (x) == LABEL_REF)
-    return XEXP (x, 0) == XEXP (y, 0);
+  /* These won't be handled correctly by the code below.  */
+  switch (GET_CODE (x))
+    {
+    case CONST_DOUBLE:
+      return 0;
+
+    case LABEL_REF:
+      return XEXP (x, 0) == XEXP (y, 0);
+
+    default:
+      break;
+    }
 
   code = GET_CODE (x);
   fmt = GET_RTX_FORMAT (code);
index e3e2cdaa501b9efcfa439a0915946365269725ae..c278319b4d26f2a44132477d903b19cc81c232d9 100644 (file)
@@ -1879,6 +1879,7 @@ rtx_renumbered_equal_p (rtx x, rtx y)
     case ADDR_VEC:
     case ADDR_DIFF_VEC:
     case CONST_INT:
+    case CONST_DOUBLE:
       return 0;
 
     case LABEL_REF:
index 2686294bfd8db536f64154d13017ffe466ab4b3b..a904881be3d273090605e7ec8a446852452500ff 100644 (file)
@@ -2057,14 +2057,26 @@ rtx_equal_for_loop_p (rtx x, rtx y, struct loop_movables *movables,
   if (GET_MODE (x) != GET_MODE (y))
     return 0;
 
-  /* These three types of rtx's can be compared nonrecursively.  */
-  if (code == REG)
-    return (REGNO (x) == REGNO (y) || regs_match_p (x, y, movables));
+  /* These types of rtx's can be compared nonrecursively.  */
+  switch (code)
+    {
+    case PC:
+    case CC0:
+    case CONST_INT:
+    case CONST_DOUBLE:
+      return 0;
 
-  if (code == LABEL_REF)
-    return XEXP (x, 0) == XEXP (y, 0);
-  if (code == SYMBOL_REF)
-    return XSTR (x, 0) == XSTR (y, 0);
+    case REG:
+      return (REGNO (x) == REGNO (y) || regs_match_p (x, y, movables));
+
+    case LABEL_REF:
+      return XEXP (x, 0) == XEXP (y, 0);
+    case SYMBOL_REF:
+      return XSTR (x, 0) == XSTR (y, 0);
+
+    default:
+      break;
+    }
 
   /* Compare the elements.  If any pair of corresponding elements
      fail to match, return 0 for the whole things.  */
@@ -3984,6 +3996,24 @@ rtx_equal_for_prefetch_p (rtx x, rtx y)
   if (code != GET_CODE (y))
     return 0;
 
+  if (GET_MODE (x) != GET_MODE (y))
+    return 0;
+
+  switch (code)
+    {
+    case PC:
+    case CC0:
+    case CONST_INT:
+    case CONST_DOUBLE:
+      return 0;
+
+    case LABEL_REF:
+      return XEXP (x, 0) == XEXP (y, 0);
+
+    default:
+      break;
+    }
+
   if (COMMUTATIVE_ARITH_P (x))
     {
       return ((rtx_equal_for_prefetch_p (XEXP (x, 0), XEXP (y, 0))
index e2d4a8e1f3abb5cee9a0f8cab28f1b766e57c063..378db66aeaceab08db63ae902bb6b79d7f51a220 100644 (file)
@@ -2208,20 +2208,30 @@ operands_match_p (rtx x, rtx y)
 
  slow:
 
-  /* Now we have disposed of all the cases
-     in which different rtx codes can match.  */
+  /* Now we have disposed of all the cases in which different rtx codes
+     can match.  */
   if (code != GET_CODE (y))
     return 0;
-  if (code == LABEL_REF)
-    return XEXP (x, 0) == XEXP (y, 0);
-  if (code == SYMBOL_REF)
-    return XSTR (x, 0) == XSTR (y, 0);
 
   /* (MULT:SI x y) and (MULT:HI x y) are NOT equivalent.  */
-
   if (GET_MODE (x) != GET_MODE (y))
     return 0;
 
+  switch (code)
+    {
+    case CONST_INT:
+    case CONST_DOUBLE:
+      return 0;
+
+    case LABEL_REF:
+      return XEXP (x, 0) == XEXP (y, 0);
+    case SYMBOL_REF:
+      return XSTR (x, 0) == XSTR (y, 0);
+
+    default:
+      break;
+    }
+
   /* Compare the elements.  If any pair of corresponding elements
      fail to match, return 0 for the whole things.  */
 
This page took 0.086474 seconds and 5 git commands to generate.