OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gcc-4.2.2/] [libgomp/] [testsuite/] [libgomp.fortran/] [do2.f90] - Diff between revs 154 and 816

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 154 Rev 816
! { dg-do run }
! { dg-do run }
  integer, dimension (128) :: a, b
  integer, dimension (128) :: a, b
  integer :: i, j
  integer :: i, j
  logical :: k
  logical :: k
  a = -1
  a = -1
  b = -1
  b = -1
  do i = 1, 128
  do i = 1, 128
    if (i .ge. 8 .and. i .le. 15) then
    if (i .ge. 8 .and. i .le. 15) then
      b(i) = 1 * 256 + i
      b(i) = 1 * 256 + i
    else if (i .ge. 19 .and. i .le. 23) then
    else if (i .ge. 19 .and. i .le. 23) then
      b(i) = 2 * 256 + i
      b(i) = 2 * 256 + i
    else if (i .ge. 28 .and. i .le. 38) then
    else if (i .ge. 28 .and. i .le. 38) then
      if (iand (i, 1) .eq. 0) b(i) = 3 * 256 + i
      if (iand (i, 1) .eq. 0) b(i) = 3 * 256 + i
    else if (i .ge. 59 .and. i .le. 79) then
    else if (i .ge. 59 .and. i .le. 79) then
      if (iand (i - 59, 3) .eq. 0) b(i) = 4 * 256 + i
      if (iand (i - 59, 3) .eq. 0) b(i) = 4 * 256 + i
    else if (i .ge. 101 .and. i .le. 125) then
    else if (i .ge. 101 .and. i .le. 125) then
      if (mod (i - 101, 12) .eq. 0) b(i) = 5 * 256 + i
      if (mod (i - 101, 12) .eq. 0) b(i) = 5 * 256 + i
    end if
    end if
  end do
  end do
  k = .false.
  k = .false.
  j = 8
  j = 8
!$omp parallel num_threads (4)
!$omp parallel num_threads (4)
!$omp do ordered
!$omp do ordered
  do i = 8, 15
  do i = 8, 15
    a(i) = 1 * 256 + i
    a(i) = 1 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 1
    j = j + 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 23
  j = 23
!$omp end single
!$omp end single
!$omp do ordered
!$omp do ordered
  do i = 23, 19, -1
  do i = 23, 19, -1
    a(i) = 2 * 256 + i
    a(i) = 2 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 1
    j = j - 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 28
  j = 28
!$omp end single
!$omp end single
!$omp do ordered
!$omp do ordered
  do i = 28, 39, 2
  do i = 28, 39, 2
    a(i) = 3 * 256 + i
    a(i) = 3 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 2
    j = j + 2
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 79
  j = 79
!$omp end single
!$omp end single
!$omp do ordered
!$omp do ordered
  do i = 79, 59, -4
  do i = 79, 59, -4
    a(i) = 4 * 256 + i
    a(i) = 4 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 4
    j = j - 4
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 125
  j = 125
!$omp end single
!$omp end single
!$omp do ordered
!$omp do ordered
  do i = 125, 90, -12
  do i = 125, 90, -12
    a(i) = 5 * 256 + i
    a(i) = 5 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 12
    j = j - 12
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp end parallel
!$omp end parallel
  if (any (a .ne. b) .or. k) call abort
  if (any (a .ne. b) .or. k) call abort
  a = -1
  a = -1
  k = .false.
  k = .false.
  j = 8
  j = 8
!$omp parallel num_threads (4)
!$omp parallel num_threads (4)
!$omp do ordered schedule (static)
!$omp do ordered schedule (static)
  do i = 8, 15
  do i = 8, 15
    a(i) = 1 * 256 + i
    a(i) = 1 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 1
    j = j + 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 23
  j = 23
!$omp end single
!$omp end single
!$omp do ordered schedule (static, 1)
!$omp do ordered schedule (static, 1)
  do i = 23, 19, -1
  do i = 23, 19, -1
    a(i) = 2 * 256 + i
    a(i) = 2 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 1
    j = j - 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 28
  j = 28
!$omp end single
!$omp end single
!$omp do ordered schedule (static, 3)
!$omp do ordered schedule (static, 3)
  do i = 28, 39, 2
  do i = 28, 39, 2
    a(i) = 3 * 256 + i
    a(i) = 3 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 2
    j = j + 2
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 79
  j = 79
!$omp end single
!$omp end single
!$omp do ordered schedule (static, 6)
!$omp do ordered schedule (static, 6)
  do i = 79, 59, -4
  do i = 79, 59, -4
    a(i) = 4 * 256 + i
    a(i) = 4 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 4
    j = j - 4
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 125
  j = 125
!$omp end single
!$omp end single
!$omp do ordered schedule (static, 2)
!$omp do ordered schedule (static, 2)
  do i = 125, 90, -12
  do i = 125, 90, -12
    a(i) = 5 * 256 + i
    a(i) = 5 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 12
    j = j - 12
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp end parallel
!$omp end parallel
  if (any (a .ne. b) .or. k) call abort
  if (any (a .ne. b) .or. k) call abort
  a = -1
  a = -1
  k = .false.
  k = .false.
  j = 8
  j = 8
!$omp parallel num_threads (4)
!$omp parallel num_threads (4)
!$omp do ordered schedule (dynamic)
!$omp do ordered schedule (dynamic)
  do i = 8, 15
  do i = 8, 15
    a(i) = 1 * 256 + i
    a(i) = 1 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 1
    j = j + 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 23
  j = 23
