Ensure that each these functions generates a sh[rl]d instruction.

llvm-svn: 19682
This commit is contained in:
Chris Lattner 2005-01-19 06:30:36 +00:00
parent 41fe201b61
commit 892336a1b5
1 changed files with 22 additions and 0 deletions

View File

@ -0,0 +1,22 @@
; RUN: llvm-as < %s | llc -march=x86 -x86-asm-syntax=intel -disable-pattern-isel=0 | grep sh[lr]d | wc -l | grep 4
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
}