70 lines
2.2 KiB
Fortran
70 lines
2.2 KiB
Fortran
! RUN: bbc -emit-fir %s -o - | FileCheck %s
|
|
! RUN: flang-new -fc1 -emit-fir %s -o - | FileCheck %s
|
|
|
|
! CHECK-LABEL: isnan_f32
|
|
subroutine isnan_f32(r)
|
|
real :: r
|
|
i = isnan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f32) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine isnan_f32
|
|
|
|
! CHECK-LABEL: ieee_is_nan_f32
|
|
subroutine ieee_is_nan_f32(r)
|
|
use ieee_arithmetic
|
|
real :: r
|
|
i = ieee_is_nan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f32) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine ieee_is_nan_f32
|
|
|
|
! CHECK-LABEL: isnan_f64
|
|
subroutine isnan_f64(r)
|
|
real(KIND=8) :: r
|
|
i = isnan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f64) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine isnan_f64
|
|
|
|
! CHECK-LABEL: ieee_is_nan_f64
|
|
subroutine ieee_is_nan_f64(r)
|
|
use ieee_arithmetic
|
|
real(KIND=8) :: r
|
|
i = ieee_is_nan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f64) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine ieee_is_nan_f64
|
|
|
|
! CHECK-LABEL: isnan_f80
|
|
subroutine isnan_f80(r)
|
|
real(KIND=10) :: r
|
|
i = isnan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f80) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine isnan_f80
|
|
|
|
! CHECK-LABEL: ieee_is_nan_f80
|
|
subroutine ieee_is_nan_f80(r)
|
|
use ieee_arithmetic
|
|
real(KIND=10) :: r
|
|
i = ieee_is_nan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f80) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine ieee_is_nan_f80
|
|
|
|
! CHECK-LABEL: isnan_f128
|
|
subroutine isnan_f128(r)
|
|
real(KIND=16) :: r
|
|
i = isnan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f128) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine isnan_f128
|
|
|
|
! CHECK-LABEL: ieee_is_nan_f128
|
|
subroutine ieee_is_nan_f128(r)
|
|
use ieee_arithmetic
|
|
real(KIND=16) :: r
|
|
i = ieee_is_nan(r)
|
|
! CHECK: %[[l:.*]] = "llvm.intr.is.fpclass"(%{{.*}}) <{bit = 3 : i32}> : (f128) -> i1
|
|
! CHECK: fir.convert %[[l]] : (i1) -> !fir.logical<4>
|
|
end subroutine ieee_is_nan_f128
|