openmp: Don't ICE on detach clause with erroneous decl [PR98742]
authorJakub Jelinek <jakub@redhat.com>
Wed, 20 Jan 2021 07:35:20 +0000 (08:35 +0100)
committerJakub Jelinek <jakub@redhat.com>
Wed, 20 Jan 2021 07:38:46 +0000 (08:38 +0100)
Similarly to how we handle erroneous operands to e.g. allocate clause,
this change just removes those clauses instead of accessing TYPE_MAIN_VARIANT
of its type, which doesn't work on error_mark_node.  Also, just for good
measure, bails out if TYPE_NAME is NULL.

2021-01-20  Jakub Jelinek  <jakub@redhat.com>

PR c++/98742
* semantics.c (finish_omp_clauses) <case OMP_CLAUSE_DETACH>: If
error_operand_p, remove clause without further checking.  Check
for non-NULL TYPE_NAME.

* c-c++-common/gomp/task-detach-2.c: New test.

gcc/cp/semantics.c
gcc/testsuite/c-c++-common/gomp/task-detach-2.c [new file with mode: 0644]

index c8a6283b1206f5b60e3077ab4daf21ee27d85167..244fc70d02d1579257455557dc95efba4ca23344 100644 (file)
@@ -7430,12 +7430,18 @@ finish_omp_clauses (tree clauses, enum c_omp_region_type ort)
              remove = true;
              break;
            }
+         else if (error_operand_p (t))
+           {
+             remove = true;
+             break;
+           }
          else
            {
              tree type = TYPE_MAIN_VARIANT (TREE_TYPE (t));
              if (!type_dependent_expression_p (t)
                  && (!INTEGRAL_TYPE_P (type)
                      || TREE_CODE (type) != ENUMERAL_TYPE
+                     || TYPE_NAME (type) == NULL_TREE
                      || (DECL_NAME (TYPE_NAME (type))
                          != get_identifier ("omp_event_handle_t"))))
                {
diff --git a/gcc/testsuite/c-c++-common/gomp/task-detach-2.c b/gcc/testsuite/c-c++-common/gomp/task-detach-2.c
new file mode 100644 (file)
index 0000000..2d197d2
--- /dev/null
@@ -0,0 +1,9 @@
+/* PR c++/98742 */
+/* { dg-do compile } */
+
+void
+foo ()
+{
+#pragma omp task detach(0)     /* { dg-error "before numeric constant" } */
+  ;
+}