mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2026-04-24 13:18:17 +00:00
bswap implementation
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25312 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -0,0 +1,23 @@
|
||||
; bswap should be constant folded when it is passed a constant argument
|
||||
|
||||
; RUN: llvm-as < %s | llc -march=x86 -enable-x86-dag-isel | grep bswapl | wc -l | grep 3 &&
|
||||
; RUN: llvm-as < %s | llc -march=x86 -enable-x86-dag-isel | grep rolw | wc -l | grep 1
|
||||
|
||||
declare ushort %llvm.bswap.i16(ushort)
|
||||
declare uint %llvm.bswap.i32(uint)
|
||||
declare ulong %llvm.bswap.i64(ulong)
|
||||
|
||||
ushort %W(ushort %A) {
|
||||
%Z = call ushort %llvm.bswap.i16(ushort %A)
|
||||
ret ushort %Z
|
||||
}
|
||||
|
||||
uint %X(uint %A) {
|
||||
%Z = call uint %llvm.bswap.i32(uint %A)
|
||||
ret uint %Z
|
||||
}
|
||||
|
||||
ulong %Y(ulong %A) {
|
||||
%Z = call ulong %llvm.bswap.i64(ulong %A)
|
||||
ret ulong %Z
|
||||
}
|
||||
Reference in New Issue
Block a user