File: basic-target-parallel-reduction.f90

package info (click to toggle)
llvm-toolchain-21 1%3A21.1.8-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,236,764 kB
  • sloc: cpp: 7,619,776; ansic: 1,433,958; asm: 1,058,748; python: 252,197; f90: 94,671; objc: 70,753; lisp: 42,813; pascal: 18,401; sh: 8,601; ml: 5,111; perl: 4,720; makefile: 3,721; awk: 3,523; javascript: 2,272; xml: 892; fortran: 770
file content (27 lines) | stat: -rw-r--r-- 627 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
! Basic offloading test with a target region
! REQUIRES: flang, amdgpu

! RUN: %libomptarget-compile-fortran-generic
! RUN: env LIBOMPTARGET_INFO=16 %libomptarget-run-generic 2>&1 | %fcheck-generic
program main
   use omp_lib
   integer :: error = 0
   integer :: i
   integer :: sum = 0

   !$omp target parallel do reduction(+:sum)
   do i = 1, 100
       sum = sum + i
   end do
   !$omp end target parallel do

   if (sum /= 5050) then
     error = 1
  endif

  print *,"number of errors: ", error

end program main

! CHECK:  "PluginInterface" device {{[0-9]+}} info: Launching kernel {{.*}}
! CHECK:  number of errors: 0