Commit 8fc708b7 by Jakub Jelinek Committed by Jakub Jelinek

re PR c/68960 (__attribute__ ((aligned ())) is ignored for OpenMP private variables)

	PR middle-end/68960
	* gimple-expr.c (copy_var_decl): If var has DECL_USER_ALIGN set, copy
	it and DECL_ALIGN too.

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

From-SVN: r232122
parent 827d8502
2016-01-07 Jakub Jelinek <jakub@redhat.com>
PR middle-end/68960
* gimple-expr.c (copy_var_decl): If var has DECL_USER_ALIGN set, copy
it and DECL_ALIGN too.
2016-01-06 Robert Suchanek <robert.suchanek@imgtec.com>
* config/mips/mips-ftypes.def: Sort to lexicographical order.
......
......@@ -375,6 +375,11 @@ copy_var_decl (tree var, tree name, tree type)
TREE_USED (copy) = 1;
DECL_SEEN_IN_BIND_EXPR_P (copy) = 1;
DECL_ATTRIBUTES (copy) = DECL_ATTRIBUTES (var);
if (DECL_USER_ALIGN (var))
{
DECL_ALIGN (copy) = DECL_ALIGN (var);
DECL_USER_ALIGN (copy) = 1;
}
return copy;
}
......
2016-01-07 Jakub Jelinek <jakub@redhat.com>
PR middle-end/68960
* testsuite/libgomp.c/pr68960.c: New test.
2016-01-06 Nathan Sidwell <nathan@acm.org>
* openacc.h (acc_on_device): Add routine pragma for C++ wrapper.
......
/* PR middle-end/68960 */
/* { dg-do run } */
int
main ()
{
int temp[257] __attribute__ ((aligned (256))) = { 0 };
#pragma omp parallel private (temp) num_threads (2)
{
int *p = &temp[0];
asm volatile ("" : "+g" (p));
if (((__UINTPTR_TYPE__) p) & 255)
__builtin_abort ();
}
#pragma omp parallel num_threads (2)
#pragma omp single
#pragma omp task firstprivate (temp)
{
int *p = &temp[0];
asm volatile ("" : "+g" (p));
if (((__UINTPTR_TYPE__) p) & 255)
__builtin_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