re PR tree-optimization/82374 (#pragma GCC optimize is not applied to openmp-generate...
authorJakub Jelinek <jakub@redhat.com>
Wed, 4 Oct 2017 07:50:38 +0000 (09:50 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Wed, 4 Oct 2017 07:50:38 +0000 (09:50 +0200)
PR tree-optimization/82374
* omp-low.c (create_omp_child_function): Copy DECL_ATTRIBUTES,
DECL_FUNCTION_SPECIFIC_OPTIMIZATION,
DECL_FUNCTION_SPECIFIC_TARGET and DECL_FUNCTION_VERSIONED from
current_function_decl to the new decl.

* gcc.dg/gomp/pr82374.c: New test.

From-SVN: r253395

gcc/ChangeLog
gcc/omp-low.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/gomp/pr82374.c [new file with mode: 0644]

index f7a448b3ecf9480867985b3cefdda49ad69817ff..3512f9e703ee17f83799f84e86e1af138c1103a5 100644 (file)
@@ -1,3 +1,11 @@
+2017-10-04  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/82374
+       * omp-low.c (create_omp_child_function): Copy DECL_ATTRIBUTES,
+       DECL_FUNCTION_SPECIFIC_OPTIMIZATION,
+       DECL_FUNCTION_SPECIFIC_TARGET and DECL_FUNCTION_VERSIONED from
+       current_function_decl to the new decl.
+
 2017-10-03  Michael Meissner  <meissner@linux.vnet.ibm.com>
 
        * config/rs6000/rs6000-builtin.def (BU_FLOAT128_2_HW): Define new
index 8ed8f7c90f2dd5c2262e3a234710d03aad401a6f..3645661038afe9aec2008a528d0dd9959b0bce15 100644 (file)
@@ -1626,6 +1626,14 @@ create_omp_child_function (omp_context *ctx, bool task_copy)
   DECL_CONTEXT (decl) = NULL_TREE;
   DECL_INITIAL (decl) = make_node (BLOCK);
   BLOCK_SUPERCONTEXT (DECL_INITIAL (decl)) = decl;
+  DECL_ATTRIBUTES (decl) = DECL_ATTRIBUTES (current_function_decl);
+  DECL_FUNCTION_SPECIFIC_OPTIMIZATION (decl)
+    = DECL_FUNCTION_SPECIFIC_OPTIMIZATION (current_function_decl);
+  DECL_FUNCTION_SPECIFIC_TARGET (decl)
+    = DECL_FUNCTION_SPECIFIC_TARGET (current_function_decl);
+  DECL_FUNCTION_VERSIONED (decl)
+    = DECL_FUNCTION_VERSIONED (current_function_decl);
+
   if (omp_maybe_offloaded_ctx (ctx))
     {
       cgraph_node::get_create (decl)->offloadable = 1;
index 9205fbe6846edf16c353f53c283122c170cbc454..816646517ac1ef145fc28ff6bd21f8610ec1082a 100644 (file)
@@ -1,3 +1,8 @@
+2017-10-04  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/82374
+       * gcc.dg/gomp/pr82374.c: New test.
+
 2017-10-04  Richard Biener  <rguenther@suse.de>
 
        * gfortran.dg/graphite/id-17.f: For ilp32 allow graphite codegen
diff --git a/gcc/testsuite/gcc.dg/gomp/pr82374.c b/gcc/testsuite/gcc.dg/gomp/pr82374.c
new file mode 100644 (file)
index 0000000..0ac70ae
--- /dev/null
@@ -0,0 +1,31 @@
+/* PR tree-optimization/82374 */
+/* { dg-do compile } */
+/* { dg-options "-O2 -fno-tree-vectorize -fdump-tree-vect-details" } */
+/* { dg-additional-options "-mavx -mno-avx2" { target i?86-*-* x86_64-*-* } } */
+/* { dg-additional-options "-mvsx" { target powerpc_vsx_ok } } */
+
+#define SIZE (1024 * 1024 * 1024)
+
+float a[SIZE];
+float b[SIZE];
+float c[SIZE];
+float d[SIZE];
+
+__attribute__((optimize ("O2", "tree-vectorize"))) void
+foo (void)
+{
+  int i;
+#pragma omp parallel for
+  for (i = 0; i < SIZE; i++)
+    c[i] = a[i] + b[i];
+}
+
+__attribute__((optimize ("O2", "tree-vectorize"))) void
+bar (void)
+{
+  int i;
+  for (i = 0; i < SIZE; i++)
+    d[i] = a[i] + b[i];
+}
+
+/* { dg-final { scan-tree-dump-times "vectorized 1 loops" 2 "vect" { target { { i?86-*-* x86_64-*-* } || { powerpc_vsx_ok } } } } } */