forked from OSchip/llvm-project
32 lines
688 B
Plaintext
32 lines
688 B
Plaintext
; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -x86-asm-syntax=intel | \
|
|
; RUN: grep {sh\[lr\]d} | wc -l | grep 5
|
|
|
|
long %test1(long %X, ubyte %C) {
|
|
%Y = shl long %X, ubyte %C
|
|
ret long %Y
|
|
}
|
|
long %test2(long %X, ubyte %C) {
|
|
%Y = shr long %X, ubyte %C
|
|
ret long %Y
|
|
}
|
|
ulong %test3(ulong %X, ubyte %C) {
|
|
%Y = shr ulong %X, ubyte %C
|
|
ret ulong %Y
|
|
}
|
|
|
|
uint %test4(uint %A, uint %B, ubyte %C) {
|
|
%X = shl uint %A, ubyte %C
|
|
%Cv = sub ubyte 32, %C
|
|
%Y = shr uint %B, ubyte %Cv
|
|
%Z = or uint %Y, %X
|
|
ret uint %Z
|
|
}
|
|
|
|
ushort %test5(ushort %A, ushort %B, ubyte %C) {
|
|
%X = shl ushort %A, ubyte %C
|
|
%Cv = sub ubyte 16, %C
|
|
%Y = shr ushort %B, ubyte %Cv
|
|
%Z = or ushort %Y, %X
|
|
ret ushort %Z
|
|
}
|