]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR c++/38908 (Unexplained "'<anonymous>' is used uninitialized in this function...
authorRichard Guenther <rguenther@suse.de>
Wed, 28 Jan 2009 09:36:41 +0000 (09:36 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Wed, 28 Jan 2009 09:36:41 +0000 (09:36 +0000)
2009-01-28  Richard Guenther  <rguenther@suse.de>

PR middle-end/38908
* tree-ssa.c (warn_uninitialized_var): Do not warn for seemingly
uninitialized aggregate uses in call arguments.

* g++.dg/warn/Wuninitialized-2.C: New testcase.

From-SVN: r143722

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/warn/Wuninitialized-2.C [new file with mode: 0644]
gcc/tree-ssa.c

index 2727cc2ff2340af4e789079736d006b0eeef6a68..88de5d2c5abeb889343f44b602c2a2f00e8b7920 100644 (file)
@@ -1,3 +1,9 @@
+2009-01-28  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/38908
+       * tree-ssa.c (warn_uninitialized_var): Do not warn for seemingly
+       uninitialized aggregate uses in call arguments.
+
 2009-01-28  Paolo Bonzini  <bonzini@gnu.org>
 
        PR tree-optimization/38984
index 7721a56f2bff82abbbfbf9a9f52b9d91501d4f75..2db69bee90cf9df4b0b706daa521135f64c4053a 100644 (file)
@@ -1,3 +1,8 @@
+2009-01-28  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/38908
+       * g++.dg/warn/Wuninitialized-2.C: New testcase.
+
 2009-01-28  Paolo Bonzini  <bonzini@gnu.org>
 
        PR tree-optimization/38984
diff --git a/gcc/testsuite/g++.dg/warn/Wuninitialized-2.C b/gcc/testsuite/g++.dg/warn/Wuninitialized-2.C
new file mode 100644 (file)
index 0000000..2b6f925
--- /dev/null
@@ -0,0 +1,53 @@
+/* { dg-do compile } */
+/* { dg-options "-O -Wuninitialized" } */
+
+struct S8 { template<typename T> S8(T) { } };
+
+template<typename T> struct S10;
+template<typename T> struct S10<T()> { typedef T S12; typedef S8 S1(); };
+
+template<typename T> struct S3 { };
+template<typename T> struct S11 { S11(S3<T>); };
+
+struct S2
+{
+  template<typename T> operator S11<T>() { return S11<T>(S5<T>()); }
+  template<typename T> struct S5:public S3<T>
+  {
+    virtual typename S10<T>::S12 S13() {
+      return 0;
+    }
+  };
+};
+
+template<typename T> S11<T> S6(S3<T>) { return S11<T>(S3<T>()); }
+template<typename S12> struct S7 { typedef S12 S15(); };
+
+struct S4
+{
+  template<typename T> operator S11<T>()
+  {
+    struct S14:public S3<T>
+    { 
+      S14(S2 x):S11_(x) { }
+      S11<typename S7<typename S10<T>::S12>::S15> S11_;
+    };
+    return S6(S14(S11_));
+  }
+  S2 S11_;
+};
+
+struct S9
+{
+  template<typename F> operator S11<F>() { return S11<F>(S14<F>(S11_)); }
+  template<typename F> struct S14:public S3<F>
+  {
+    S14(S4 x):S11_(x) { }
+    S11<typename S10<F>::S1> S11_;
+  };
+  S4 S11_;
+};
+
+void S15(S11<void()>);
+void S16() { S9 x; S15(x); }
+
index 91cbc1950018995abcea1e12bf4152adb0118fe1..75e4685149f771ab85cf359b0ef9794d8d3e4753 100644 (file)
@@ -1496,9 +1496,13 @@ warn_uninitialized_var (tree *tp, int *walk_subtrees, void *data_)
             || !gimple_aliases_computed_p (cfun))
          return NULL_TREE;
 
+       /* If the load happens as part of a call do not warn about it.  */
+       if (is_gimple_call (data->stmt))
+         return NULL_TREE;
+
        vuse = SINGLE_SSA_USE_OPERAND (data->stmt, SSA_OP_VUSE);
        if (vuse == NULL_USE_OPERAND_P)
-           return NULL_TREE;
+         return NULL_TREE;
 
        op = USE_FROM_PTR (vuse);
        if (t != SSA_NAME_VAR (op)