diff --git a/flang/module/cudadevice.f90 b/flang/module/cudadevice.f90 index 65c703df0a905..d21ee98658991 100644 --- a/flang/module/cudadevice.f90 +++ b/flang/module/cudadevice.f90 @@ -738,7 +738,7 @@ attributes(device) real(8) function sinpi(x) bind(c,name='__nv_sinpi') end interface interface __int2double_rn - attributes(device) double precision function __int2double_rn(i) bind(c) + attributes(device) double precision function __int2double_rn(i) bind(c, name='__nv_int2double_rn') !dir$ ignore_tkr (d) i integer, value :: i end function diff --git a/flang/test/Lower/CUDA/cuda-libdevice.cuf b/flang/test/Lower/CUDA/cuda-libdevice.cuf index 7bb2ab065316a..0e024f06d06d0 100644 --- a/flang/test/Lower/CUDA/cuda-libdevice.cuf +++ b/flang/test/Lower/CUDA/cuda-libdevice.cuf @@ -245,6 +245,15 @@ end subroutine ! CHECK: %{{.*}} = fir.call @__nv_float2uint_ru(%{{.*}}) proc_attrs fastmath : (f32) -> i32 ! CHECK: %{{.*}} = fir.call @__nv_float2uint_rz(%{{.*}}) proc_attrs fastmath : (f32) -> i32 +attributes(global) subroutine test_int2double_rn() + double precision :: res + integer :: r + res = __int2double_rn(r) +end subroutine + +! CHECK-LABEL: _QPtest_int2double_rn +! CHECK: %{{.*}} = fir.call @__nv_int2double_rn(%{{.*}}) proc_attrs fastmath : (i32) -> f64 + attributes(global) subroutine test_fdividef() real :: res real :: r