mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:33:20 +01:00
5fad1ddebc
Add branch weights to branch instructions, so that the following passes can optimize based on it (i.e. basic block ordering). Fixes <rdar://problem/17887137>. llvm-svn: 214537
20 lines
612 B
LLVM
20 lines
612 B
LLVM
; RUN: llc -mtriple=arm64-apple-darwin -aarch64-atomic-cfg-tidy=0 < %s | FileCheck %s
|
|
; RUN: llc -mtriple=arm64-apple-darwin -aarch64-atomic-cfg-tidy=0 -fast-isel -fast-isel-abort < %s | FileCheck %s
|
|
|
|
; Test if the BBs are reordred according to their branch weights.
|
|
define i64 @branch_weights_test(i64 %a, i64 %b) {
|
|
; CHECK-LABEL: branch_weights_test
|
|
; CHECK-LABEL: success
|
|
; CHECK-LABEL: fail
|
|
%1 = icmp ult i64 %a, %b
|
|
br i1 %1, label %fail, label %success, !prof !0
|
|
|
|
fail:
|
|
ret i64 -1
|
|
|
|
success:
|
|
ret i64 0
|
|
}
|
|
|
|
!0 = metadata !{metadata !"branch_weights", i32 0, i32 2147483647}
|