[llvm] 005db9c - [Test] Add test showing InstCombine missing simplification opportunity

Max Kazantsev via llvm-commits llvm-commits at lists.llvm.org
Sun Jun 7 23:44:31 PDT 2020


Author: Max Kazantsev
Date: 2020-06-08T13:19:09+07:00
New Revision: 005db9c361f317259daa5aa07b6700a1af671f69

URL: https://github.com/llvm/llvm-project/commit/005db9c361f317259daa5aa07b6700a1af671f69
DIFF: https://github.com/llvm/llvm-project/commit/005db9c361f317259daa5aa07b6700a1af671f69.diff

LOG: [Test] Add test showing InstCombine missing simplification opportunity

Added: 
    llvm/test/Transforms/InstCombine/simple_phi_condition.ll

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/llvm/test/Transforms/InstCombine/simple_phi_condition.ll b/llvm/test/Transforms/InstCombine/simple_phi_condition.ll
new file mode 100644
index 000000000000..cded618fba16
--- /dev/null
+++ b/llvm/test/Transforms/InstCombine/simple_phi_condition.ll
@@ -0,0 +1,143 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -S < %s -instcombine | FileCheck %s
+; RUN: opt -S < %s -passes=instcombine | FileCheck %s
+
+; TODO: Simplify to "ret cond".
+define i1 @test_direct_implication(i1 %cond) {
+; CHECK-LABEL: @test_direct_implication(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_TRUE:%.*]], label [[IF_FALSE:%.*]]
+; CHECK:       if.true:
+; CHECK-NEXT:    br label [[MERGE:%.*]]
+; CHECK:       if.false:
+; CHECK-NEXT:    br label [[MERGE]]
+; CHECK:       merge:
+; CHECK-NEXT:    [[RET:%.*]] = phi i1 [ true, [[IF_TRUE]] ], [ false, [[IF_FALSE]] ]
+; CHECK-NEXT:    ret i1 [[RET]]
+;
+entry:
+  br i1 %cond, label %if.true, label %if.false
+
+if.true:
+  br label %merge
+
+if.false:
+  br label %merge
+
+merge:
+  %ret = phi i1 [true, %if.true], [false, %if.false]
+  ret i1 %ret
+}
+
+; TODO: Simplify to "ret !cond".
+define i1 @test_inverted_implication(i1 %cond) {
+; CHECK-LABEL: @test_inverted_implication(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_TRUE:%.*]], label [[IF_FALSE:%.*]]
+; CHECK:       if.true:
+; CHECK-NEXT:    br label [[MERGE:%.*]]
+; CHECK:       if.false:
+; CHECK-NEXT:    br label [[MERGE]]
+; CHECK:       merge:
+; CHECK-NEXT:    [[RET:%.*]] = phi i1 [ false, [[IF_TRUE]] ], [ true, [[IF_FALSE]] ]
+; CHECK-NEXT:    ret i1 [[RET]]
+;
+entry:
+  br i1 %cond, label %if.true, label %if.false
+
+if.true:
+  br label %merge
+
+if.false:
+  br label %merge
+
+merge:
+  %ret = phi i1 [false, %if.true], [true, %if.false]
+  ret i1 %ret
+}
+
+; TODO: Simplify to "ret cond".
+define i1 @test_direct_implication_complex_cfg(i1 %cond, i32 %cnt1) {
+; CHECK-LABEL: @test_direct_implication_complex_cfg(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_TRUE:%.*]], label [[IF_FALSE:%.*]]
+; CHECK:       if.true:
+; CHECK-NEXT:    br label [[LOOP1:%.*]]
+; CHECK:       loop1:
+; CHECK-NEXT:    [[IV1:%.*]] = phi i32 [ 0, [[IF_TRUE]] ], [ [[IV1_NEXT:%.*]], [[LOOP1]] ]
+; CHECK-NEXT:    [[IV1_NEXT]] = add i32 [[IV1]], 1
+; CHECK-NEXT:    [[LOOP_COND_1:%.*]] = icmp slt i32 [[IV1_NEXT]], [[CNT1:%.*]]
+; CHECK-NEXT:    br i1 [[LOOP_COND_1]], label [[LOOP1]], label [[IF_TRUE_END:%.*]]
+; CHECK:       if.true.end:
+; CHECK-NEXT:    br label [[MERGE:%.*]]
+; CHECK:       if.false:
+; CHECK-NEXT:    br label [[MERGE]]
+; CHECK:       merge:
+; CHECK-NEXT:    [[RET:%.*]] = phi i1 [ true, [[IF_TRUE_END]] ], [ false, [[IF_FALSE]] ]
+; CHECK-NEXT:    ret i1 [[RET]]
+;
+entry:
+  br i1 %cond, label %if.true, label %if.false
+
+if.true:
+  br label %loop1
+
+loop1:
+  %iv1 = phi i32 [0, %if.true], [%iv1.next, %loop1]
+  %iv1.next = add i32 %iv1, 1
+  %loop.cond.1 = icmp slt i32 %iv1.next, %cnt1
+  br i1 %loop.cond.1, label %loop1, label %if.true.end
+
+if.true.end:
+  br label %merge
+
+if.false:
+  br label %merge
+
+merge:
+  %ret = phi i1 [true, %if.true.end], [false, %if.false]
+  ret i1 %ret
+}
+
+; TODO: Simplify to "ret !cond".
+define i1 @test_inverted_implication_complex_cfg(i1 %cond, i32 %cnt1) {
+; CHECK-LABEL: @test_inverted_implication_complex_cfg(
+; CHECK-NEXT:  entry:
+; CHECK-NEXT:    br i1 [[COND:%.*]], label [[IF_TRUE:%.*]], label [[IF_FALSE:%.*]]
+; CHECK:       if.true:
+; CHECK-NEXT:    br label [[LOOP1:%.*]]
+; CHECK:       loop1:
+; CHECK-NEXT:    [[IV1:%.*]] = phi i32 [ 0, [[IF_TRUE]] ], [ [[IV1_NEXT:%.*]], [[LOOP1]] ]
+; CHECK-NEXT:    [[IV1_NEXT]] = add i32 [[IV1]], 1
+; CHECK-NEXT:    [[LOOP_COND_1:%.*]] = icmp slt i32 [[IV1_NEXT]], [[CNT1:%.*]]
+; CHECK-NEXT:    br i1 [[LOOP_COND_1]], label [[LOOP1]], label [[IF_TRUE_END:%.*]]
+; CHECK:       if.true.end:
+; CHECK-NEXT:    br label [[MERGE:%.*]]
+; CHECK:       if.false:
+; CHECK-NEXT:    br label [[MERGE]]
+; CHECK:       merge:
+; CHECK-NEXT:    [[RET:%.*]] = phi i1 [ false, [[IF_TRUE_END]] ], [ true, [[IF_FALSE]] ]
+; CHECK-NEXT:    ret i1 [[RET]]
+;
+entry:
+  br i1 %cond, label %if.true, label %if.false
+
+if.true:
+  br label %loop1
+
+loop1:
+  %iv1 = phi i32 [0, %if.true], [%iv1.next, %loop1]
+  %iv1.next = add i32 %iv1, 1
+  %loop.cond.1 = icmp slt i32 %iv1.next, %cnt1
+  br i1 %loop.cond.1, label %loop1, label %if.true.end
+
+if.true.end:
+  br label %merge
+
+if.false:
+  br label %merge
+
+merge:
+  %ret = phi i1 [false, %if.true.end], [true, %if.false]
+  ret i1 %ret
+}


        


More information about the llvm-commits mailing list