+2010-10-04 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/45876
+ * fold-const.c (fold_binary_loc) <case BIT_AND_EXPR>: Use
+ arg0's type or its unsigned counterpart as utype. Convert
+ arg1 to utype unconditionally.
+
2010-10-04 Julian Brown <julian@codesourcery.com>
* expr.c (expand_assignment): Add assertion to prevent emitting
|| (TREE_CODE (arg0) != NEGATE_EXPR
&& pmop[1] != TREE_OPERAND (arg0, 1)))
{
- tree utype = type;
+ tree utype = TREE_TYPE (arg0);
if (! TYPE_OVERFLOW_WRAPS (TREE_TYPE (arg0)))
{
/* Perform the operations in a type that has defined
overflow behavior. */
- utype = unsigned_type_for (type);
+ utype = unsigned_type_for (TREE_TYPE (arg0));
if (pmop[0] != NULL)
pmop[0] = fold_convert_loc (loc, utype, pmop[0]);
if (pmop[1] != NULL)
tem = fold_build2_loc (loc, MINUS_EXPR, utype,
pmop[0], pmop[1]);
/* TEM is now the new binary +, - or unary - replacement. */
- if (utype == type)
- return fold_build2_loc (loc, BIT_AND_EXPR, type,
- tem, arg1);
- else
- {
- tem = fold_build2_loc (loc, BIT_AND_EXPR, utype, tem,
- fold_convert_loc (loc, utype,
- arg1));
- return fold_convert_loc (loc, type, tem);
- }
+ tem = fold_build2_loc (loc, BIT_AND_EXPR, utype, tem,
+ fold_convert_loc (loc, utype, arg1));
+ return fold_convert_loc (loc, type, tem);
}
}
}