mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-11 15:08:16 +00:00
5d6365c80c
This is mostly achieved by providing the correct register class manually, because getRegClassFor always returns the GPR*AllRegClass for MVT::i32 and MVT::i64. Also cleanup the code to use the FastEmitInst_* method whenever possible. This makes sure that the operands' register class is properly constrained. For all the remaining cases this adds the missing constrainOperandRegClass calls for each operand. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@216225 91177308-0d34-0410-b5e6-96231b3b80d8
20 lines
656 B
LLVM
20 lines
656 B
LLVM
; RUN: llc -mtriple=arm64-apple-darwin -aarch64-atomic-cfg-tidy=0 -verify-machineinstrs < %s | FileCheck %s
|
|
; RUN: llc -mtriple=arm64-apple-darwin -aarch64-atomic-cfg-tidy=0 -fast-isel -fast-isel-abort -verify-machineinstrs < %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}
|