summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/SimplifyCFG
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2016-03-17 15:30:52 +0000
committerSanjay Patel <spatel@rotateright.com>2016-03-17 15:30:52 +0000
commit9e23fedaf0f84d4a020514df4beefe65fe6da50b (patch)
tree420dd16d18265ca8093bee18ef4d625e3d3d4f3e /llvm/test/Transforms/SimplifyCFG
parent071a099102a4183309dbc80d52fc2454a9222f1e (diff)
downloadbcm5719-llvm-9e23fedaf0f84d4a020514df4beefe65fe6da50b.tar.gz
bcm5719-llvm-9e23fedaf0f84d4a020514df4beefe65fe6da50b.zip
propagate 'unpredictable' metadata on select instructions
This is similar to D18133 where we allowed profile weights on select instructions. This extends that change to also allow the 'unpredictable' attribute of branches to apply to selects. A test to check that 'unpredictable' metadata is preserved when cloning instructions was checked in at: http://reviews.llvm.org/rL263648 Differential Revision: http://reviews.llvm.org/D18220 llvm-svn: 263716
Diffstat (limited to 'llvm/test/Transforms/SimplifyCFG')
-rw-r--r--llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll6
1 files changed, 4 insertions, 2 deletions
diff --git a/llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll b/llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll
index 60931fc71aa..0ca65286da3 100644
--- a/llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll
+++ b/llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll
@@ -5,7 +5,7 @@
define i32 @FoldTwoEntryPHINode(i1 %C, i32 %V1, i32 %V2, i16 %V3) {
entry:
- br i1 %C, label %then, label %else, !prof !0
+ br i1 %C, label %then, label %else, !prof !0, !unpredictable !1
then:
%V4 = or i32 %V2, %V1
br label %Cont
@@ -21,12 +21,14 @@ Cont:
; CHECK-NEXT: entry:
; CHECK-NEXT: %V5 = sext i16 %V3 to i32
; CHECK-NEXT: %V4 = or i32 %V2, %V1
-; CHECK-NEXT: %V6 = select i1 %C, i32 %V4, i32 %V5, !prof !0
+; CHECK-NEXT: %V6 = select i1 %C, i32 %V4, i32 %V5, !prof !0, !unpredictable !1
; CHECK-NEXT: %0 = call i32 @FoldTwoEntryPHINode(i1 false, i32 0, i32 0, i16 0)
; CHECK-NEXT: ret i32 %V1
}
!0 = !{!"branch_weights", i32 3, i32 5}
+!1 = !{}
; CHECK: !0 = !{!"branch_weights", i32 3, i32 5}
+; CHECK: !1 = !{}
OpenPOWER on IntegriCloud