| ! { dg-do compile } |
| |
| SUBROUTINE foo(n,array) |
| IMPLICIT NONE |
| INTEGER, INTENT (IN) :: n |
| REAL, INTENT(INOUT),OPTIONAL:: array(:) |
| INTEGER:: i |
| |
| !$OMP PARALLEL DO DEFAULT(none) SHARED(array,n) PRIVATE(i) |
| DO i = 1,n |
| IF (PRESENT(array)) THEN |
| array(i) = array(i) + i |
| ENDIF |
| ENDDO |
| !$OMP END PARALLEL DO |
| END SUBROUTINE foo |
| |
| subroutine s1 (array) |
| real, optional :: array(:) |
| !$omp parallel default(none) firstprivate (array) |
| if (present (array)) array(:) = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s2 (array) |
| real, optional :: array(:) |
| !$omp parallel default(none) shared (array) |
| !$omp master |
| if (present (array)) array(:) = 3 |
| !$omp end master |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s3 (array) |
| real, optional :: array(:) |
| !$omp parallel default(none) private (array) |
| if (present (array)) array(:) = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s4 (arg) |
| real, optional :: arg |
| !$omp parallel default(none) firstprivate (arg) |
| if (present (arg)) arg = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s5 (arg) |
| real, optional :: arg |
| !$omp parallel default(none) shared (arg) |
| !$omp master |
| if (present (arg)) arg = 3 |
| !$omp end master |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s6 (arg) |
| real, optional :: arg |
| !$omp parallel default(none) private (arg) |
| if (present (arg)) arg = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s7 (arg) |
| real, value, optional :: arg |
| !$omp parallel default(none) firstprivate (arg) |
| if (present (arg)) arg = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s8 (arg) |
| real, value, optional :: arg |
| !$omp parallel default(none) shared (arg) |
| !$omp master |
| if (present (arg)) arg = 3 |
| !$omp end master |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s9 (arg) |
| real, value, optional :: arg |
| !$omp parallel default(none) private (arg) |
| if (present (arg)) arg = 3 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine s10 (arg) |
| real, optional :: arg(..) |
| !$omp parallel default(none) private (arg) |
| if (present (arg)) stop 10 |
| !$omp end parallel |
| end subroutine |
| |
| subroutine w1 (array) |
| real, optional :: array(:) |
| !$omp parallel default(none) ! { dg-message "note: enclosing 'parallel'" } |
| if (.not.present (array)) stop 1 ! { dg-error "'array' not specified in enclosing 'parallel'" } |
| !$omp end parallel |
| end subroutine |
| |
| subroutine w2 (array2) |
| real, optional :: array2(*) |
| !$omp parallel default(none) ! { dg-message "note: enclosing 'parallel'" "TODO" { xfail *-*-* } } |
| if (.not.present (array2)) stop 2 ! { dg-error "'array2' not specified in enclosing 'parallel'" "TODO" { xfail *-*-* } } |
| !$omp end parallel |
| end subroutine |
| |
| subroutine w3 (arg) |
| real, optional :: arg |
| !$omp parallel default(none) ! { dg-message "note: enclosing 'parallel'" } |
| if (.not.present (arg)) stop 3 ! { dg-error "'arg' not specified in enclosing 'parallel'" } |
| !$omp end parallel |
| end subroutine |
| |
| subroutine w4 (arg2) |
| real, value, optional :: arg2 |
| !$omp parallel default(none) ! { dg-message "note: enclosing 'parallel" "TODO" { xfail *-*-* } } |
| if (.not.present (arg2)) stop 4 ! { dg-error "'arg2' not specified in enclosing 'parallel'" "TODO" { xfail *-*-*} } |
| !$omp end parallel |
| end subroutine |
| |
| subroutine w5 (array3) |
| real, optional :: array3(..) |
| !$omp parallel default(none) ! { dg-message "note: enclosing 'parallel'" } |
| if (.not.present (array3)) stop 5 ! { dg-error "'array3' not specified in enclosing 'parallel'" } |
| !$omp end parallel |
| end subroutine |