pragma: respect pragma in lambda functions

Message ID 9cedfef0-dd5f-7dbd-e7fb-cb64e427dd30@suse.cz
State New
Headers
Series pragma: respect pragma in lambda functions |

Commit Message

Martin Liška Dec. 16, 2021, 11:07 a.m. UTC
  In g:01ad8c54fdca we started supporting target pragma changes
that are primarily caused by optimization option. The same can happen
in the opposite way and we need to check for changes both
in optimization_current_node and target_option_current_node.

Patch can bootstrap on x86_64-linux-gnu and survives regression tests.

Ready to be installed?
Thanks,
Martin

	PR c++/103696

gcc/ChangeLog:

	* attribs.c (decl_attributes): Check if
	target_option_current_node is changed.

gcc/testsuite/ChangeLog:

	* g++.target/i386/pr103696.C: New test.
---
  gcc/attribs.c                            |  3 ++-
  gcc/testsuite/g++.target/i386/pr103696.C | 25 ++++++++++++++++++++++++
  2 files changed, 27 insertions(+), 1 deletion(-)
  create mode 100644 gcc/testsuite/g++.target/i386/pr103696.C
  

Comments

Jeff Law Dec. 16, 2021, 4:43 p.m. UTC | #1
On 12/16/2021 4:07 AM, Martin Liška wrote:
> In g:01ad8c54fdca we started supporting target pragma changes
> that are primarily caused by optimization option. The same can happen
> in the opposite way and we need to check for changes both
> in optimization_current_node and target_option_current_node.
>
> Patch can bootstrap on x86_64-linux-gnu and survives regression tests.
>
> Ready to be installed?
> Thanks,
> Martin
>
>     PR c++/103696
>
> gcc/ChangeLog:
>
>     * attribs.c (decl_attributes): Check if
>     target_option_current_node is changed.
>
> gcc/testsuite/ChangeLog:
>
>     * g++.target/i386/pr103696.C: New test.
OK
jeff
  

Patch

diff --git a/gcc/attribs.c b/gcc/attribs.c
index 01a9ed66485..29703e75fba 100644
--- a/gcc/attribs.c
+++ b/gcc/attribs.c
@@ -605,7 +605,8 @@  decl_attributes (tree *node, tree attributes, int flags,
      }
  
    if (TREE_CODE (*node) == FUNCTION_DECL
-      && optimization_current_node != optimization_default_node
+      && (optimization_current_node != optimization_default_node
+	  || target_option_current_node != target_option_default_node)
        && !DECL_FUNCTION_SPECIFIC_OPTIMIZATION (*node))
      {
        DECL_FUNCTION_SPECIFIC_OPTIMIZATION (*node) = optimization_current_node;
diff --git a/gcc/testsuite/g++.target/i386/pr103696.C b/gcc/testsuite/g++.target/i386/pr103696.C
new file mode 100644
index 00000000000..de7d5c68be9
--- /dev/null
+++ b/gcc/testsuite/g++.target/i386/pr103696.C
@@ -0,0 +1,25 @@ 
+// PR c++/103696
+// { dg-options "-O2 -std=c++14 -fdump-tree-optimized" }
+
+int global_var;
+
+void fn() {
+}
+
+#pragma GCC optimize("finite-math-only")
+#pragma GCC target("sse3")
+
+void fn2() {
+}
+
+void fn3() {
+}
+
+int solve() {
+    auto nested = []() {
+        return global_var;
+    };
+    return nested();
+}
+
+/* { dg-final { scan-tree-dump-not "lambda" "optimized" } } */