mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-13 19:32:41 +00:00
98813e365c
This patch handles the lowering of real comparison operations. The real comparison operations are lowered to `arith.cmpf` operation. This patch is part of the upstreaming effort from fir-dev branch. Reviewed By: PeteSteinfeld, schweitz Differential Revision: https://reviews.llvm.org/D120561 Co-authored-by: Eric Schweitz <eschweitz@nvidia.com> Co-authored-by: Jean Perier <jperier@nvidia.com>
105 lines
3.2 KiB
Fortran
105 lines
3.2 KiB
Fortran
! RUN: bbc %s -o - | FileCheck %s
|
|
|
|
! Test real add on real kinds.
|
|
|
|
! CHECK-LABEL: real2
|
|
REAL(2) FUNCTION real2(x0, x1)
|
|
REAL(2) :: x0
|
|
REAL(2) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f16>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f16>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f16
|
|
real2 = x0 + x1
|
|
! CHECK: return %{{.*}} : f16
|
|
END FUNCTION real2
|
|
|
|
! CHECK-LABEL: real3
|
|
REAL(3) FUNCTION real3(x0, x1)
|
|
REAL(3) :: x0
|
|
REAL(3) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<bf16>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<bf16>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : bf16
|
|
real3 = x0 + x1
|
|
! CHECK: return %{{.*}} : bf16
|
|
END FUNCTION real3
|
|
|
|
! CHECK-LABEL: real4
|
|
REAL(4) FUNCTION real4(x0, x1)
|
|
REAL(4) :: x0
|
|
REAL(4) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f32>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f32>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f32
|
|
real4 = x0 + x1
|
|
! CHECK: return %{{.*}} : f32
|
|
END FUNCTION real4
|
|
|
|
! CHECK-LABEL: defreal
|
|
REAL FUNCTION defreal(x0, x1)
|
|
REAL :: x0
|
|
REAL :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f32>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f32>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f32
|
|
defreal = x0 + x1
|
|
! CHECK: return %{{.*}} : f32
|
|
END FUNCTION defreal
|
|
|
|
! CHECK-LABEL: real8
|
|
REAL(8) FUNCTION real8(x0, x1)
|
|
REAL(8) :: x0
|
|
REAL(8) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f64>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f64>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f64
|
|
real8 = x0 + x1
|
|
! CHECK: return %{{.*}} : f64
|
|
END FUNCTION real8
|
|
|
|
! CHECK-LABEL: doubleprec
|
|
DOUBLE PRECISION FUNCTION doubleprec(x0, x1)
|
|
DOUBLE PRECISION :: x0
|
|
DOUBLE PRECISION :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f64>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f64>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f64
|
|
doubleprec = x0 + x1
|
|
! CHECK: return %{{.*}} : f64
|
|
END FUNCTION doubleprec
|
|
|
|
! CHECK-LABEL: real10
|
|
REAL(10) FUNCTION real10(x0, x1)
|
|
REAL(10) :: x0
|
|
REAL(10) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f80>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f80>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f80
|
|
real10 = x0 + x1
|
|
! CHECK: return %{{.*}} : f80
|
|
END FUNCTION real10
|
|
|
|
! CHECK-LABEL: real16
|
|
REAL(16) FUNCTION real16(x0, x1)
|
|
REAL(16) :: x0
|
|
REAL(16) :: x1
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f128>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f128>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f128
|
|
real16 = x0 + x1
|
|
! CHECK: return %{{.*}} : f128
|
|
END FUNCTION real16
|
|
|
|
! CHECK-LABEL: real16b
|
|
REAL(16) FUNCTION real16b(x0, x1)
|
|
REAL(16) :: x0
|
|
REAL(16) :: x1
|
|
! CHECK-DAG: %[[v0:.+]] = arith.constant 4.0{{.*}} : f128
|
|
! CHECK-DAG: %[[v1:.+]] = fir.load %arg0 : !fir.ref<f128>
|
|
! CHECK-DAG: %[[v2:.+]] = fir.load %arg1 : !fir.ref<f128>
|
|
! CHECK: %[[v3:.+]] = arith.addf %[[v1]], %[[v2]] : f128
|
|
! CHECK: %[[v4:.+]] = arith.subf %[[v3]], %[[v0]] : f128
|
|
real16b = x0 + x1 - 4.0_16
|
|
! CHECK: return %{{.*}} : f128
|
|
END FUNCTION real16b
|