diff options
author | Cong Hou <congh@google.com> | 2015-10-12 19:44:08 +0000 |
---|---|---|
committer | Cong Hou <congh@google.com> | 2015-10-12 19:44:08 +0000 |
commit | 3320bcd81569bcf9dc73b02bfc6b08352ab4cf22 (patch) | |
tree | 88cd719539b68524d4b7d19904618552db71df07 /llvm/test/Transforms/JumpThreading | |
parent | 4a5f35c0aec040614e01f70c988b557641542fdb (diff) | |
download | bcm5719-llvm-3320bcd81569bcf9dc73b02bfc6b08352ab4cf22.tar.gz bcm5719-llvm-3320bcd81569bcf9dc73b02bfc6b08352ab4cf22.zip |
Update the branch weight metadata in JumpThreading pass.
In JumpThreading pass, the branch weight metadata is not updated after CFG modification. Consider the jump threading on PredBB, BB, and SuccBB. After jump threading, the weight on BB->SuccBB should be adjusted as some of it is contributed by the edge PredBB->BB, which doesn't exist anymore. This patch tries to update the edge weight in metadata on BB->SuccBB by scaling it by 1 - Freq(PredBB->BB) / Freq(BB->SuccBB).
Differential revision: http://reviews.llvm.org/D10979
llvm-svn: 250089
Diffstat (limited to 'llvm/test/Transforms/JumpThreading')
-rw-r--r-- | llvm/test/Transforms/JumpThreading/update-edge-weight.ll | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/llvm/test/Transforms/JumpThreading/update-edge-weight.ll b/llvm/test/Transforms/JumpThreading/update-edge-weight.ll new file mode 100644 index 00000000000..b5c5d01a3c6 --- /dev/null +++ b/llvm/test/Transforms/JumpThreading/update-edge-weight.ll @@ -0,0 +1,43 @@ +; RUN: opt -S -jump-threading %s | FileCheck %s + +; Test if edge weights are properly updated after jump threading. + +; CHECK: !2 = !{!"branch_weights", i32 22, i32 7} + +define void @foo(i32 %n) !prof !0 { +entry: + %cmp = icmp sgt i32 %n, 10 + br i1 %cmp, label %if.then.1, label %if.else.1, !prof !1 + +if.then.1: + tail call void @a() + br label %if.cond + +if.else.1: + tail call void @b() + br label %if.cond + +if.cond: + %cmp1 = icmp sgt i32 %n, 5 + br i1 %cmp1, label %if.then.2, label %if.else.2, !prof !2 + +if.then.2: + tail call void @c() + br label %if.end + +if.else.2: + tail call void @d() + br label %if.end + +if.end: + ret void +} + +declare void @a() +declare void @b() +declare void @c() +declare void @d() + +!0 = !{!"function_entry_count", i64 1} +!1 = !{!"branch_weights", i32 10, i32 5} +!2 = !{!"branch_weights", i32 10, i32 1} |