[committed] Fix C++ ICE with UDRs (PR c++/58874)

Jakub Jelinek jakub@redhat.com
Tue Nov 26 23:27:00 GMT 2013


Hi!

The problem on this testcase was that
start_preparsed_function called maybe_begin_member_template_processing
but finish_function wasn't called with matching flag and thus
didn't call maybe_end_member_template_processing and we ended up with
processing_template_decl even when it shouldn't be set.

Fixed thusly, bootstrapped/regtested on x86_64-linux and i686-linux,
committed to trunk.

2013-11-26  Jakub Jelinek  <jakub@redhat.com>

	PR c++/58874
	* parser.c (cp_parser_late_parsing_for_member): For OpenMP UDRs
	pass 2 instead of 0 to finish_function.

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

--- gcc/cp/parser.c.jj	2013-11-25 10:20:12.000000000 +0100
+++ gcc/cp/parser.c	2013-11-26 17:13:16.104183792 +0100
@@ -23275,7 +23275,7 @@ cp_parser_late_parsing_for_member (cp_pa
 	{
 	  parser->lexer->in_pragma = true;
 	  cp_parser_omp_declare_reduction_exprs (member_function, parser);
-	  finish_function (0);
+	  finish_function (/*inline*/2);
 	  cp_check_omp_declare_reduction (member_function);
 	}
       else
--- gcc/testsuite/g++.dg/gomp/pr58874.C.jj	2013-11-26 17:15:35.534470121 +0100
+++ gcc/testsuite/g++.dg/gomp/pr58874.C	2013-11-26 17:18:44.487502021 +0100
@@ -0,0 +1,14 @@
+// PR c++/58874
+// { dg-do compile }
+// { dg-options "-fopenmp" }
+
+struct A
+{
+  template<int> struct B
+  {
+    #pragma omp declare reduction (x : int : omp_out |= omp_in)
+  };
+};
+
+#pragma omp declare reduction (y : long : omp_out |= omp_in) \
+	initializer (omp_priv = 0)

	Jakub



More information about the Gcc-patches mailing list