OSDN Git Service

PR c/51339
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 5 Dec 2011 20:49:38 +0000 (20:49 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 5 Dec 2011 20:49:38 +0000 (20:49 +0000)
* c-decl.c (c_finish_incomplete_decl, finish_decl): Call
relayout_decl instead of layout_decl.

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

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@182026 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/c-decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/gomp/pr51339.c [new file with mode: 0644]

index cc90010..9767de4 100644 (file)
@@ -1,3 +1,9 @@
+2011-12-05  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/51339
+       * c-decl.c (c_finish_incomplete_decl, finish_decl): Call
+       relayout_decl instead of layout_decl.
+
 2011-12-05  Richard Sandiford  <rdsandiford@googlemail.com>
 
        * resource.c (init_resource_info): Only consider EXIT_IGNORE_STACK
index 44358a8..4338fdf 100644 (file)
@@ -719,7 +719,7 @@ c_finish_incomplete_decl (tree decl)
 
          complete_array_type (&TREE_TYPE (decl), NULL_TREE, true);
 
-         layout_decl (decl, 0);
+         relayout_decl (decl);
        }
     }
 }
@@ -4311,7 +4311,7 @@ finish_decl (tree decl, location_t init_loc, tree init,
       if (DECL_INITIAL (decl))
        TREE_TYPE (DECL_INITIAL (decl)) = type;
 
-      layout_decl (decl, 0);
+      relayout_decl (decl);
     }
 
   if (TREE_CODE (decl) == VAR_DECL)
index c78d3f4..73cef0b 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-05  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/51339
+       * gcc.dg/gomp/pr51339.c: New test.
+
 2011-12-05  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/51399
diff --git a/gcc/testsuite/gcc.dg/gomp/pr51339.c b/gcc/testsuite/gcc.dg/gomp/pr51339.c
new file mode 100644 (file)
index 0000000..198e4c1
--- /dev/null
@@ -0,0 +1,15 @@
+/* PR c/51339 */
+/* { dg-do compile } */
+/* { dg-options "-fopenmp" } */
+
+char g[] = "g";
+
+void
+foo (void)
+{
+#pragma omp parallel sections firstprivate (g) lastprivate (g)
+  {
+  #pragma omp section
+    g[0] = 'h';
+  }
+}