OpenMP/Fortran: Permit assumed-size arrays in uniform clause
gcc/fortran/ChangeLog: * openmp.cc (resolve_omp_clauses): Permit assumed-size arrays in uniform clause. gcc/testsuite/ChangeLog: * gfortran.dg/gomp/declare-simd-3.f90: New test.
This commit is contained in:
parent
49ba4fdeb6
commit
a6afbe5e95
2 changed files with 32 additions and 1 deletions
|
@ -7386,7 +7386,8 @@ resolve_omp_clauses (gfc_code *code, gfc_omp_clauses *omp_clauses,
|
|||
|| code->op == EXEC_OACC_PARALLEL
|
||||
|| code->op == EXEC_OACC_SERIAL))
|
||||
check_array_not_assumed (n->sym, n->where, name);
|
||||
else if (n->sym->as && n->sym->as->type == AS_ASSUMED_SIZE)
|
||||
else if (list != OMP_LIST_UNIFORM
|
||||
&& n->sym->as && n->sym->as->type == AS_ASSUMED_SIZE)
|
||||
gfc_error ("Assumed size array %qs in %s clause at %L",
|
||||
n->sym->name, name, &n->where);
|
||||
if (n->sym->attr.in_namelist && !is_reduction)
|
||||
|
|
30
gcc/testsuite/gfortran.dg/gomp/declare-simd-3.f90
Normal file
30
gcc/testsuite/gfortran.dg/gomp/declare-simd-3.f90
Normal file
|
@ -0,0 +1,30 @@
|
|||
! { dg-do compile }
|
||||
|
||||
module m
|
||||
implicit none (type, external)
|
||||
contains
|
||||
real function add(x, y, j) result(res)
|
||||
!$omp declare simd(add) uniform(x, y) linear(j : 1) simdlen(4)
|
||||
integer, value :: j
|
||||
real, intent(in) :: x(*), y(*)
|
||||
res = x(j) + y(j)
|
||||
end function
|
||||
end module m
|
||||
|
||||
program main
|
||||
use m
|
||||
implicit none (type, external)
|
||||
real, allocatable :: A(:), B(:), C(:)
|
||||
integer :: i, N
|
||||
N = 128
|
||||
A = [(3*i, i = 1, N)]
|
||||
B = [(7*i, i = 1, N)]
|
||||
allocate (C(N))
|
||||
|
||||
!$omp simd
|
||||
do i = 1, N
|
||||
C(i) = add(A, B, i)
|
||||
end do
|
||||
|
||||
if (any (C /= [(10*i, i = 1, N)])) error stop
|
||||
end program main
|
Loading…
Add table
Reference in a new issue