llvm/test/Transforms/SimplifyCFG/PhiEliminate2.ll
Sanjay Patel 1956ff6e28 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



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@263716 91177308-0d34-0410-b5e6-96231b3b80d8
2016-03-17 15:30:52 +00:00

35 lines
1.0 KiB
LLVM

; RUN: opt < %s -simplifycfg -S | FileCheck %s
; Use a select to make this a single BB.
; Also, make sure the profile metadata is propagated to the select (PR26636).
define i32 @FoldTwoEntryPHINode(i1 %C, i32 %V1, i32 %V2, i16 %V3) {
entry:
br i1 %C, label %then, label %else, !prof !0, !unpredictable !1
then:
%V4 = or i32 %V2, %V1
br label %Cont
else:
%V5 = sext i16 %V3 to i32
br label %Cont
Cont:
%V6 = phi i32 [ %V5, %else ], [ %V4, %then ]
call i32 @FoldTwoEntryPHINode( i1 false, i32 0, i32 0, i16 0 )
ret i32 %V1
; CHECK-LABEL: @FoldTwoEntryPHINode(
; 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, !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 = !{}