* thumb2.md (thumb2_tlobits_cbranch): Delete.
authorrearnsha <rearnsha@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 24 Jun 2010 22:46:54 +0000 (22:46 +0000)
committerrearnsha <rearnsha@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 24 Jun 2010 22:46:54 +0000 (22:46 +0000)
(peephole2 to convert zero_extract/compare of single bit to
 lshift/compare): New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@161344 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/arm/thumb2.md

index 6e5c9d7..d036392 100644 (file)
@@ -1,3 +1,9 @@
+2010-06-24  Richard Earnshaw  <rearnsha@arm.com>
+
+       * thumb2.md (thumb2_tlobits_cbranch): Delete.
+       (peephole2 to convert zero_extract/compare of single bit to
+        lshift/compare): New.
+
 2010-06-24  Anatoly Sokolov  <aesok@post.ru>
 
        * fold-const.c (const_binop): Remove 'notrunc' argement. Adjust
index 7045d14..3985183 100644 (file)
    (set_attr "predicable" "yes")]
 )
 
-(define_insn "*thumb2_tlobits_cbranch"
-  [(set (pc)
-       (if_then_else
-        (match_operator 0 "equality_operator"
-         [(zero_extract:SI (match_operand:SI 1 "s_register_operand" "l,h,h")
-                           (match_operand:SI 2 "const_int_operand" "i,Pu,i")
-                           (const_int 0))
-          (const_int 0)])
-        (label_ref (match_operand 3 "" ""))
-        (pc)))
-   (clobber (match_scratch:SI 4 "=l,X,r"))
-   (clobber (reg:CC CC_REGNUM))]
-  "TARGET_THUMB2"
-  "*
-  {
-  if (which_alternative == 0)
-    {
-      rtx op[3];
-      op[0] = operands[4];
-      op[1] = operands[1];
-      op[2] = GEN_INT (32 - INTVAL (operands[2]));
-
-      output_asm_insn (\"lsls\\t%0, %1, %2\", op);
-      switch (get_attr_length (insn))
-       {
-         case 4:  return \"b%d0\\t%l3\";
-         case 6:  return \"b%D0\\t.LCB%=\;b\\t%l3\\t%@long jump\\n.LCB%=:\";
-         default: return \"b%D0\\t.LCB%=\;bl\\t%l3\\t%@far jump\\n.LCB%=:\";
-       }
-    }
-  else
-    {
-      rtx op[3];
-
-      if (which_alternative == 1)
-       {
-         op[0] = operands[1];
-         op[1] = GEN_INT ((1 << INTVAL (operands[2])) - 1);
-         output_asm_insn (\"tst\\t%0, %1\", op);
-       }
-      else
-       {
-         op[0] = operands[4];
-         op[1] = operands[1];
-         op[2] = GEN_INT (32 - INTVAL (operands[2]));
-         output_asm_insn (\"lsls\\t%0, %1, %2\", op);
-       }
+(define_peephole2
+  [(set (match_operand:CC_NOOV 0 "cc_register" "")
+       (compare:CC_NOOV (zero_extract:SI
+                         (match_operand:SI 1 "low_register_operand" "")
+                         (const_int 1)
+                         (match_operand:SI 2 "const_int_operand" ""))
+                        (const_int 0)))
+   (match_scratch:SI 3 "l")
+   (set (pc)
+       (if_then_else (match_operator:CC_NOOV 4 "equality_operator"
+                      [(match_dup 0) (const_int 0)])
+                     (match_operand 5 "" "")
+                     (match_operand 6 "" "")))]
+  "TARGET_THUMB2
+   && (INTVAL (operands[2]) >= 0 && INTVAL (operands[2]) < 32)"
+  [(parallel [(set (match_dup 0)
+                  (compare:CC_NOOV (ashift:SI (match_dup 1) (match_dup 2))
+                                   (const_int 0)))
+             (clobber (match_dup 3))])
+   (set (pc)
+       (if_then_else (match_op_dup 4 [(match_dup 0) (const_int 0)])
+                     (match_dup 5) (match_dup 6)))]
+  "
+  operands[2] = GEN_INT (31 - INTVAL (operands[2]));
+  operands[4] = gen_rtx_fmt_ee (GET_CODE (operands[4]) == NE ? LT : GE,
+                               VOIDmode, operands[0], const0_rtx);
+  ")
 
-      switch (get_attr_length (insn))
-       {
-         case 6:  return \"b%d0\\t%l3\";
-         case 8:  return \"b%D0\\t.LCB%=\;b\\t%l3\\t%@long jump\\n.LCB%=:\";
-         default: return \"b%D0\\t.LCB%=\;bl\\t%l3\\t%@far jump\\n.LCB%=:\";
-       }
-    }
-  }"
-  [(set (attr "far_jump")
-       (if_then_else
-           (and (ge (minus (match_dup 3) (pc)) (const_int -2040))
-                (le (minus (match_dup 3) (pc)) (const_int 2048)))
-           (const_string "no")
-           (const_string "yes")))
-   (set (attr "length")
-       (if_then_else
-         (eq (symbol_ref ("which_alternative"))
-                         (const_int 0))
-         (if_then_else
-           (and (ge (minus (match_dup 3) (pc)) (const_int -250))
-                (le (minus (match_dup 3) (pc)) (const_int 256)))
-           (const_int 4)
-           (if_then_else
-               (and (ge (minus (match_dup 3) (pc)) (const_int -2040))
-                    (le (minus (match_dup 3) (pc)) (const_int 2048)))
-               (const_int 6)
-               (const_int 8)))
-         (if_then_else
-           (and (ge (minus (match_dup 3) (pc)) (const_int -250))
-                (le (minus (match_dup 3) (pc)) (const_int 256)))
-           (const_int 6)
-           (if_then_else
-               (and (ge (minus (match_dup 3) (pc)) (const_int -2040))
-                    (le (minus (match_dup 3) (pc)) (const_int 2048)))
-               (const_int 8)
-               (const_int 10)))))]
-)