]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
sccvn: Punt on ref->size not multiple of 8 for memset (, 123, ) in 9.x [PR93945]
authorJakub Jelinek <jakub@redhat.com>
Thu, 27 Feb 2020 10:21:52 +0000 (11:21 +0100)
committerJakub Jelinek <jakub@redhat.com>
Thu, 27 Feb 2020 10:21:52 +0000 (11:21 +0100)
And here is the corresponding 9.x change where we the patch just punts if
ref->size is not whole bytes, like we already punt if offseti is not byte
aligned.

2020-02-27  Jakub Jelinek  <jakub@redhat.com>

PR tree-optimization/93945
* tree-ssa-sccvn.c (vn_reference_lookup_3): For memset with non-zero
second operand, require ref->size to be a multiple of BITS_PER_UNIT.

* gcc.c-torture/execute/pr93945.c: New test.

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/execute/pr93945.c [new file with mode: 0644]
gcc/tree-ssa-sccvn.c

index d09456d27fa083ac5743d7fc51f61c08ef1dfeba..c106e96c97883465b686d474b601eb2b1f582bac 100644 (file)
@@ -1,3 +1,9 @@
+2020-02-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/93945
+       * tree-ssa-sccvn.c (vn_reference_lookup_3): For memset with non-zero
+       second operand, require ref->size to be a multiple of BITS_PER_UNIT.
+
 2020-02-26  Carl Love  <cel@us.ibm.com>
 
        PR target/91276
index 845976a9a3dfd4b65b0a326c133529d4f3e89ce4..899b90d2e8c08edead0088216eef413b5cdcc283 100644 (file)
@@ -1,3 +1,8 @@
+2020-02-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/93945
+       * gcc.c-torture/execute/pr93945.c: New test.
+
 2020-02-26  Marek Polacek  <polacek@redhat.com>
            Jakub Jelinek  <jakub@redhat.com>
 
diff --git a/gcc/testsuite/gcc.c-torture/execute/pr93945.c b/gcc/testsuite/gcc.c-torture/execute/pr93945.c
new file mode 100644 (file)
index 0000000..99e455c
--- /dev/null
@@ -0,0 +1,45 @@
+/* PR tree-optimization/93945 */
+
+union U { char a[8]; struct S { unsigned int b : 8, c : 13, d : 11; } e; } u;
+
+__attribute__((noipa)) int
+foo (void)
+{
+  __builtin_memset (&u.a, 0xf4, sizeof (u.a));
+  return u.e.c;
+}
+
+__attribute__((noipa)) int
+bar (void)
+{
+  asm volatile ("" : : "g" (&u) : "memory");
+  return u.e.c;
+}
+
+__attribute__((noipa)) int
+baz (void)
+{
+  __builtin_memset (&u.a, 0xf4, sizeof (u.a));
+  return u.e.d;
+}
+
+__attribute__((noipa)) int
+qux (void)
+{
+  asm volatile ("" : : "g" (&u) : "memory");
+  return u.e.d;
+}
+
+int
+main ()
+{
+  int a = foo ();
+  int b = bar ();
+  if (a != b)
+    __builtin_abort ();
+  a = baz ();
+  b = qux ();
+  if (a != b)
+    __builtin_abort ();
+  return 0;
+}
index aea11bdebba9788054973a0968ceb71acb35788e..32f45c95cdf2613467c0f7cce66e39ca5c392e97 100644 (file)
@@ -2113,7 +2113,8 @@ vn_reference_lookup_3 (ao_ref *ref, tree vuse, void *data_,
               || (INTEGRAL_TYPE_P (vr->type) && known_eq (ref->size, 8)))
              && CHAR_BIT == 8 && BITS_PER_UNIT == 8
              && offset.is_constant (&offseti)
-             && offseti % BITS_PER_UNIT == 0))
+             && offseti % BITS_PER_UNIT == 0
+             && multiple_p (ref->size, BITS_PER_UNIT)))
       && poly_int_tree_p (gimple_call_arg (def_stmt, 2))
       && (TREE_CODE (gimple_call_arg (def_stmt, 0)) == ADDR_EXPR
          || TREE_CODE (gimple_call_arg (def_stmt, 0)) == SSA_NAME))