[llvm] 690f769 - [Test] Add simple test where IndVars fails to remove checks on negative values

Max Kazantsev via llvm-commits llvm-commits at lists.llvm.org
Fri Sep 17 01:41:02 PDT 2021


Author: Max Kazantsev
Date: 2021-09-17T15:40:32+07:00
New Revision: 690f76958a737ebd1b17f9bc50f781b3aaa4f011

URL: https://github.com/llvm/llvm-project/commit/690f76958a737ebd1b17f9bc50f781b3aaa4f011
DIFF: https://github.com/llvm/llvm-project/commit/690f76958a737ebd1b17f9bc50f781b3aaa4f011.diff

LOG: [Test] Add simple test where IndVars fails to remove checks on negative values

Added: 
    llvm/test/Transforms/IndVarSimplify/negative_ranges.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/IndVarSimplify/negative_ranges.ll b/llvm/test/Transforms/IndVarSimplify/negative_ranges.ll
new file mode 100644
index 000000000000..41b5b4846b98
--- /dev/null
+++ b/llvm/test/Transforms/IndVarSimplify/negative_ranges.ll
@@ -0,0 +1,105 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -indvars -S < %s | FileCheck %s
+; RUN: opt -passes=indvars -S < %s | FileCheck %s
+
+declare i1 @cond()
+
+; FIXME: 2nd check is implied by the 1st one as both values are negative.
+define i32 @test_01(i32* %p, i32* %s) {
+; CHECK-LABEL: @test_01(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    [[START:%.*]] = load i32, i32* [[P:%.*]], align 4, !range [[RNG0:![0-9]+]]
+; CHECK-NEXT:    [[END:%.*]] = load i32, i32* [[S:%.*]], align 4, !range [[RNG0]]
+; CHECK-NEXT:    br label [[LOOP:%.*]]
+; CHECK:       loop:
+; CHECK-NEXT:    [[IV:%.*]] = phi i32 [ [[START]], [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[BACKEDGE:%.*]] ]
+; CHECK-NEXT:    [[C1:%.*]] = icmp slt i32 [[IV]], [[END]]
+; CHECK-NEXT:    br i1 [[C1]], label [[GUARDED:%.*]], label [[SIDE_EXIT:%.*]]
+; CHECK:       guarded:
+; CHECK-NEXT:    [[C2:%.*]] = icmp ult i32 [[IV]], [[END]]
+; CHECK-NEXT:    br i1 [[C2]], label [[BACKEDGE]], label [[SIDE_EXIT]]
+; CHECK:       backedge:
+; CHECK-NEXT:    [[IV_NEXT]] = add nuw nsw i32 [[IV]], 1
+; CHECK-NEXT:    [[LOOP_COND:%.*]] = call i1 @cond()
+; CHECK-NEXT:    br i1 [[LOOP_COND]], label [[LOOP]], label [[EXIT:%.*]]
+; CHECK:       exit:
+; CHECK-NEXT:    ret i32 1
+; CHECK:       side_exit:
+; CHECK-NEXT:    ret i32 0
+;
+entry:
+  %start = load i32, i32* %p, !range !0
+  %end = load i32, i32* %s, !range !0
+  br label %loop
+
+loop:
+  %iv = phi i32 [%start, %entry], [%iv.next, %backedge]
+  %c1 = icmp slt i32 %iv, %end
+  br i1 %c1, label %guarded, label %side_exit
+
+guarded:
+  %c2 = icmp ult i32 %iv, %end
+  br i1 %c2, label %backedge, label %side_exit
+
+backedge:
+  %iv.next = add nuw nsw i32 %iv, 1
+  %loop.cond = call i1 @cond()
+  br i1 %loop.cond, label %loop, label %exit
+
+exit:
+  ret i32 1
+
+side_exit:
+  ret i32 0
+}
+
+; FIXME: 2nd check is implied by the 1st one as both values are negative.
+define i32 @test_02(i32* %p, i32* %s) {
+; CHECK-LABEL: @test_02(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    [[START:%.*]] = load i32, i32* [[P:%.*]], align 4, !range [[RNG0]]
+; CHECK-NEXT:    [[END:%.*]] = load i32, i32* [[S:%.*]], align 4, !range [[RNG0]]
+; CHECK-NEXT:    br label [[LOOP:%.*]]
+; CHECK:       loop:
+; CHECK-NEXT:    [[IV:%.*]] = phi i32 [ [[START]], [[ENTRY:%.*]] ], [ [[IV_NEXT:%.*]], [[BACKEDGE:%.*]] ]
+; CHECK-NEXT:    [[C1:%.*]] = icmp ult i32 [[IV]], [[END]]
+; CHECK-NEXT:    br i1 [[C1]], label [[GUARDED:%.*]], label [[SIDE_EXIT:%.*]]
+; CHECK:       guarded:
+; CHECK-NEXT:    [[C2:%.*]] = icmp slt i32 [[IV]], [[END]]
+; CHECK-NEXT:    br i1 [[C2]], label [[BACKEDGE]], label [[SIDE_EXIT]]
+; CHECK:       backedge:
+; CHECK-NEXT:    [[IV_NEXT]] = add nuw nsw i32 [[IV]], 1
+; CHECK-NEXT:    [[LOOP_COND:%.*]] = call i1 @cond()
+; CHECK-NEXT:    br i1 [[LOOP_COND]], label [[LOOP]], label [[EXIT:%.*]]
+; CHECK:       exit:
+; CHECK-NEXT:    ret i32 1
+; CHECK:       side_exit:
+; CHECK-NEXT:    ret i32 0
+;
+entry:
+  %start = load i32, i32* %p, !range !0
+  %end = load i32, i32* %s, !range !0
+  br label %loop
+
+loop:
+  %iv = phi i32 [%start, %entry], [%iv.next, %backedge]
+  %c1 = icmp ult i32 %iv, %end
+  br i1 %c1, label %guarded, label %side_exit
+
+guarded:
+  %c2 = icmp slt i32 %iv, %end
+  br i1 %c2, label %backedge, label %side_exit
+
+backedge:
+  %iv.next = add nuw nsw i32 %iv, 1
+  %loop.cond = call i1 @cond()
+  br i1 %loop.cond, label %loop, label %exit
+
+exit:
+  ret i32 1
+
+side_exit:
+  ret i32 0
+}
+
+!0 = !{i32 -1000, i32 0}


        


More information about the llvm-commits mailing list