! This test checks lowering of OpenACC routine directive in interfaces. ! RUN: bbc -fopenacc -emit-hlfir %s -o - | FileCheck %s subroutine sub1(a) !$acc routine worker bind(sub2) real :: a(:) end subroutine subroutine sub2(a) !$acc routine worker nohost real :: a(:) end subroutine subroutine test interface subroutine sub1(a) !$acc routine worker bind(sub2) real :: a(:) end subroutine subroutine sub2(a) !$acc routine worker nohost real :: a(:) end subroutine end interface end subroutine ! CHECK: acc.routine @acc_routine_1 func(@_QPsub2) worker nohost ! CHECK: acc.routine @acc_routine_0 func(@_QPsub1) bind("_QPsub2") worker ! CHECK: func.func @_QPsub1(%arg0: !fir.box> {fir.bindc_name = "a"}) attributes {acc.routine_info = #acc.routine_info<[@acc_routine_0]>} ! CHECK: func.func @_QPsub2(%arg0: !fir.box> {fir.bindc_name = "a"}) attributes {acc.routine_info = #acc.routine_info<[@acc_routine_1]>}