Hi!

This wrong-code issue has been fixed with r15-7249.
We still emit warnings which are questionable and perhaps we'd
get better generated code if niters determined the loop has only a single
iteration without UB and we'd punt on vectorizing it (or unrolling).

Tested on x86_64-linux -m32/-m64, committed to trunk as obvious.

2025-01-31  Jakub Jelinek  <ja...@redhat.com>

        PR middle-end/117498
        * gcc.c-torture/execute/pr117498.c: New test.

--- gcc/testsuite/gcc.c-torture/execute/pr117498.c.jj
+++ gcc/testsuite/gcc.c-torture/execute/pr117498.c
@@ -0,0 +1,35 @@
+/* PR middle-end/117498 */
+
+int a, d, f;
+char g;
+volatile int c = 1;
+
+int
+foo ()
+{
+  if (c == 0)
+    return -1;
+  return 1;
+}
+
+void
+bar (int h, int i, char *k, char *m)
+{
+  for (; d < i; d += 2)
+    for (int j = 0; j < h; j++)
+      m[j] = k[4 * j];
+}
+
+void
+baz (long h)
+{
+  char n = 0;
+  bar (h, 4, &n, &g);
+}
+
+int
+main ()
+{
+  f = foo ();
+  baz ((unsigned char) f - 4);
+}


        Jakub

Reply via email to