]> gcc.gnu.org Git - gcc.git/commitdiff
re PR middle-end/39732 (-fprofile-generate -O1: ICE: verify_stmts failed, ADDRESSABLE...
authorRichard Guenther <rguenther@suse.de>
Sat, 11 Apr 2009 10:19:55 +0000 (10:19 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Sat, 11 Apr 2009 10:19:55 +0000 (10:19 +0000)
2009-04-11  Richard Guenther  <rguenther@suse.de>

PR middle-end/39732
* tree-inline.c (declare_return_variable): Mark DECL_BY_REFERENCE
return variables as TREE_ADDRESSABLE.

* g++.dg/torture/pr39732.C: New testcase.

From-SVN: r145954

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/torture/pr39732.C [new file with mode: 0644]
gcc/tree-inline.c

index 3d6b046edc5ddd95ba04a1eb147e14d7bab7c620..7d9e7384ff373bebe784c4ce6361c3784fb88252 100644 (file)
@@ -1,3 +1,9 @@
+2009-04-11  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/39732
+       * tree-inline.c (declare_return_variable): Mark DECL_BY_REFERENCE
+       return variables as TREE_ADDRESSABLE.
+
 2009-04-11  Richard Guenther  <rguenther@suse.de>
 
        PR tree-optimization/39713
index 108e17d07f1aed3df63e6cb01eb4e9714a780cfa..aedd017f189aa0235f7e6a77c977d9ffb75e56a2 100644 (file)
@@ -1,3 +1,8 @@
+2009-04-11  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/39732
+       * g++.dg/torture/pr39732.C: New testcase.
+
 2009-04-11  Daniel Franke  <franke.daniel@gmail.com>
 
        * gfortran.dg/whole_file_5.f90: New.
diff --git a/gcc/testsuite/g++.dg/torture/pr39732.C b/gcc/testsuite/g++.dg/torture/pr39732.C
new file mode 100644 (file)
index 0000000..4184175
--- /dev/null
@@ -0,0 +1,29 @@
+/* { dg-do compile } */
+/* { dg-options "-fprofile-generate" } */
+
+template<class _CharT>     struct char_traits;
+template<typename _OI>
+_OI __copy_move_a2(_OI __result);
+template<typename _OI>     inline _OI
+copy(_OI __result)
+{
+  return __copy_move_a2 (__result);
+}
+template<typename _CharT, typename _Traits>
+class basic_ostream     { };
+template<typename _Tp, typename _CharT = char, typename _Traits = char_traits<_CharT> >
+class ostream_iterator      {
+    typedef basic_ostream<_CharT, _Traits> ostream_type;
+    ostream_type* _M_stream;
+    const _CharT* _M_string;
+public:
+    ostream_iterator(ostream_type& __s, const _CharT* __c)
+       : _M_stream(&__s), _M_string(__c) { }
+    ostream_iterator(const ostream_iterator& __obj)
+       : _M_stream(__obj._M_stream), _M_string(__obj._M_string) { }
+};
+int f(void)
+{
+  basic_ostream<char, char_traits<char> > os;
+  copy(ostream_iterator<const int>(os, ","));
+}
index e1e1f1154d1b003ec4b7949e9ac4f8da02bd3260..686611d7c5625c27261a1b9fbf0f63bc52c3e47f 100644 (file)
@@ -2386,7 +2386,10 @@ declare_return_variable (copy_body_data *id, tree return_slot, tree modify_dest,
   STRIP_USELESS_TYPE_CONVERSION (use);
 
   if (DECL_BY_REFERENCE (result))
-    var = build_fold_addr_expr (var);
+    {
+      TREE_ADDRESSABLE (var) = 1;
+      var = build_fold_addr_expr (var);
+    }
 
  done:
   /* Register the VAR_DECL as the equivalent for the RESULT_DECL; that
This page took 0.130052 seconds and 5 git commands to generate.