On Fri, 8 Feb 2019 at 20:00, Richard Biener <rguent...@suse.de> wrote:
>
> On February 8, 2019 7:22:48 PM GMT+01:00, Jakub Jelinek <ja...@redhat.com> 
> wrote:
> >Hi!
> >
> >The following testcase distilled from
> >https://gcc.gnu.org/bugzilla/show_bug.cgi?id=88739#c0
> >aborts on s390x-linux when compiled with trunk -O2 with r268332
> >reverted (or
> >e.g. with -O2 and gcc 7.x) and succeeds with trunk -O2, or -O0 with any
> >of
> >those compilers.  Tested also on x86_64-linux with -m32/-m64 make
> >check.
> >
> >Ok for trunk?
>
> OK and thanks for the testcase!
>
> Richard.
>
> >2019-02-08  Jakub Jelinek  <ja...@redhat.com>
> >
> >       PR tree-optimization/88739
> >       * gcc.c-torture/execute/pr88739.c: New test.
> >
> >--- gcc/testsuite/gcc.c-torture/execute/pr88739.c.jj   2019-01-27
> >12:44:12.526219828 +0100
> >+++ gcc/testsuite/gcc.c-torture/execute/pr88739.c      2019-02-08
> >18:48:25.880556579 +0100
> >@@ -0,0 +1,59 @@
> >+/* PR tree-optimization/88739 */
> >+#if __SIZEOF_SHORT__ == 2 &&  __SIZEOF_INT__ == 4 && __CHAR_BIT__ == 8
> >+struct A
> >+{
> >+  unsigned int a, b, c;
> >+  unsigned int d : 30;
> >+  unsigned int e : 2;
> >+};
> >+
> >+union U
> >+{
> >+  struct A f;
> >+  unsigned int g[4];
> >+  unsigned short h[8];
> >+  unsigned char i[16];
> >+};
> >+volatile union U v = { .f.d = 0x4089 };
> >+
> >+__attribute__((noipa)) void
> >+bar (int x)
> >+{
> >+  static int i;
> >+  switch (i++)
> >+    {
> >+    case 0: if (x != v.f.d) __builtin_abort (); break;
> >+    case 1: if (x != v.f.e) __builtin_abort (); break;
> >+    case 2: if (x != v.g[3]) __builtin_abort (); break;
> >+    case 3: if (x != v.h[6]) __builtin_abort (); break;
> >+    case 4: if (x != v.h[7]) __builtin_abort (); break;
> >+    default: __builtin_abort (); break;
> >+    }
> >+}
> >+
> >+void
> >+foo (unsigned int x)
> >+{
> >+  union U u;
> >+  u.f.d = x >> 2;
> >+  u.f.e = 0;
> >+  bar (u.f.d);
> >+  bar (u.f.e);
> >+  bar (u.g[3]);
> >+  bar (u.h[6]);
> >+  bar (u.h[7]);
> >+}
> >+
> >+int
> >+main ()
> >+{
> >+  foo (0x10224);
> >+  return 0;
> >+}
> >+#else
> >+int
> >+main ()
> >+{
> >+  return 0;
> >+}
> >+#endif
> >
> >       Jakub
>

Looks more elaborate than what I was deriving from #c0. I'll let you
know if I see some problems on aarch64_be or armeb.

Thanks,

Christophe

Reply via email to