From: Juneyoung Lee Date: Tue, 4 Aug 2020 09:15:00 +0000 (+0900) Subject: [JumpThreading] Add a test for simplification of cast of any op; NFC X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=e218da7ff39df3aeb7c923fbd75aaa8ace581e37;p=platform%2Fupstream%2Fllvm.git [JumpThreading] Add a test for simplification of cast of any op; NFC --- diff --git a/llvm/test/Transforms/JumpThreading/threadable-edge-cast.ll b/llvm/test/Transforms/JumpThreading/threadable-edge-cast.ll new file mode 100644 index 0000000..71c34de --- /dev/null +++ b/llvm/test/Transforms/JumpThreading/threadable-edge-cast.ll @@ -0,0 +1,101 @@ +; 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() + +; trunc(and) should be simplified +define i32 @test(i1 %cond0) { +; CHECK-LABEL: @test( +; CHECK-NEXT: br i1 [[COND0:%.*]], 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 i32 [ 10, [[T1]] ], [ 0, [[F1]] ] +; CHECK-NEXT: [[B:%.*]] = phi i32 [ [[V1]], [[T1]] ], [ [[V2]], [[F1]] ] +; CHECK-NEXT: [[AND:%.*]] = and i32 [[A]], 1 +; CHECK-NEXT: [[COND:%.*]] = trunc i32 [[AND]] to i1 +; CHECK-NEXT: br i1 [[COND]], 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 %cond0, label %T1, label %F1 +T1: + %v1 = call i32 @f1() + br label %Merge + +F1: + %v2 = call i32 @f2() + br label %Merge + +Merge: + %A = phi i32 [10, %T1], [0, %F1] + %B = phi i32 [%v1, %T1], [%v2, %F1] + %And = and i32 %A, 1 + %cond = trunc i32 %And to i1 + br i1 %cond, label %T2, label %F2 + +T2: + call void @f3() + ret i32 %B + +F2: + ret i32 %B +} + +; trunc(select) should be simplified +define i32 @test2(i1 %cond0) { +; CHECK-LABEL: @test2( +; CHECK-NEXT: br i1 [[COND0:%.*]], 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: [[A2:%.*]] = xor i1 [[A]], true +; CHECK-NEXT: [[SEL:%.*]] = select i1 [[A2]], i32 10, i32 0 +; CHECK-NEXT: [[COND:%.*]] = trunc i32 [[SEL]] to i1 +; CHECK-NEXT: br i1 [[COND]], 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 %cond0, label %T1, label %F1 +T1: + %v1 = call i32 @f1() + br label %Merge + +F1: + %v2 = call i32 @f2() + br label %Merge + +Merge: + %A = phi i1 [1, %T1], [0, %F1] + %B = phi i32 [%v1, %T1], [%v2, %F1] + %A2 = xor i1 %A, 1 + %sel = select i1 %A2, i32 10, i32 0 + %cond = trunc i32 %sel to i1 + br i1 %cond, label %T2, label %F2 + +T2: + call void @f3() + ret i32 %B + +F2: + ret i32 %B +} +