* simplify-rtx.c (simplify_unary_operation_1) <TRUNCATE>: When
authornemet <nemet@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 3 Apr 2006 18:12:15 +0000 (18:12 +0000)
committernemet <nemet@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 3 Apr 2006 18:12:15 +0000 (18:12 +0000)
trying to remove TRUNCATE check if all bits outside the new mode
are identical to the sign bit.

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

gcc/ChangeLog
gcc/simplify-rtx.c

index b264035..d157632 100644 (file)
@@ -1,3 +1,9 @@
+2006-04-03  Adam Nemet  <anemet@caviumnetworks.com>
+
+       * simplify-rtx.c (simplify_unary_operation_1) <TRUNCATE>: When
+       trying to remove TRUNCATE check if all bits outside the new mode
+       are identical to the sign bit.
+
 2006-04-03  Jeff Law  <law@redhat.com>
 
        * tree-ssa-dom.c (propagate_rhs_into_lhs): Avoid useless folding
index cac77ad..0ce033d 100644 (file)
@@ -656,7 +656,8 @@ simplify_unary_operation_1 (enum rtx_code code, enum machine_mode mode, rtx op)
       if ((TRULY_NOOP_TRUNCATION (GET_MODE_BITSIZE (mode),
                                 GET_MODE_BITSIZE (GET_MODE (op)))
           ? (num_sign_bit_copies (op, GET_MODE (op))
-             >= (unsigned int) (GET_MODE_BITSIZE (mode) + 1))
+             > (unsigned int) (GET_MODE_BITSIZE (GET_MODE (op))
+                               - GET_MODE_BITSIZE (mode)))
           : truncated_to_mode (mode, op))
          && ! (GET_CODE (op) == LSHIFTRT
                && GET_CODE (XEXP (op, 0)) == MULT))