mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-09 21:50:50 +00:00
1956ff6e28
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
35 lines
1.0 KiB
LLVM
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 = !{}
|
|
|