| ; REQUIRES: asserts |
| ; RUN: opt -S -passes=dfa-jump-threading %s -debug-only=dfa-jump-threading 2>&1 | FileCheck %s |
| |
| ; CHECK-COUNT-3: Exiting early due to unpredictability heuristic. |
| |
| @.str.1 = private unnamed_addr constant [3 x i8] c"10\00", align 1 |
| @.str.2 = private unnamed_addr constant [3 x i8] c"30\00", align 1 |
| @.str.3 = private unnamed_addr constant [3 x i8] c"20\00", align 1 |
| @.str.4 = private unnamed_addr constant [3 x i8] c"40\00", align 1 |
| |
| define void @test1(i32 noundef %num, i32 noundef %num2) { |
| entry: |
| br label %while.body |
| |
| while.body: ; preds = %entry, %sw.epilog |
| %num.addr.0 = phi i32 [ %num, %entry ], [ %num.addr.1, %sw.epilog ] |
| switch i32 %num.addr.0, label %sw.default [ |
| i32 10, label %sw.bb |
| i32 30, label %sw.bb1 |
| i32 20, label %sw.bb2 |
| i32 40, label %sw.bb3 |
| ] |
| |
| sw.bb: ; preds = %while.body |
| %call.i = tail call i32 @bar(ptr noundef nonnull @.str.1) |
| br label %sw.epilog |
| |
| sw.bb1: ; preds = %while.body |
| %call.i4 = tail call i32 @bar(ptr noundef nonnull @.str.2) |
| br label %sw.epilog |
| |
| sw.bb2: ; preds = %while.body |
| %call.i5 = tail call i32 @bar(ptr noundef nonnull @.str.3) |
| br label %sw.epilog |
| |
| sw.bb3: ; preds = %while.body |
| %call.i6 = tail call i32 @bar(ptr noundef nonnull @.str.4) |
| %call = tail call noundef i32 @foo() |
| %add = add nsw i32 %call, %num2 |
| br label %sw.epilog |
| |
| sw.default: ; preds = %while.body |
| ret void |
| |
| sw.epilog: ; preds = %sw.bb3, %sw.bb2, %sw.bb1, %sw.bb |
| %num.addr.1 = phi i32 [ %add, %sw.bb3 ], [ 40, %sw.bb2 ], [ 20, %sw.bb1 ], [ 30, %sw.bb ] |
| br label %while.body |
| } |
| |
| |
| define void @test2(i32 noundef %num, i32 noundef %num2) { |
| entry: |
| br label %while.body |
| |
| while.body: ; preds = %entry, %sw.epilog |
| %num.addr.0 = phi i32 [ %num, %entry ], [ %num.addr.1, %sw.epilog ] |
| switch i32 %num.addr.0, label %sw.default [ |
| i32 10, label %sw.epilog |
| i32 30, label %sw.bb1 |
| i32 20, label %sw.bb2 |
| i32 40, label %sw.bb3 |
| ] |
| |
| sw.bb1: ; preds = %while.body |
| br label %sw.epilog |
| |
| sw.bb2: ; preds = %while.body |
| br label %sw.epilog |
| |
| sw.bb3: ; preds = %while.body |
| br label %sw.epilog |
| |
| sw.default: ; preds = %while.body |
| ret void |
| |
| sw.epilog: ; preds = %while.body, %sw.bb3, %sw.bb2, %sw.bb1 |
| %.str.4.sink = phi ptr [ @.str.4, %sw.bb3 ], [ @.str.3, %sw.bb2 ], [ @.str.2, %sw.bb1 ], [ @.str.1, %while.body ] |
| %num.addr.1 = phi i32 [ %num2, %sw.bb3 ], [ 40, %sw.bb2 ], [ 20, %sw.bb1 ], [ 30, %while.body ] |
| %call.i6 = tail call i32 @bar(ptr noundef nonnull %.str.4.sink) |
| br label %while.body |
| } |
| |
| |
| define void @test3(i32 noundef %num, i32 noundef %num2) { |
| entry: |
| %add = add nsw i32 %num2, 40 |
| br label %while.body |
| |
| while.body: ; preds = %entry, %sw.epilog |
| %num.addr.0 = phi i32 [ %num, %entry ], [ %num.addr.1, %sw.epilog ] |
| switch i32 %num.addr.0, label %sw.default [ |
| i32 10, label %sw.bb |
| i32 30, label %sw.bb1 |
| i32 20, label %sw.bb2 |
| i32 40, label %sw.bb3 |
| ] |
| |
| sw.bb: ; preds = %while.body |
| %call.i = tail call i32 @bar(ptr noundef nonnull @.str.1) |
| br label %sw.epilog |
| |
| sw.bb1: ; preds = %while.body |
| %call.i5 = tail call i32 @bar(ptr noundef nonnull @.str.2) |
| br label %sw.epilog |
| |
| sw.bb2: ; preds = %while.body |
| %call.i6 = tail call i32 @bar(ptr noundef nonnull @.str.3) |
| br label %sw.epilog |
| |
| sw.bb3: ; preds = %while.body |
| %call.i7 = tail call i32 @bar(ptr noundef nonnull @.str.4) |
| br label %sw.epilog |
| |
| sw.default: ; preds = %while.body |
| ret void |
| |
| sw.epilog: ; preds = %sw.bb3, %sw.bb2, %sw.bb1, %sw.bb |
| %num.addr.1 = phi i32 [ %add, %sw.bb3 ], [ 40, %sw.bb2 ], [ 20, %sw.bb1 ], [ 30, %sw.bb ] |
| br label %while.body |
| } |
| |
| |
| declare noundef i32 @foo() |
| declare noundef i32 @bar(ptr nocapture noundef readonly) |