* builtins.c (fold_builtin_memset): Check c is INTEGER_CST instead
of host_integerp check. Use TREE_INT_CST_LOW instead of tree_low_cst.
* gcc.dg/pr46647.c: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@167170
138bc75d-0d04-0410-961f-
82ee72b054a4
2010-11-26 Jakub Jelinek <jakub@redhat.com>
+ PR middle-end/46647
+ * builtins.c (fold_builtin_memset): Check c is INTEGER_CST instead
+ of host_integerp check. Use TREE_INT_CST_LOW instead of tree_low_cst.
+
PR bootstrap/45700
* tree.h (build1_stat_loc, build2_stat_loc, build3_stat_loc,
build4_stat_loc, build5_stat_loc, build6_stat_loc): New inlines.
if (integer_zerop (len))
return omit_one_operand_loc (loc, type, dest, c);
- if (! host_integerp (c, 1) || TREE_SIDE_EFFECTS (dest))
+ if (TREE_CODE (c) != INTEGER_CST || TREE_SIDE_EFFECTS (dest))
return NULL_TREE;
var = dest;
if (CHAR_BIT != 8 || BITS_PER_UNIT != 8 || HOST_BITS_PER_WIDE_INT > 64)
return NULL_TREE;
- cval = tree_low_cst (c, 1);
+ cval = TREE_INT_CST_LOW (c);
cval &= 0xff;
cval |= cval << 8;
cval |= cval << 16;
+2010-11-26 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/46647
+ * gcc.dg/pr46647.c: New test.
+
2010-11-25 Janus Weil <janus@gcc.gnu.org>
PR fortran/46581
--- /dev/null
+/* PR middle-end/46647 */
+/* { dg-do compile } */
+/* { dg-options "-O2 -fdump-tree-optimized" } */
+
+int a;
+
+int
+func1 (void)
+{
+ __builtin_memset (&a, -1, sizeof (a));
+ return 0;
+}
+
+int
+func2 (void)
+{
+ __builtin_memset (&a, 123, sizeof (a));
+ return 0;
+}
+
+int
+func3 (void)
+{
+ __builtin_memset (&a, 0, sizeof (a));
+ return 0;
+}
+
+/* { dg-final { scan-tree-dump-not "memset" "optimized" } } */
+/* { dg-final { cleanup-tree-dump "optimized" } } */