URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [gfortran.dg/] [gomp/] [workshare2.f90] - Rev 694
Compare with Previous | Blame | View Log
! { dg-do compile }! { dg-options "-fopenmp -ffrontend-optimize -fdump-tree-original" }! PR 50690 - this used to ICE because workshare could not handle! BLOCKs.! To test for correct execution, run this program (but don't forget! to unset the stack limit).program fooimplicit noneinteger, parameter :: n = 10000000real, parameter :: eps = 3e-7integer :: i,jreal :: A(n), B(5), C(n)real :: tmpB(1) = 3.344tmp = B(1)do i=1,10call random_number(a)c = a!$omp parallel default(shared)!$omp workshareA(:) = A(:)*cos(B(1))+A(:)*cos(B(1))!$omp end workshare nowait!$omp end parallel ! sync is implied hereend doc = c*tmp + c*tmpdo j=1,nif (abs(a(j)-c(j)) > eps) thenprint *,1,j,a(j), c(j)call abortend ifend dodo i=1,10call random_number(a)c = a!$omp parallel workshare default(shared)A(:) = A(:)*cos(B(1))+A(:)*cos(B(1))!$omp end parallel workshareend doc = c*tmp + c*tmpdo j=1,nif (abs(a(j)-c(j)) > eps) thenprint *,2,j,a(j), c(j)call abortend ifend doend program foo! { dg-final { scan-tree-dump-times "__var" 0 "original" } }! { dg-final { cleanup-tree-dump "original" } }
