blob: 8c2788290a8d54c10af2ff7e8e6767c0b791af8e [file] [log] [blame] [edit]
! RUN: %flang_fc1 -emit-hlfir %s -o - | FileCheck %s
! Test integer intrinsic operation lowering to fir.
! CHECK-LABEL: func.func @_QPeq0_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi eq, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION eq0_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
eq0_test = x0 .EQ. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPne1_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi ne, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION ne1_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
ne1_test = x0 .NE. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPlt2_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi slt, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION lt2_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
lt2_test = x0 .LT. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPle3_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi sle, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION le3_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
le3_test = x0 .LE. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPgt4_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi sgt, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION gt4_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
gt4_test = x0 .GT. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPge5_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: %[[reg3:.*]] = arith.cmpi sge, %[[reg1]], %[[reg2]] : i32
! CHECK: fir.convert %[[reg3]] : (i1) -> !fir.logical<4>
LOGICAL FUNCTION ge5_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
ge5_test = x0 .GE. x1
END FUNCTION
! CHECK-LABEL: func.func @_QPadd6_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: arith.addi %[[reg1]], %[[reg2]] : i32
INTEGER(4) FUNCTION add6_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
add6_test = x0 + x1
END FUNCTION
! CHECK-LABEL: func.func @_QPsub7_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: arith.subi %[[reg1]], %[[reg2]] : i32
INTEGER(4) FUNCTION sub7_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
sub7_test = x0 - x1
END FUNCTION
! CHECK-LABEL: func.func @_QPmult8_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: arith.muli %[[reg1]], %[[reg2]] : i32
INTEGER(4) FUNCTION mult8_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
mult8_test = x0 * x1
END FUNCTION
! CHECK-LABEL: func.func @_QPdiv9_test(
! CHECK-SAME: %[[arg0:.*]]: !fir.ref<i32> {{.*}}, %[[arg1:.*]]: !fir.ref<i32> {{.*}})
! CHECK: %[[VAL_1:.*]]:2 = hlfir.declare %[[arg0]]
! CHECK: %[[VAL_2:.*]]:2 = hlfir.declare %[[arg1]]
! CHECK-DAG: %[[reg1:.*]] = fir.load %[[VAL_1]]#0
! CHECK-DAG: %[[reg2:.*]] = fir.load %[[VAL_2]]#0
! CHECK: arith.divsi %[[reg1]], %[[reg2]] : i32
INTEGER(4) FUNCTION div9_test(x0, x1)
INTEGER(4) :: x0
INTEGER(4) :: x1
div9_test = x0 / x1
END FUNCTION