llvm/offload/test/offloading/fortran/target_map_common_block.f90

! Basic offloading test with a target region
! REQUIRES: flang, amdgpu
! RUN: %libomptarget-compile-fortran-run-and-check-generic

! Testing simple variables in common block.
program main
  call check_device
  call commonblock_simple_with_implicit_type_var
  call commonblock_simple_with_integer
  call commonblock_simple_with_real
  call commonblock_simple_to_from
  call set_commonblock_named
  call use_commonblock_named
end program main

!-----

subroutine check_device
  use omp_lib
  integer :: devices(2)
  devices(1) = omp_get_device_num()
  !$omp target map(tofrom:devices)
    devices(2) = omp_get_device_num()
  !$omp end target
  print *, omp_get_num_devices()
  !CHECK: [[ND:[0-9]+]]
  print *, omp_get_default_device()
  !CHECK: [[DD:[0-9]+]]
  !CHECK: devices: [[ND]] [[DD]]
  print *, "devices: ", devices
end subroutine check_device

!-----

subroutine commonblock_simple_with_implicit_type_var
  use omp_lib
  common var1
  var1 = 10
  print *, "var1 before target = ", var1
  !$omp target map(tofrom:var1)
    var1 = 20
  !$omp end target
  print *, "var1 after target = ", var1
end subroutine

! CHECK: var1 before target = 10
! CHECK: var1 after target = 20

! -----

subroutine commonblock_simple_with_integer
  use omp_lib
  integer :: var2
  common var2
  var2 = 10
  print *, "var2 before target = ", var2
  !$omp target map(tofrom:var2)
    var2 = 20
  !$omp end target
  print *, "var2 after target = ", var2
end subroutine

! CHECK: var2 before target = 10
! CHECK: var2 after target = 20

! -----

subroutine commonblock_simple_with_real
  use omp_lib
  real :: var3
  common var3
  var3 = 12.5
  print *, "var3 before target = ", var3
  !$omp target map(tofrom:var3)
    var3 = 14.5
  !$omp end target
  print *, "var3 after target = ", var3
end subroutine

! CHECK: var3 before target = 12.5
! CHECK: var3 after target = 14.5

! -----

subroutine commonblock_simple_to_from
  use omp_lib
  integer :: var4, tmp
  common var4
  var4 = 10
  tmp = 20
  !$omp target map(to:var4) map(from:tmp)
    tmp = var4
    var4 = 20
  !$omp end target
  print *, "var4 after target = ", var4
  print *, "tmp after target = ", tmp
end subroutine

! CHECK: var4 after target = 10
! CHECK: tmp after target = 10

! -----

subroutine set_commonblock_named
  integer :: var6
  common /my_common_block/ var6
  var6 = 20
end subroutine

subroutine use_commonblock_named
  integer :: var6
  common /my_common_block/ var6
  print *, "var6 before target = ", var6
  !$omp target map(tofrom: var6)
    var6 = 30
  !$omp end target
  print *, "var6 after target = ", var6
end subroutine

! CHECK: var6 before target = 20
! CHECK: var6 after target = 30