We now properly optimize this testcase and no longer diagnose
a bogus uninit use.

Tested on x86_64-unknown-linux-gnu, pushed.

        PR tree-optimization/101912
        * gcc.dg/uninit-pr101912.c: New testcase.
---
 gcc/testsuite/gcc.dg/uninit-pr101912.c | 21 +++++++++++++++++++++
 1 file changed, 21 insertions(+)
 create mode 100644 gcc/testsuite/gcc.dg/uninit-pr101912.c

diff --git a/gcc/testsuite/gcc.dg/uninit-pr101912.c 
b/gcc/testsuite/gcc.dg/uninit-pr101912.c
new file mode 100644
index 00000000000..1550c03436d
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/uninit-pr101912.c
@@ -0,0 +1,21 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -Wuninitialized" } */
+
+int getint (void);
+int
+tzloadbody (void)
+{
+  int n = getint ();
+  int prevcorr;
+  int leapcnt = 0;
+  for (int i = 0; i < n; i++)
+    {
+      int corr = getint ();
+      if (corr < 1 || (corr == 1 && !(leapcnt == 0 || (prevcorr < corr ? corr 
== prevcorr + 1 : (corr == prevcorr || corr == prevcorr - 1))))) /* { dg-bogus 
"uninitialized" } */
+       return -1;
+
+      prevcorr = corr;
+      leapcnt++;
+    }
+  return leapcnt;
+}
-- 
2.35.3

Reply via email to