!RUN: %flang_fc1 -emit-hlfir -fopenmp -fopenmp-version=52 %s -o - | FileCheck %s --check-prefixes ALL,HOST
!RUN: %flang_fc1 -emit-hlfir -fopenmp -fopenmp-version=52 -fopenmp-is-device %s -o - | FileCheck %s --check-prefixes ALL
program main
use, intrinsic :: iso_c_binding
implicit none
interface
subroutine any_interface() bind(c,name="any_interface")
use, intrinsic :: iso_c_binding
implicit none
!$omp declare target enter(any_interface) device_type(any)
end subroutine any_interface
subroutine host_interface() bind(c,name="host_interface")
use, intrinsic :: iso_c_binding
implicit none
!$omp declare target enter(host_interface) device_type(host)
end subroutine host_interface
subroutine device_interface() bind(c,name="device_interface")
use, intrinsic :: iso_c_binding
implicit none
!$omp declare target enter(device_interface) device_type(nohost)
end subroutine device_interface
subroutine called_from_target_interface(f1, f2) bind(c,name="called_from_target_interface")
use, intrinsic :: iso_c_binding
implicit none
type(c_funptr),value :: f1
type(c_funptr),value :: f2
end subroutine called_from_target_interface
subroutine called_from_host_interface(f1) bind(c,name="called_from_host_interface")
use, intrinsic :: iso_c_binding
implicit none
type(c_funptr),value :: f1
end subroutine called_from_host_interface
subroutine unused_unemitted_interface() bind(c,name="unused_unemitted_interface")
use, intrinsic :: iso_c_binding
implicit none
!$omp declare target enter(unused_unemitted_interface) device_type(nohost)
end subroutine unused_unemitted_interface
end interface
CALL called_from_host_interface(c_funloc(host_interface))
!$omp target
CALL called_from_target_interface(c_funloc(any_interface), c_funloc(device_interface))
!$omp end target
end program main
!HOST-LABEL: func.func {{.*}} @host_interface()
!HOST-SAME: {{.*}}, omp.declare_target = #omp.declaretarget<device_type = (host), capture_clause = (enter)>{{.*}}
!ALL-LABEL: func.func {{.*}} @called_from_target_interface(!fir.ref<i64>, !fir.ref<i64>)
!ALL-SAME: {{.*}}, omp.declare_target = #omp.declaretarget<device_type = (nohost), capture_clause = (to)>{{.*}}
!ALL-LABEL: func.func {{.*}} @any_interface()
!ALL-SAME: {{.*}}, omp.declare_target = #omp.declaretarget<device_type = (any), capture_clause = (enter)>{{.*}}
!ALL-LABEL: func.func {{.*}} @device_interface()
!ALL-SAME: {{.*}}, omp.declare_target = #omp.declaretarget<device_type = (nohost), capture_clause = (enter)>{{.*}}