mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-25 21:46:50 +00:00
62660310d9
crc32.[8|16|32] have been renamed to .crc32.32.[8|16|32] and crc64.[8|16|32] have been renamed to .crc32.64.[8|64]. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132163 91177308-0d34-0410-b5e6-96231b3b80d8
18 lines
435 B
LLVM
18 lines
435 B
LLVM
; RUN: opt < %s -instcombine -S | FileCheck %s
|
|
|
|
; crc32 with 64-bit destination zeros high 32-bit.
|
|
; rdar://9467055
|
|
|
|
define i64 @test() nounwind {
|
|
entry:
|
|
; CHECK: test
|
|
; CHECK: tail call i64 @llvm.x86.sse42.crc32.64.64
|
|
; CHECK-NOT: and
|
|
; CHECK: ret
|
|
%0 = tail call i64 @llvm.x86.sse42.crc32.64.64(i64 0, i64 4) nounwind
|
|
%1 = and i64 %0, 4294967295
|
|
ret i64 %1
|
|
}
|
|
|
|
declare i64 @llvm.x86.sse42.crc32.64.64(i64, i64) nounwind readnone
|