]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c: Reject gimple and rtl functions as needed functions [PR121421]
authorAndrew Pinski <andrew.pinski@oss.qualcomm.com>
Tue, 16 Sep 2025 05:37:44 +0000 (22:37 -0700)
committerAndrew Pinski <andrew.pinski@oss.qualcomm.com>
Tue, 16 Sep 2025 22:28:48 +0000 (15:28 -0700)
These two don't make sense as nested functions as they both don't handle
the unnesting and/or have support for the static chain.

So let's reject them.

Bootstrapped and tested on x86_64-linux-gnu.

PR c/121421

gcc/c/ChangeLog:

* c-parser.cc (c_parser_declaration_or_fndef): Error out for gimple
and rtl functions as nested functions.

gcc/testsuite/ChangeLog:

* gcc.dg/gimplefe-error-16.c: New test.

Signed-off-by: Andrew Pinski <andrew.pinski@oss.qualcomm.com>
gcc/c/c-parser.cc
gcc/testsuite/gcc.dg/gimplefe-error-16.c [new file with mode: 0644]

index f1aaab12e6e8a8c3fee11c702875447d624bafc3..df44a915ed4fb23e75fd634478495b02b8d4beb7 100644 (file)
@@ -3222,7 +3222,7 @@ c_parser_declaration_or_fndef (c_parser *parser, bool fndef_ok,
       else
        fnbody = c_parser_compound_statement (parser, &endloc);
       tree fndecl = current_function_decl;
-      if (nested)
+      if (nested && specs->declspec_il == cdil_none)
        {
          tree decl = current_function_decl;
          /* Mark nested functions as needing static-chain initially.
@@ -3235,6 +3235,15 @@ c_parser_declaration_or_fndef (c_parser *parser, bool fndef_ok,
          c_pop_function_context ();
          add_stmt (build_stmt (DECL_SOURCE_LOCATION (decl), DECL_EXPR, decl));
        }
+      else if (nested)
+       {
+         if (specs->declspec_il == cdil_rtl)
+           error ("%<__RTL%> function cannot be a nested function");
+         else
+           error ("%<__GIMPLE%> function cannot be a nested function");
+         finish_function (endloc);
+         c_pop_function_context ();
+       }
       else
        {
          if (fnbody)
diff --git a/gcc/testsuite/gcc.dg/gimplefe-error-16.c b/gcc/testsuite/gcc.dg/gimplefe-error-16.c
new file mode 100644 (file)
index 0000000..4cdeac8
--- /dev/null
@@ -0,0 +1,10 @@
+/* { dg-do compile } */
+/* { dg-options "-fgimple" } */
+/* PR c/121421 */
+/* Gimple functions cannot be nested functions. */
+
+
+void main(void)
+{
+    void __GIMPLE b(){} /* { dg-error "cannot be a nested" } */
+}