!$omp end single
!$omp end single
!$omp do ordered schedule (dynamic, 4)
!$omp do ordered schedule (dynamic, 4)
  do i = 23, 19, -1
  do i = 23, 19, -1
    a(i) = 2 * 256 + i
    a(i) = 2 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 1
    j = j - 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 28
  j = 28
!$omp end single
!$omp end single
!$omp do ordered schedule (dynamic, 1)
!$omp do ordered schedule (dynamic, 1)
  do i = 28, 39, 2
  do i = 28, 39, 2
    a(i) = 3 * 256 + i
    a(i) = 3 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 2
    j = j + 2
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 79
  j = 79
!$omp end single
!$omp end single
!$omp do ordered schedule (dynamic, 2)
!$omp do ordered schedule (dynamic, 2)
  do i = 79, 59, -4
  do i = 79, 59, -4
    a(i) = 4 * 256 + i
    a(i) = 4 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 4
    j = j - 4
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 125
  j = 125
!$omp end single
!$omp end single
!$omp do ordered schedule (dynamic, 3)
!$omp do ordered schedule (dynamic, 3)
  do i = 125, 90, -12
  do i = 125, 90, -12
    a(i) = 5 * 256 + i
    a(i) = 5 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 12
    j = j - 12
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp end parallel
!$omp end parallel
  if (any (a .ne. b) .or. k) call abort
  if (any (a .ne. b) .or. k) call abort
  a = -1
  a = -1
  k = .false.
  k = .false.
  j = 8
  j = 8
!$omp parallel num_threads (4)
!$omp parallel num_threads (4)
!$omp do ordered schedule (guided)
!$omp do ordered schedule (guided)
  do i = 8, 15
  do i = 8, 15
    a(i) = 1 * 256 + i
    a(i) = 1 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 1
    j = j + 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 23
  j = 23
!$omp end single
!$omp end single
!$omp do ordered schedule (guided, 4)
!$omp do ordered schedule (guided, 4)
  do i = 23, 19, -1
  do i = 23, 19, -1
    a(i) = 2 * 256 + i
    a(i) = 2 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 1
    j = j - 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 28
  j = 28
!$omp end single
!$omp end single
!$omp do ordered schedule (guided, 1)
!$omp do ordered schedule (guided, 1)
  do i = 28, 39, 2
  do i = 28, 39, 2
    a(i) = 3 * 256 + i
    a(i) = 3 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 2
    j = j + 2
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 79
  j = 79
!$omp end single
!$omp end single
!$omp do ordered schedule (guided, 2)
!$omp do ordered schedule (guided, 2)
  do i = 79, 59, -4
  do i = 79, 59, -4
    a(i) = 4 * 256 + i
    a(i) = 4 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 4
    j = j - 4
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 125
  j = 125
!$omp end single
!$omp end single
!$omp do ordered schedule (guided, 3)
!$omp do ordered schedule (guided, 3)
  do i = 125, 90, -12
  do i = 125, 90, -12
    a(i) = 5 * 256 + i
    a(i) = 5 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 12
    j = j - 12
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp end parallel
!$omp end parallel
  if (any (a .ne. b) .or. k) call abort
  if (any (a .ne. b) .or. k) call abort
  a = -1
  a = -1
  k = .false.
  k = .false.
  j = 8
  j = 8
!$omp parallel num_threads (4)
!$omp parallel num_threads (4)
!$omp do ordered schedule (runtime)
!$omp do ordered schedule (runtime)
  do i = 8, 15
  do i = 8, 15
    a(i) = 1 * 256 + i
    a(i) = 1 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 1
    j = j + 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 23
  j = 23
!$omp end single
!$omp end single
!$omp do ordered schedule (runtime)
!$omp do ordered schedule (runtime)
  do i = 23, 19, -1
  do i = 23, 19, -1
    a(i) = 2 * 256 + i
    a(i) = 2 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 1
    j = j - 1
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 28
  j = 28
!$omp end single
!$omp end single
!$omp do ordered schedule (runtime)
!$omp do ordered schedule (runtime)
  do i = 28, 39, 2
  do i = 28, 39, 2
    a(i) = 3 * 256 + i
    a(i) = 3 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j + 2
    j = j + 2
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 79
  j = 79
!$omp end single
!$omp end single
!$omp do ordered schedule (runtime)
!$omp do ordered schedule (runtime)
  do i = 79, 59, -4
  do i = 79, 59, -4
    a(i) = 4 * 256 + i
    a(i) = 4 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 4
    j = j - 4
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp single
!$omp single
  j = 125
  j = 125
!$omp end single
!$omp end single
!$omp do ordered schedule (runtime)
!$omp do ordered schedule (runtime)
  do i = 125, 90, -12
  do i = 125, 90, -12
    a(i) = 5 * 256 + i
    a(i) = 5 * 256 + i
!$omp ordered
!$omp ordered
    if (i .ne. j) k = .true.
    if (i .ne. j) k = .true.
    j = j - 12
    j = j - 12
!$omp end ordered
!$omp end ordered
  end do
  end do
!$omp end parallel
!$omp end parallel
  if (any (a .ne. b) .or. k) call abort
  if (any (a .ne. b) .or. k) call abort
end
end
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.