mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
6433a60405
Summary: Update Flag when generating cc output. Fixes PR40737. Reviewers: rnk, nickdesaulniers, craig.topper, spatel Subscribers: hiraditya, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D58283 llvm-svn: 354163
20 lines
722 B
LLVM
20 lines
722 B
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc -mtriple=x86_64-unknown-linux-gnu %s -o - | FileCheck %s
|
|
|
|
define i8 @_BitScanForward(i32* nocapture %Index, i32 %Mask) {
|
|
; CHECK-LABEL: _BitScanForward:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: #APP
|
|
; CHECK-NEXT: bsfl %esi, %ecx
|
|
; CHECK-NEXT: #NO_APP
|
|
; CHECK-NEXT: setne %al
|
|
; CHECK-NEXT: movl %ecx, (%rdi)
|
|
; CHECK-NEXT: retq
|
|
entry:
|
|
%0 = tail call { i8, i32 } asm "bsf$(l $2,$1 $| $1,$2$)", "={@ccnz},=r,r,~{dirflag},~{fpsr},~{flags}"(i32 %Mask)
|
|
%asmresult = extractvalue { i8, i32 } %0, 0
|
|
%asmresult1 = extractvalue { i8, i32 } %0, 1
|
|
store i32 %asmresult1, i32* %Index, align 4
|
|
ret i8 %asmresult
|
|
}
|