re PR c++/90950 (OpenMP clause handling rejecting references to incomplete types...
authorJakub Jelinek <jakub@redhat.com>
Fri, 21 Jun 2019 06:46:45 +0000 (08:46 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 21 Jun 2019 06:46:45 +0000 (08:46 +0200)
PR c++/90950
* semantics.c (finish_omp_clauses): Don't reject references to
incomplete types if processing_template_decl.

* g++.dg/gomp/lastprivate-1.C: New test.

From-SVN: r272543

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/gomp/lastprivate-1.C [new file with mode: 0644]

index 5b65926..c958318 100644 (file)
@@ -1,3 +1,9 @@
+2019-06-21  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/90950
+       * semantics.c (finish_omp_clauses): Don't reject references to
+       incomplete types if processing_template_decl.
+
 2019-06-19  Marek Polacek  <polacek@redhat.com>
 
        PR c++/60364 - noreturn after first decl not diagnosed.
index 6cf3af7..92c4875 100644 (file)
@@ -7831,7 +7831,8 @@ finish_omp_clauses (tree clauses, enum c_omp_region_type ort)
          t = require_complete_type (t);
          if (t == error_mark_node)
            remove = true;
-         else if (TYPE_REF_P (TREE_TYPE (t))
+         else if (!processing_template_decl
+                  && TYPE_REF_P (TREE_TYPE (t))
                   && !complete_type_or_else (TREE_TYPE (TREE_TYPE (t)), t))
            remove = true;
        }
index 221fb69..ab8cc80 100644 (file)
@@ -1,5 +1,8 @@
 2019-06-21  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/90950
+       * g++.dg/gomp/lastprivate-1.C: New test.
+
        * gcc.dg/vect/vect-simd-11.c: New test.
        * gcc.target/i386/sse2-vect-simd-11.c: New test.
        * gcc.target/i386/avx2-vect-simd-11.c: New test.
diff --git a/gcc/testsuite/g++.dg/gomp/lastprivate-1.C b/gcc/testsuite/g++.dg/gomp/lastprivate-1.C
new file mode 100644 (file)
index 0000000..ce25e1a
--- /dev/null
@@ -0,0 +1,16 @@
+// PR c++/90950
+// { dg-do compile }
+
+template <typename T>
+T
+foo (void)
+{
+  T y = 0;
+  T &x = y;
+  #pragma omp parallel for lastprivate (x)
+  for (int i = 0; i < 8; ++i)
+    x = i;
+  return x;
+}
+
+int a = foo<int> ();