1! Offloading test checking interaction of an explicit derived type member
2! mapping of two arrays with explicit bounds when mapped to target
3! REQUIRES: flang, amdgpu
4
5! RUN: %libomptarget-compile-fortran-run-and-check-generic
6program main
7    type :: scalar_array
8    real(4) :: break_0
9    real(4) :: array_x(10)
10    real(4) :: break_1
11    real(4) :: array_y(10)
12    real(4) :: break_3
13    end type scalar_array
14
15    type(scalar_array) :: scalar_arr
16
17  do i = 1, 10
18    scalar_arr%array_x(i) = i
19  end do
20
21  !$omp target map(tofrom:scalar_arr%array_x(3:6), scalar_arr%array_y(3:6))
22    do i = 1, 10
23      scalar_arr%array_y(i) = scalar_arr%array_x(i)
24    end do
25  !$omp end target
26
27  print*, scalar_arr%array_y
28end program main
29
30!CHECK: 0. 0. 3. 4. 5. 6. 0. 0. 0. 0.
31