mirror of
https://github.com/gcc-mirror/gcc.git
synced 2024-11-21 13:40:47 +00:00
re PR c++/56217 (ICE: OpenMP: when combining shared() and a move constructor)
PR middle-end/56217 * omp-low.c (use_pointer_for_field): Return false if lower_send_shared_vars doesn't generate any copy-out code. * g++.dg/gomp/pr56217.C: New test. * testsuite/libgomp.c++/pr56217.C: New test. From-SVN: r195796
This commit is contained in:
parent
ca4a4fe903
commit
6d840d9980
@ -1,3 +1,9 @@
|
||||
2013-02-06 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/56217
|
||||
* omp-low.c (use_pointer_for_field): Return false if
|
||||
lower_send_shared_vars doesn't generate any copy-out code.
|
||||
|
||||
2013-02-06 Tom de Vries <tom@codesourcery.com>
|
||||
|
||||
PR rtl-optimization/56131
|
||||
|
@ -757,12 +757,20 @@ use_pointer_for_field (tree decl, omp_context *shared_ctx)
|
||||
if (TREE_ADDRESSABLE (decl))
|
||||
return true;
|
||||
|
||||
/* lower_send_shared_vars only uses copy-in, but not copy-out
|
||||
for these. */
|
||||
if (TREE_READONLY (decl)
|
||||
|| ((TREE_CODE (decl) == RESULT_DECL
|
||||
|| TREE_CODE (decl) == PARM_DECL)
|
||||
&& DECL_BY_REFERENCE (decl)))
|
||||
return false;
|
||||
|
||||
/* Disallow copy-in/out in nested parallel if
|
||||
decl is shared in outer parallel, otherwise
|
||||
each thread could store the shared variable
|
||||
in its own copy-in location, making the
|
||||
variable no longer really shared. */
|
||||
if (!TREE_READONLY (decl) && shared_ctx->is_nested)
|
||||
if (shared_ctx->is_nested)
|
||||
{
|
||||
omp_context *up;
|
||||
|
||||
@ -785,11 +793,10 @@ use_pointer_for_field (tree decl, omp_context *shared_ctx)
|
||||
}
|
||||
}
|
||||
|
||||
/* For tasks avoid using copy-in/out, unless they are readonly
|
||||
(in which case just copy-in is used). As tasks can be
|
||||
/* For tasks avoid using copy-in/out. As tasks can be
|
||||
deferred or executed in different thread, when GOMP_task
|
||||
returns, the task hasn't necessarily terminated. */
|
||||
if (!TREE_READONLY (decl) && is_task_ctx (shared_ctx))
|
||||
if (is_task_ctx (shared_ctx))
|
||||
{
|
||||
tree outer;
|
||||
maybe_mark_addressable_and_ret:
|
||||
|
@ -1,3 +1,8 @@
|
||||
2013-02-06 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/56217
|
||||
* g++.dg/gomp/pr56217.C: New test.
|
||||
|
||||
2013-02-05 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR tree-optimization/56205
|
||||
|
14
gcc/testsuite/g++.dg/gomp/pr56217.C
Normal file
14
gcc/testsuite/g++.dg/gomp/pr56217.C
Normal file
@ -0,0 +1,14 @@
|
||||
// PR middle-end/56217
|
||||
// { dg-do compile }
|
||||
// { dg-options "-fopenmp" }
|
||||
|
||||
struct S { int *p; S (); S (S &); };
|
||||
|
||||
S
|
||||
foo ()
|
||||
{
|
||||
S s;
|
||||
#pragma omp task shared (s)
|
||||
s.p = 0;
|
||||
return s;
|
||||
}
|
@ -1,3 +1,8 @@
|
||||
2013-02-06 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
PR middle-end/56217
|
||||
* testsuite/libgomp.c++/pr56217.C: New test.
|
||||
|
||||
2013-02-01 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* task.c (GOMP_task, GOMP_taskwait): Comment.
|
||||
|
36
libgomp/testsuite/libgomp.c++/pr56217.C
Normal file
36
libgomp/testsuite/libgomp.c++/pr56217.C
Normal file
@ -0,0 +1,36 @@
|
||||
// PR middle-end/56217
|
||||
// { dg-do run }
|
||||
// { dg-options "-std=c++0x" }
|
||||
|
||||
extern "C" void abort ();
|
||||
|
||||
template <typename T>
|
||||
struct ptr {
|
||||
T *p;
|
||||
ptr () : p () {}
|
||||
ptr (ptr &) = delete;
|
||||
ptr (ptr &&o) : p(o) {}
|
||||
operator T * () { return p; }
|
||||
};
|
||||
|
||||
int a[6] = { 100, 101, 102, 103, 104, 105 };
|
||||
|
||||
static ptr<int>
|
||||
f ()
|
||||
{
|
||||
ptr<int> pt;
|
||||
#pragma omp task shared (pt)
|
||||
pt.p = a + 2;
|
||||
#pragma omp taskwait
|
||||
return pt;
|
||||
}
|
||||
|
||||
int
|
||||
main ()
|
||||
{
|
||||
ptr<int> pt;
|
||||
#pragma omp parallel
|
||||
#pragma omp single
|
||||
if (f () != a + 2 || *f () != 102)
|
||||
abort ();
|
||||
}
|
Loading…
Reference in New Issue
Block a user