re PR rtl-optimization/15068 (ICE in elim_reg_cond)
authorPaul Brook <paul@codesourcery.com>
Mon, 2 Aug 2004 13:19:39 +0000 (13:19 +0000)
committerPaul Brook <pbrook@gcc.gnu.org>
Mon, 2 Aug 2004 13:19:39 +0000 (13:19 +0000)
PR rtl-optimization/15068
* flow.c (init_propagate_block_info): Check condition is reversible.

From-SVN: r85439

gcc/ChangeLog
gcc/flow.c

index 9393406db64f1d4b1c2700d4344ba3b98fb23786..7dc0a5b503c92758c767855f70de03cc1fa8ee80 100644 (file)
@@ -1,3 +1,8 @@
+2004-08-02  Paul Brook  <paul@codesourcery.com>
+
+       PR rtl-optimization/15068
+       * flow.c (init_propagate_block_info): Check condition is reversible.
+
 2004-08-02  Gabriel Dos Reis  <gdr@integrable-solutions.net>
 
        * gengtype.h (options::info): Change type to const char *.
index bf8e61ce3f636f3850077db535b68fa221566c34..344b48bf22310fda0f45d34b58aee6bb9e7fd566 100644 (file)
@@ -1865,19 +1865,22 @@ init_propagate_block_info (basic_block bb, regset live, regset local_set,
          rtx set_src = SET_SRC (pc_set (BB_END (bb)));
          rtx cond_true = XEXP (set_src, 0);
          rtx reg = XEXP (cond_true, 0);
+         enum rtx_code inv_cond;
 
          if (GET_CODE (reg) == SUBREG)
            reg = SUBREG_REG (reg);
 
          /* We can only track conditional lifetimes if the condition is
-            in the form of a comparison of a register against zero.  
-            If the condition is more complex than that, then it is safe
-            not to record any information.  */
-         if (REG_P (reg)
+            in the form of a reversible comparison of a register against
+            zero.  If the condition is more complex than that, then it is
+            safe not to record any information.  */
+         inv_cond = reversed_comparison_code (cond_true, BB_END (bb));
+         if (inv_cond != UNKNOWN
+             && REG_P (reg)
              && XEXP (cond_true, 1) == const0_rtx)
            {
              rtx cond_false
-               = gen_rtx_fmt_ee (reverse_condition (GET_CODE (cond_true)),
+               = gen_rtx_fmt_ee (inv_cond,
                                  GET_MODE (cond_true), XEXP (cond_true, 0),
                                  XEXP (cond_true, 1));
              if (GET_CODE (XEXP (set_src, 1)) == PC)