From: Evan Cheng Date: Tue, 7 Nov 2006 22:18:14 +0000 (+0000) Subject: New test case. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=4d23a2fa10a38962133adb30c978042e07a594b5;p=oota-llvm.git New test case. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31520 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/CodeGen/X86/unpcklps.ll b/test/CodeGen/X86/unpcklps.ll deleted file mode 100644 index b7f7d1454cd..00000000000 --- a/test/CodeGen/X86/unpcklps.ll +++ /dev/null @@ -1,18 +0,0 @@ -; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | grep unpcklps && -; RUN: llvm-as < %s | llc -march=x86 -mcpu=yonah | not grep 'sub.*esp' - -void %test(<4 x float>* %res, <4 x float>* %A, <4 x float>* %B) { - %tmp = load <4 x float>* %B ; <<4 x float>> [#uses=2] - %tmp3 = load <4 x float>* %A ; <<4 x float>> [#uses=2] - %tmp = extractelement <4 x float> %tmp3, uint 0 ; [#uses=1] - %tmp7 = extractelement <4 x float> %tmp, uint 0 ; [#uses=1] - %tmp8 = extractelement <4 x float> %tmp3, uint 1 ; [#uses=1] - %tmp9 = extractelement <4 x float> %tmp, uint 1 ; [#uses=1] - %tmp10 = insertelement <4 x float> undef, float %tmp, uint 0 ; <<4 x float>> [#uses=1] - %tmp11 = insertelement <4 x float> %tmp10, float %tmp7, uint 1 ; <<4 x float>> [#uses=1] - %tmp12 = insertelement <4 x float> %tmp11, float %tmp8, uint 2 ; <<4 x float>> [#uses=1] - %tmp13 = insertelement <4 x float> %tmp12, float %tmp9, uint 3 ; <<4 x float>> [#uses=1] - store <4 x float> %tmp13, <4 x float>* %res - ret void -} - diff --git a/test/CodeGen/X86/vec_shuffle-10.ll b/test/CodeGen/X86/vec_shuffle-10.ll new file mode 100644 index 00000000000..b3fc841a114 --- /dev/null +++ b/test/CodeGen/X86/vec_shuffle-10.ll @@ -0,0 +1,25 @@ +; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 && +; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | grep unpcklps | wc -l | grep 1 && +; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | grep unpckhps | wc -l | grep 1 && +; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | not grep 'sub.*esp' + +void %test(<4 x float>* %res, <4 x float>* %A, <4 x float>* %B) { + %tmp = load <4 x float>* %B ; <<4 x float>> [#uses=2] + %tmp3 = load <4 x float>* %A ; <<4 x float>> [#uses=2] + %tmp = extractelement <4 x float> %tmp3, uint 0 ; [#uses=1] + %tmp7 = extractelement <4 x float> %tmp, uint 0 ; [#uses=1] + %tmp8 = extractelement <4 x float> %tmp3, uint 1 ; [#uses=1] + %tmp9 = extractelement <4 x float> %tmp, uint 1 ; [#uses=1] + %tmp10 = insertelement <4 x float> undef, float %tmp, uint 0 ; <<4 x float>> [#uses=1] + %tmp11 = insertelement <4 x float> %tmp10, float %tmp7, uint 1 ; <<4 x float>> [#uses=1] + %tmp12 = insertelement <4 x float> %tmp11, float %tmp8, uint 2 ; <<4 x float>> [#uses=1] + %tmp13 = insertelement <4 x float> %tmp12, float %tmp9, uint 3 ; <<4 x float>> [#uses=1] + store <4 x float> %tmp13, <4 x float>* %res + ret void +} + +void %test2(<4 x float> %X, <4 x float>* %res) { + %tmp5 = shufflevector <4 x float> %X, <4 x float> undef, <4 x uint> < uint 2, uint 6, uint 3, uint 7 > + store <4 x float> %tmp5, <4 x float>* %res + ret void +}