------- Comment #4 from jakub at gcc dot gnu dot org  2007-09-19 17:30 -------
I think the standard is very vague here.
First consider:
!$omp parallel default(none)
  call something
!$omp do schedule(static, chunksize)
  do i=1,100
    call somethingelse
  done
!$omp end do
!$omp end parallel

Do you agree that this must issue an error?  Here page 36 only says that
if there was say !$omp do schedule(static, chunksize) private(chunksize), then
schedule would use the outer chunksize, while inside of the loop would be a
different, privatized, variable.  I can't see how chunksize wouldn't count here
as a reference of that variable inside of the parallel.

Now, consider:
!$omp parallel default(none)
!$omp do schedule(static, chunksize)
  do i=1,100
    call somethingelse
  done
!$omp end do
!$omp end parallel

I believe this falls to the same category as the previous one.
Now, for the combined parallel it is very unclear, but doesn't section 2.6
say they have the same semantics as the above?


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=33439

Reply via email to