[llvm] r374807 - [Tests] Add a few more tests for idioms with FP induction variables

Philip Reames via llvm-commits llvm-commits at lists.llvm.org
Mon Oct 14 12:10:39 PDT 2019


Author: reames
Date: Mon Oct 14 12:10:39 2019
New Revision: 374807

URL: http://llvm.org/viewvc/llvm-project?rev=374807&view=rev
Log:
[Tests] Add a few more tests for idioms with FP induction variables


Modified:
    llvm/trunk/test/Transforms/IndVarSimplify/floating-point-iv.ll

Modified: llvm/trunk/test/Transforms/IndVarSimplify/floating-point-iv.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/IndVarSimplify/floating-point-iv.ll?rev=374807&r1=374806&r2=374807&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/IndVarSimplify/floating-point-iv.ll (original)
+++ llvm/trunk/test/Transforms/IndVarSimplify/floating-point-iv.ll Mon Oct 14 12:10:39 2019
@@ -139,3 +139,234 @@ define void @test5() nounwind {
 exit:
   ret void
 }
+
+define double @test_max_be() {
+; CHECK-LABEL: @test_max_be(
+; CHECK-NEXT:  bb4:
+; CHECK-NEXT:    br label [[BB8:%.*]]
+; CHECK:       bb8:
+; CHECK-NEXT:    [[TMP10:%.*]] = phi double [ 0.000000e+00, [[BB4:%.*]] ], [ [[TMP12:%.*]], [[BB22:%.*]] ]
+; CHECK-NEXT:    [[TMP11_INT:%.*]] = phi i32 [ 0, [[BB4]] ], [ [[TMP13_INT:%.*]], [[BB22]] ]
+; CHECK-NEXT:    [[INDVAR_CONV:%.*]] = sitofp i32 [[TMP11_INT]] to double
+; CHECK-NEXT:    [[TMP12]] = fadd double [[TMP10]], [[INDVAR_CONV]]
+; CHECK-NEXT:    [[TMP13_INT]] = add nuw nsw i32 [[TMP11_INT]], 1
+; CHECK-NEXT:    [[TMP14:%.*]] = icmp slt i32 [[TMP13_INT]], 99999
+; CHECK-NEXT:    br i1 [[TMP14]], label [[BB22]], label [[BB6:%.*]]
+; CHECK:       bb22:
+; CHECK-NEXT:    br i1 true, label [[BB8]], label [[BB6]]
+; CHECK:       bb6:
+; CHECK-NEXT:    [[TMP12_LCSSA:%.*]] = phi double [ [[TMP12]], [[BB22]] ], [ [[TMP12]], [[BB8]] ]
+; CHECK-NEXT:    ret double [[TMP12_LCSSA]]
+;
+bb4:
+  br label %bb8
+
+bb8:
+  %tmp9 = phi i64 [ 1, %bb4 ], [ %tmp23, %bb22 ]
+  %tmp10 = phi double [ 0.000000e+00, %bb4 ], [ %tmp12, %bb22 ]
+  %tmp11 = phi double [ 0.000000e+00, %bb4 ], [ %tmp13, %bb22 ]
+  %tmp12 = fadd double %tmp10, %tmp11
+  %tmp13 = fadd double %tmp11, 1.000000e+00
+  %tmp14 = fcmp olt double %tmp13, 9.999900e+04
+  br i1 %tmp14, label %bb22, label %bb6
+
+bb22:
+  %tmp23 = add nuw nsw i64 %tmp9, 1
+  %tmp24 = icmp ult i64 %tmp9, 1048576
+  br i1 %tmp24, label %bb8, label %bb6
+
+bb6:
+  ret double %tmp12
+}
+
+define float @test_max_be2() {
+; CHECK-LABEL: @test_max_be2(
+; CHECK-NEXT:  bb4:
+; CHECK-NEXT:    br label [[BB8:%.*]]
+; CHECK:       bb8:
+; CHECK-NEXT:    [[TMP10:%.*]] = phi float [ 0.000000e+00, [[BB4:%.*]] ], [ [[TMP12:%.*]], [[BB22:%.*]] ]
+; CHECK-NEXT:    [[TMP11_INT:%.*]] = phi i32 [ 0, [[BB4]] ], [ [[TMP13_INT:%.*]], [[BB22]] ]
+; CHECK-NEXT:    [[INDVAR_CONV:%.*]] = sitofp i32 [[TMP11_INT]] to float
+; CHECK-NEXT:    [[TMP12]] = fadd float [[TMP10]], [[INDVAR_CONV]]
+; CHECK-NEXT:    [[TMP13_INT]] = add nuw nsw i32 [[TMP11_INT]], 1
+; CHECK-NEXT:    [[TMP14:%.*]] = icmp slt i32 [[TMP13_INT]], 99999
+; CHECK-NEXT:    br i1 [[TMP14]], label [[BB22]], label [[BB6:%.*]]
+; CHECK:       bb22:
+; CHECK-NEXT:    br i1 true, label [[BB8]], label [[BB6]]
+; CHECK:       bb6:
+; CHECK-NEXT:    [[TMP12_LCSSA:%.*]] = phi float [ [[TMP12]], [[BB22]] ], [ [[TMP12]], [[BB8]] ]
+; CHECK-NEXT:    ret float [[TMP12_LCSSA]]
+;
+bb4:
+  br label %bb8
+
+bb8:
+  %tmp9 = phi i64 [ 1, %bb4 ], [ %tmp23, %bb22 ]
+  %tmp10 = phi float [ 0.000000e+00, %bb4 ], [ %tmp12, %bb22 ]
+  %tmp11 = phi float [ 0.000000e+00, %bb4 ], [ %tmp13, %bb22 ]
+  %tmp12 = fadd float %tmp10, %tmp11
+  %tmp13 = fadd float %tmp11, 1.000000e+00
+  %tmp14 = fcmp olt float %tmp13, 9.999900e+04
+  br i1 %tmp14, label %bb22, label %bb6
+
+bb22:
+  %tmp23 = add nuw nsw i64 %tmp9, 1
+  %tmp24 = icmp ult i64 %tmp9, 1048576
+  br i1 %tmp24, label %bb8, label %bb6
+
+bb6:
+  ret float %tmp12
+}
+
+; Bounds check
+define float @test_max_be3() {
+; CHECK-LABEL: @test_max_be3(
+; CHECK-NEXT:  bb4:
+; CHECK-NEXT:    br label [[BB8:%.*]]
+; CHECK:       bb8:
+; CHECK-NEXT:    [[TMP10:%.*]] = phi float [ 0.000000e+00, [[BB4:%.*]] ], [ [[TMP12:%.*]], [[BB22:%.*]] ]
+; CHECK-NEXT:    [[TMP11_INT:%.*]] = phi i32 [ 0, [[BB4]] ], [ [[TMP13_INT:%.*]], [[BB22]] ]
+; CHECK-NEXT:    [[INDVAR_CONV:%.*]] = sitofp i32 [[TMP11_INT]] to float
+; CHECK-NEXT:    [[TMP12]] = fadd float [[TMP10]], [[INDVAR_CONV]]
+; CHECK-NEXT:    [[TMP13_INT]] = add nuw nsw i32 [[TMP11_INT]], 1
+; CHECK-NEXT:    [[TMP14:%.*]] = icmp slt i32 [[TMP13_INT]], 99999
+; CHECK-NEXT:    br i1 [[TMP14]], label [[BB22]], label [[BB6:%.*]]
+; CHECK:       bb22:
+; CHECK-NEXT:    br i1 true, label [[BB8]], label [[BB6]]
+; CHECK:       bb6:
+; CHECK-NEXT:    [[TMP12_LCSSA:%.*]] = phi float [ [[TMP12]], [[BB22]] ], [ [[TMP12]], [[BB8]] ]
+; CHECK-NEXT:    ret float [[TMP12_LCSSA]]
+;
+bb4:
+  br label %bb8
+
+bb8:
+  %tmp9 = phi i64 [ 1, %bb4 ], [ %tmp23, %bb22 ]
+  %tmp10 = phi float [ 0.000000e+00, %bb4 ], [ %tmp12, %bb22 ]
+  %tmp11 = phi float [ 0.000000e+00, %bb4 ], [ %tmp13, %bb22 ]
+  %tmp12 = fadd float %tmp10, %tmp11
+  %tmp13 = fadd float %tmp11, 1.000000e+00
+  %tmp14 = fcmp olt float %tmp13, 9.999900e+04
+  br i1 %tmp14, label %bb22, label %bb6
+
+bb22:
+  %tmp23 = add nuw nsw i64 %tmp9, 1
+  ;; 2^23 = 16777215
+  %tmp24 = icmp ult i64 %tmp9, 16777215
+  br i1 %tmp24, label %bb8, label %bb6
+
+bb6:
+  ret float %tmp12
+}
+
+
+; Show that given a computeable exit count, we can remove an
+; fcmp of a casted integer IV. (TODO)
+define void @fcmp1() nounwind {
+; CHECK-LABEL: @fcmp1(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br label [[BB:%.*]]
+; CHECK:       bb:
+; CHECK-NEXT:    [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[BACKEDGE:%.*]] ]
+; CHECK-NEXT:    [[CMP1:%.*]] = icmp ult i64 [[IV]], 20000
+; CHECK-NEXT:    br i1 [[CMP1]], label [[BACKEDGE]], label [[RETURN:%.*]]
+; CHECK:       backedge:
+; CHECK-NEXT:    [[IV_FP:%.*]] = sitofp i64 [[IV]] to double
+; CHECK-NEXT:    [[TMP0:%.*]] = tail call i32 @foo(double [[IV_FP]]) #0
+; CHECK-NEXT:    [[IV_NEXT]] = add nuw nsw i64 [[IV]], 1
+; CHECK-NEXT:    [[CMP2:%.*]] = fcmp olt double [[IV_FP]], 1.000000e+04
+; CHECK-NEXT:    br i1 [[CMP2]], label [[BB]], label [[RETURN]]
+; CHECK:       return:
+; CHECK-NEXT:    ret void
+;
+entry:
+  br label %bb
+
+bb:		; preds = %bb, %entry
+  %iv = phi i64 [ 0, %entry ], [ %iv.next, %backedge ]
+  %cmp1 = icmp slt i64 %iv, 20000
+  br i1 %cmp1, label %backedge, label %return
+
+backedge:
+  %iv.fp = sitofp i64 %iv to double
+  tail call i32 @foo(double %iv.fp) nounwind
+  %iv.next = add nsw nuw i64 %iv, 1
+  %cmp2 = fcmp olt double %iv.fp, 1.000000e+04
+  br i1 %cmp2, label %bb, label %return
+
+return:		; preds = %bb
+  ret void
+}
+
+define void @fcmp2() nounwind {
+; CHECK-LABEL: @fcmp2(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br label [[BB:%.*]]
+; CHECK:       bb:
+; CHECK-NEXT:    [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[BACKEDGE:%.*]] ]
+; CHECK-NEXT:    [[CMP1:%.*]] = icmp ult i64 [[IV]], 2000
+; CHECK-NEXT:    br i1 [[CMP1]], label [[BACKEDGE]], label [[RETURN:%.*]]
+; CHECK:       backedge:
+; CHECK-NEXT:    [[IV_FP:%.*]] = sitofp i64 [[IV]] to double
+; CHECK-NEXT:    [[TMP0:%.*]] = tail call i32 @foo(double [[IV_FP]]) #0
+; CHECK-NEXT:    [[IV_NEXT]] = add nuw nsw i64 [[IV]], 1
+; CHECK-NEXT:    [[CMP2:%.*]] = fcmp olt double [[IV_FP]], 1.000000e+04
+; CHECK-NEXT:    br i1 [[CMP2]], label [[BB]], label [[RETURN]]
+; CHECK:       return:
+; CHECK-NEXT:    ret void
+;
+entry:
+  br label %bb
+
+bb:		; preds = %bb, %entry
+  %iv = phi i64 [ 0, %entry ], [ %iv.next, %backedge ]
+  %cmp1 = icmp slt i64 %iv, 2000
+  br i1 %cmp1, label %backedge, label %return
+
+backedge:
+  %iv.fp = sitofp i64 %iv to double
+  tail call i32 @foo(double %iv.fp) nounwind
+  %iv.next = add nsw nuw i64 %iv, 1
+  %cmp2 = fcmp olt double %iv.fp, 1.000000e+04
+  br i1 %cmp2, label %bb, label %return
+
+return:		; preds = %bb
+  ret void
+}
+
+define void @fcmp_neg1() nounwind {
+; CHECK-LABEL: @fcmp_neg1(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br label [[BB:%.*]]
+; CHECK:       bb:
+; CHECK-NEXT:    [[IV:%.*]] = phi i64 [ 0, [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[BACKEDGE:%.*]] ]
+; CHECK-NEXT:    [[CMP1:%.*]] = icmp ult i64 [[IV]], -20
+; CHECK-NEXT:    br i1 [[CMP1]], label [[BACKEDGE]], label [[RETURN:%.*]]
+; CHECK:       backedge:
+; CHECK-NEXT:    [[IV_FP:%.*]] = sitofp i64 [[IV]] to double
+; CHECK-NEXT:    [[TMP0:%.*]] = tail call i32 @foo(double [[IV_FP]]) #0
+; CHECK-NEXT:    [[IV_NEXT]] = add nuw i64 [[IV]], 1
+; CHECK-NEXT:    [[CMP2:%.*]] = fcmp olt double [[IV_FP]], 1.000000e+04
+; CHECK-NEXT:    br i1 [[CMP2]], label [[BB]], label [[RETURN]]
+; CHECK:       return:
+; CHECK-NEXT:    ret void
+;
+entry:
+  br label %bb
+
+bb:		; preds = %bb, %entry
+  %iv = phi i64 [ 0, %entry ], [ %iv.next, %backedge ]
+  ;; Range fact outside precise integer region
+  %cmp1 = icmp ult i64 %iv, -20
+  br i1 %cmp1, label %backedge, label %return
+
+backedge:
+  %iv.fp = sitofp i64 %iv to double
+  tail call i32 @foo(double %iv.fp) nounwind
+  %iv.next = add nuw i64 %iv, 1
+  %cmp2 = fcmp olt double %iv.fp, 1.000000e+04
+  br i1 %cmp2, label %bb, label %return
+
+return:		; preds = %bb
+  ret void
+}




More information about the llvm-commits mailing list