OSDN Git Service

PR c++/48632
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 18 Apr 2011 21:55:07 +0000 (21:55 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 18 Apr 2011 21:55:07 +0000 (21:55 +0000)
* parser.c (cp_parser_omp_for_loop): Don't use cp_parser_omp_for_incr
for type dependent pointers.

* g++.dg/gomp/pr48632.C: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@172674 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/gomp/pr48632.C [new file with mode: 0644]

index 672485e..e7d75e8 100644 (file)
@@ -1,3 +1,9 @@
+2011-04-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/48632
+       * parser.c (cp_parser_omp_for_loop): Don't use cp_parser_omp_for_incr
+       for type dependent pointers.
+
 2011-04-18  Jim Meyering  <meyering@redhat.com>
 
        * pt.c (type_unification_real): Fix typo in comment: s/in in/in/.
index 2c7ace6..7d3121c 100644 (file)
@@ -24496,7 +24496,8 @@ cp_parser_omp_for_loop (cp_parser *parser, tree clauses, tree *par_clauses)
          /* If decl is an iterator, preserve the operator on decl
             until finish_omp_for.  */
          if (decl
-             && (type_dependent_expression_p (decl)
+             && ((type_dependent_expression_p (decl)
+                  && !POINTER_TYPE_P (TREE_TYPE (decl)))
                  || CLASS_TYPE_P (TREE_TYPE (decl))))
            incr = cp_parser_omp_for_incr (parser, decl);
          else
index 5295ec5..7f1ff58 100644 (file)
@@ -1,3 +1,8 @@
+2011-04-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/48632
+       * g++.dg/gomp/pr48632.C: New test.
+
 2011-04-18  Uros Bizjak  <ubizjak@gmail.com>
 
        * gcc.target/i386/sse2-maskmovdqu.c: New test.
diff --git a/gcc/testsuite/g++.dg/gomp/pr48632.C b/gcc/testsuite/g++.dg/gomp/pr48632.C
new file mode 100644 (file)
index 0000000..afa8b18
--- /dev/null
@@ -0,0 +1,22 @@
+// PR c++/48632
+// { dg-do compile }
+// { dg-options "-fopenmp" }
+
+template<typename T>
+void
+foo (T *x, T *y, unsigned z)
+{
+#pragma omp parallel for
+  for (T *p = x; p < y; p += z)
+    ;
+#pragma omp parallel for
+  for (T *p = y; p > x; p -= z)
+    ;
+}
+
+int
+main ()
+{
+  char buf[10];
+  foo (&buf[0], &buf[9], 1);
+}