2011-02-22 07:21:51 +00:00
|
|
|
; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s
|
|
|
|
; RUN: llc < %s -mtriple=x86_64-win32 | FileCheck %s
|
2010-09-09 18:48:34 +00:00
|
|
|
; RUN: llc -O0 < %s -march=x86 -mcpu=core2 | FileCheck %s --check-prefix=CHECK_O0
|
Using target specific nodes for shuffle nodes makes the mask
check more strict, breaking some cases not checked in the
testsuite, but also exposes some foldings not done before,
as this example:
movaps (%rdi), %xmm0
movaps (%rax), %xmm1
movaps %xmm0, %xmm2
movss %xmm1, %xmm2
shufps $36, %xmm2, %xmm0
now is generated as:
movaps (%rdi), %xmm0
movaps %xmm0, %xmm1
movlps (%rax), %xmm1
shufps $36, %xmm1, %xmm0
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112753 91177308-0d34-0410-b5e6-96231b3b80d8
2010-09-01 22:33:20 +00:00
|
|
|
|
|
|
|
define <4 x i32> @t00(<4 x i32>* %a0) nounwind ssp {
|
|
|
|
entry:
|
2011-02-22 07:21:51 +00:00
|
|
|
; CHECK: movaps ({{%rdi|%rcx}}), %xmm0
|
2011-08-10 17:45:17 +00:00
|
|
|
; CHECK: movaps %xmm0, %xmm1
|
|
|
|
; CHECK-NEXT: movss %xmm2, %xmm1
|
Using target specific nodes for shuffle nodes makes the mask
check more strict, breaking some cases not checked in the
testsuite, but also exposes some foldings not done before,
as this example:
movaps (%rdi), %xmm0
movaps (%rax), %xmm1
movaps %xmm0, %xmm2
movss %xmm1, %xmm2
shufps $36, %xmm2, %xmm0
now is generated as:
movaps (%rdi), %xmm0
movaps %xmm0, %xmm1
movlps (%rax), %xmm1
shufps $36, %xmm1, %xmm0
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112753 91177308-0d34-0410-b5e6-96231b3b80d8
2010-09-01 22:33:20 +00:00
|
|
|
; CHECK-NEXT: shufps $36, %xmm1, %xmm0
|
|
|
|
%0 = load <4 x i32>* undef, align 16
|
|
|
|
%1 = load <4 x i32>* %a0, align 16
|
|
|
|
%2 = shufflevector <4 x i32> %1, <4 x i32> %0, <4 x i32> <i32 0, i32 1, i32 2, i32 4>
|
|
|
|
ret <4 x i32> %2
|
|
|
|
}
|
|
|
|
|
2010-09-09 18:48:34 +00:00
|
|
|
define void @t01(double* %a0) nounwind ssp {
|
|
|
|
entry:
|
|
|
|
; CHECK_O0: movsd (%eax), %xmm0
|
|
|
|
; CHECK_O0: unpcklpd %xmm0, %xmm0
|
|
|
|
%tmp93 = load double* %a0, align 8
|
|
|
|
%vecinit94 = insertelement <2 x double> undef, double %tmp93, i32 1
|
|
|
|
store <2 x double> %vecinit94, <2 x double>* undef
|
|
|
|
ret void
|
|
|
|
}
|
2011-08-10 17:45:17 +00:00
|
|
|
|
|
|
|
define void @t02(<8 x i32>* %source, <2 x i32>* %dest) nounwind noinline {
|
|
|
|
entry:
|
2011-10-29 21:23:04 +00:00
|
|
|
; CHECK: t02
|
|
|
|
; CHECK: movaps
|
|
|
|
; CHECK: shufps
|
|
|
|
; CHECK: pshufd
|
|
|
|
; CHECK: movq
|
|
|
|
; CHECK: ret
|
2011-08-10 17:45:17 +00:00
|
|
|
%0 = bitcast <8 x i32>* %source to <4 x i32>*
|
|
|
|
%arrayidx = getelementptr inbounds <4 x i32>* %0, i64 3
|
|
|
|
%tmp2 = load <4 x i32>* %arrayidx, align 16
|
|
|
|
%tmp3 = extractelement <4 x i32> %tmp2, i32 0
|
|
|
|
%tmp5 = insertelement <2 x i32> <i32 undef, i32 0>, i32 %tmp3, i32 0
|
|
|
|
%arrayidx7 = getelementptr inbounds <8 x i32>* %source, i64 1
|
|
|
|
%1 = bitcast <8 x i32>* %arrayidx7 to <4 x i32>*
|
|
|
|
%tmp8 = load <4 x i32>* %1, align 16
|
|
|
|
%tmp9 = extractelement <4 x i32> %tmp8, i32 1
|
|
|
|
%tmp11 = insertelement <2 x i32> %tmp5, i32 %tmp9, i32 1
|
|
|
|
store <2 x i32> %tmp11, <2 x i32>* %dest, align 8
|
|
|
|
ret void
|
|
|
|
}
|