From: Jakub Jelinek Date: Wed, 15 Dec 2021 09:27:08 +0000 (+0100) Subject: openmp: Avoid calling operand_equal_p on OMP_CLAUSEs [PR103704] X-Git-Tag: upstream/12.2.0~2705 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c0e34451ae582c901a2df08498b36f68ae401f0a;p=platform%2Fupstream%2Fgcc.git openmp: Avoid calling operand_equal_p on OMP_CLAUSEs [PR103704] On OMP_CLAUSEs we reuse TREE_TYPE as CP_OMP_CLAUSE_INFO in the C++ FE. This confuses the hashing code that operand_equal_p does when checking. There is really no reason to compare OMP_CLAUSEs against expressions like captured this, they will never compare equal. 2021-12-15 Jakub Jelinek PR c++/103704 * semantics.c (finish_omp_target_clauses_r): For OMP_CLAUSEs just walk subtrees. * g++.dg/gomp/pr103704.C: New test. --- diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index d8b20ff..356fb83 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -9325,6 +9325,9 @@ finish_omp_target_clauses_r (tree *tp, int *walk_subtrees, void *ptr) return NULL_TREE; } + if (TREE_CODE (t) == OMP_CLAUSE) + return NULL_TREE; + if (current_object) { tree this_expr = TREE_OPERAND (current_object, 0); diff --git a/gcc/testsuite/g++.dg/gomp/pr103704.C b/gcc/testsuite/g++.dg/gomp/pr103704.C new file mode 100644 index 0000000..68767c4 --- /dev/null +++ b/gcc/testsuite/g++.dg/gomp/pr103704.C @@ -0,0 +1,19 @@ +// PR c++/103704 +// { dg-do compile } + +struct S { int a; }; + +template +struct U : public T { + T a; + U () + { +#pragma omp target +#pragma omp teams +#pragma omp distribute private(a) + for (int k = 0; k < 1; ++k) + ; + } +}; + +struct V : public U { V () : U () {} };