diff options
author | Jakub Jelinek <jakub@redhat.com> | 2006-05-15 11:59:30 +0200 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2006-05-15 11:59:30 +0200 |
commit | eeb1d9e08e920796ba71d81765f5a9fdf54af25e (patch) | |
tree | f98104c0cbb328853171038be84319686e79eb83 /gcc/omp-low.c | |
parent | 5b8fdd1fade31b12b6b33d4598f0e8c14caed3b4 (diff) | |
download | gcc-eeb1d9e08e920796ba71d81765f5a9fdf54af25e.zip gcc-eeb1d9e08e920796ba71d81765f5a9fdf54af25e.tar.gz gcc-eeb1d9e08e920796ba71d81765f5a9fdf54af25e.tar.bz2 |
re PR middle-end/27416 (ICE on invalid firstprivate/lastprivate)
PR middle-end/27416
* omp-low.c (build_outer_var_ref): If VAR is reference in orphaned
construct, return *VAR.
* libgomp.fortran/pr27416-1.f90: New test.
From-SVN: r113788
Diffstat (limited to 'gcc/omp-low.c')
-rw-r--r-- | gcc/omp-low.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/gcc/omp-low.c b/gcc/omp-low.c index 2de13ec..c6d186b 100644 --- a/gcc/omp-low.c +++ b/gcc/omp-low.c @@ -577,6 +577,10 @@ build_outer_var_ref (tree var, omp_context *ctx) } else if (ctx->outer) x = lookup_decl (var, ctx->outer); + else if (is_reference (var)) + /* This can happen with orphaned constructs. If var is reference, it is + possible it is shared and as such valid. */ + x = var; else gcc_unreachable (); |