[llvm] 920e267 - [JumpThreading] Add a test for D84598; NFC
Juneyoung Lee via llvm-commits
llvm-commits at lists.llvm.org
Sun Jul 26 06:00:23 PDT 2020
Author: Juneyoung Lee
Date: 2020-07-26T22:00:01+09:00
New Revision: 920e26797451774b29debfaa3faaca2cb18cfb1e
URL: https://github.com/llvm/llvm-project/commit/920e26797451774b29debfaa3faaca2cb18cfb1e
DIFF: https://github.com/llvm/llvm-project/commit/920e26797451774b29debfaa3faaca2cb18cfb1e.diff
LOG: [JumpThreading] Add a test for D84598; NFC
Added:
llvm/test/Transforms/JumpThreading/freeze.ll
Modified:
Removed:
################################################################################
diff --git a/llvm/test/Transforms/JumpThreading/freeze.ll b/llvm/test/Transforms/JumpThreading/freeze.ll
new file mode 100644
index 000000000000..37d2ad672f78
--- /dev/null
+++ b/llvm/test/Transforms/JumpThreading/freeze.ll
@@ -0,0 +1,94 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -jump-threading -S < %s | FileCheck %s
+
+declare i32 @f1()
+declare i32 @f2()
+declare void @f3()
+
+define i32 @test1(i1 %cond) {
+; CHECK-LABEL: @test1(
+; CHECK-NEXT: br i1 [[COND:%.*]], label [[T1:%.*]], label [[F1:%.*]]
+; CHECK: T1:
+; CHECK-NEXT: [[V1:%.*]] = call i32 @f1()
+; CHECK-NEXT: br label [[MERGE:%.*]]
+; CHECK: F1:
+; CHECK-NEXT: [[V2:%.*]] = call i32 @f2()
+; CHECK-NEXT: br label [[MERGE]]
+; CHECK: Merge:
+; CHECK-NEXT: [[A:%.*]] = phi i1 [ true, [[T1]] ], [ false, [[F1]] ]
+; CHECK-NEXT: [[B:%.*]] = phi i32 [ [[V1]], [[T1]] ], [ [[V2]], [[F1]] ]
+; CHECK-NEXT: [[A_FR:%.*]] = freeze i1 [[A]]
+; CHECK-NEXT: br i1 [[A_FR]], label [[T2:%.*]], label [[F2:%.*]]
+; CHECK: T2:
+; CHECK-NEXT: call void @f3()
+; CHECK-NEXT: ret i32 [[B]]
+; CHECK: F2:
+; CHECK-NEXT: ret i32 [[B]]
+;
+ br i1 %cond, label %T1, label %F1
+
+T1:
+ %v1 = call i32 @f1()
+ br label %Merge
+
+F1:
+ %v2 = call i32 @f2()
+ br label %Merge
+
+Merge:
+ %A = phi i1 [true, %T1], [false, %F1]
+ %B = phi i32 [%v1, %T1], [%v2, %F1]
+ %A.fr = freeze i1 %A
+ br i1 %A.fr, label %T2, label %F2
+
+T2:
+ call void @f3()
+ ret i32 %B
+
+F2:
+ ret i32 %B
+}
+
+define i32 @test2(i1 %cond, i1 %cond2) {
+; CHECK-LABEL: @test2(
+; CHECK-NEXT: br i1 [[COND:%.*]], label [[T1:%.*]], label [[F1:%.*]]
+; CHECK: T1:
+; CHECK-NEXT: [[V1:%.*]] = call i32 @f1()
+; CHECK-NEXT: br label [[MERGE:%.*]]
+; CHECK: F1:
+; CHECK-NEXT: [[V2:%.*]] = call i32 @f2()
+; CHECK-NEXT: br label [[MERGE]]
+; CHECK: Merge:
+; CHECK-NEXT: [[A:%.*]] = phi i1 [ true, [[T1]] ], [ [[COND2:%.*]], [[F1]] ]
+; CHECK-NEXT: [[B:%.*]] = phi i32 [ [[V1]], [[T1]] ], [ [[V2]], [[F1]] ]
+; CHECK-NEXT: [[A_FR:%.*]] = freeze i1 [[A]]
+; CHECK-NEXT: br i1 [[A_FR]], label [[T2:%.*]], label [[F2:%.*]]
+; CHECK: T2:
+; CHECK-NEXT: call void @f3()
+; CHECK-NEXT: ret i32 [[B]]
+; CHECK: F2:
+; CHECK-NEXT: ret i32 [[B]]
+;
+ br i1 %cond, label %T1, label %F1
+
+T1:
+ %v1 = call i32 @f1()
+ br label %Merge
+
+F1:
+ %v2 = call i32 @f2()
+ br label %Merge
+
+Merge:
+ %A = phi i1 [true, %T1], [%cond2, %F1]
+ %B = phi i32 [%v1, %T1], [%v2, %F1]
+ %A.fr = freeze i1 %A
+ br i1 %A.fr, label %T2, label %F2
+
+T2:
+ call void @f3()
+ ret i32 %B
+
+F2:
+ ret i32 %B
+}
More information about the llvm-commits
mailing list