| ; RUN: llc -O3 -o - %s | FileCheck %s |
| target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" |
| target triple = "x86_64-unknown-linux-gnu" |
| |
| declare void @effect(i32); |
| |
| ; After the loop gets laid out, loop.end is the only successor, but can't be |
| ; laid out because of the CFG dependency from top.fakephi. The calculations show |
| ; that it isn't profitable to tail-duplicate in this case, because of the |
| ; effects on fallthrough from %loop.end |
| ; CHECK-LABEL: {{^}}no_successor_still_no_taildup: |
| ; CHECK: %entry |
| ; CHECK: %loop.top |
| ; CHECK: %loop.latch |
| ; CHECK: %top.fakephi |
| ; CHECK: %loop.end |
| ; CHECK: %false |
| ; CHECK: %ret |
| define void @no_successor_still_no_taildup (i32 %count, i32 %key) { |
| entry: |
| br label %loop.top |
| |
| loop.top: |
| %i.loop.top = phi i32 [ %count, %entry ], [ %i.latch, %loop.latch ] |
| %cmp.top = icmp eq i32 %i.loop.top, %key |
| call void @effect(i32 0) |
| br i1 %cmp.top, label %top.fakephi, label %loop.latch, !prof !1 |
| |
| loop.latch: |
| %i.latch = sub i32 %i.loop.top, 1 |
| %cmp.latch = icmp eq i32 %i.latch, 0 |
| call void @effect(i32 1) |
| br i1 %cmp.top, label %loop.top, label %loop.end, !prof !2 |
| |
| top.fakephi: |
| call void @effect(i32 2) |
| br label %loop.end |
| |
| loop.end: |
| %cmp.end = icmp eq i32 %count, 0 |
| br i1 %cmp.end, label %ret, label %false, !prof !3 |
| |
| false: |
| call void @effect(i32 4) |
| br label %ret |
| |
| ret: |
| ret void |
| } |
| |
| !1 = !{!"branch_weights", i32 1, i32 1} |
| !2 = !{!"branch_weights", i32 5, i32 1} |
| !3 = !{!"branch_weights", i32 1, i32 2} |