Commit c140ddf3 by Jakub Jelinek Committed by Jakub Jelinek

re PR middle-end/52547 (ICE with openmp with nested function which requires a trampoline)

	PR middle-end/52547
	* tree-nested.c (convert_tramp_reference_stmt): Call declare_vars
	on any new_local_var_chain vars declared during recursing on
	GIMPLE_OMP_PARALLEL or GIMPLE_OMP_TASK body.

	* testsuite/libgomp.c/pr52547.c: New test.

From-SVN: r185707
parent e75b54a2
2012-03-22 Jakub Jelinek <jakub@redhat.com>
PR middle-end/52547
* tree-nested.c (convert_tramp_reference_stmt): Call declare_vars
on any new_local_var_chain vars declared during recursing on
GIMPLE_OMP_PARALLEL or GIMPLE_OMP_TASK body.
2012-03-22 Uros Bizjak <ubizjak@gmail.com>
* config/alpha/alpha.h (ASM_OUTPUT_ALIGN): Move to config/alpha/elf.h
......
......@@ -1954,6 +1954,7 @@ static tree
convert_tramp_reference_stmt (gimple_stmt_iterator *gsi, bool *handled_ops_p,
struct walk_stmt_info *wi)
{
struct nesting_info *info = (struct nesting_info *) wi->info;
gimple stmt = gsi_stmt (*gsi);
switch (gimple_code (stmt))
......@@ -1966,16 +1967,33 @@ convert_tramp_reference_stmt (gimple_stmt_iterator *gsi, bool *handled_ops_p,
for (i = 0; i < nargs; i++)
walk_tree (gimple_call_arg_ptr (stmt, i), convert_tramp_reference_op,
wi, NULL);
break;
}
*handled_ops_p = true;
return NULL_TREE;
case GIMPLE_OMP_PARALLEL:
case GIMPLE_OMP_TASK:
{
tree save_local_var_chain;
walk_gimple_op (stmt, convert_tramp_reference_op, wi);
save_local_var_chain = info->new_local_var_chain;
info->new_local_var_chain = NULL;
walk_body (convert_tramp_reference_stmt, convert_tramp_reference_op,
info, gimple_omp_body (stmt));
if (info->new_local_var_chain)
declare_vars (info->new_local_var_chain,
gimple_seq_first_stmt (gimple_omp_body (stmt)),
false);
info->new_local_var_chain = save_local_var_chain;
}
break;
default:
*handled_ops_p = false;
return NULL_TREE;
break;
}
*handled_ops_p = false;
*handled_ops_p = true;
return NULL_TREE;
}
......
2012-03-22 Jakub Jelinek <jakub@redhat.com>
PR middle-end/52547
* testsuite/libgomp.c/pr52547.c: New test.
2012-03-16 Bernhard Reutner-Fischer <aldot@gcc.gnu.org>
* testsuite/lib/libgomp.exp: load fortran-modules.exp
......
/* PR middle-end/52547 */
/* { dg-do run } */
extern void abort (void);
__attribute__((noinline, noclone)) int
baz (int *x, int (*fn) (int *))
{
return fn (x);
}
__attribute__((noinline, noclone)) int
foo (int x, int *y)
{
int i, e = 0;
#pragma omp parallel for reduction(|:e)
for (i = 0; i < x; ++i)
{
__label__ lab;
int bar (int *z) { return z - y; }
if (baz (&y[i], bar) != i)
e |= 1;
}
return e;
}
int
main ()
{
int a[100], i;
for (i = 0; i < 100; i++)
a[i] = i;
if (foo (100, a))
abort ();
return 0;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment