forked from OSchip/llvm-project
[X86][SSE] Update extractelement test in preparation for D52140
SimplifyDemandedVectorEltsForTargetNode will remove most of this test unless get rid of the undefs - still testing for align 1 which was the point of the test Removed out of date comment as well llvm-svn: 342531
This commit is contained in:
parent
467c5f9ce0
commit
e2b16389e7
|
@ -51,30 +51,30 @@ define i32 @t2(<8 x i32>* %xp) {
|
||||||
; low alignment load of the vector which prevents us from reliably forming a
|
; low alignment load of the vector which prevents us from reliably forming a
|
||||||
; narrow load.
|
; narrow load.
|
||||||
|
|
||||||
; The expected codegen is identical for the AVX case except
|
define void @t3(<2 x double>* %a0) {
|
||||||
; load/store instructions will have a leading 'v', so we don't
|
|
||||||
; need to special-case the checks.
|
|
||||||
|
|
||||||
define void @t3() {
|
|
||||||
; X32-SSE2-LABEL: t3:
|
; X32-SSE2-LABEL: t3:
|
||||||
; X32-SSE2: # %bb.0: # %bb
|
; X32-SSE2: # %bb.0: # %bb
|
||||||
|
; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %eax
|
||||||
; X32-SSE2-NEXT: movupd (%eax), %xmm0
|
; X32-SSE2-NEXT: movupd (%eax), %xmm0
|
||||||
; X32-SSE2-NEXT: movhpd %xmm0, (%eax)
|
; X32-SSE2-NEXT: movhpd %xmm0, (%eax)
|
||||||
|
; X32-SSE2-NEXT: retl
|
||||||
;
|
;
|
||||||
; X64-SSSE3-LABEL: t3:
|
; X64-SSSE3-LABEL: t3:
|
||||||
; X64-SSSE3: # %bb.0: # %bb
|
; X64-SSSE3: # %bb.0: # %bb
|
||||||
; X64-SSSE3-NEXT: movddup {{.*#+}} xmm0 = mem[0,0]
|
; X64-SSSE3-NEXT: movddup {{.*#+}} xmm0 = mem[0,0]
|
||||||
; X64-SSSE3-NEXT: movlpd %xmm0, (%rax)
|
; X64-SSSE3-NEXT: movlpd %xmm0, (%rax)
|
||||||
|
; X64-SSSE3-NEXT: retq
|
||||||
;
|
;
|
||||||
; X64-AVX-LABEL: t3:
|
; X64-AVX-LABEL: t3:
|
||||||
; X64-AVX: # %bb.0: # %bb
|
; X64-AVX: # %bb.0: # %bb
|
||||||
; X64-AVX-NEXT: vmovddup {{.*#+}} xmm0 = mem[0,0]
|
; X64-AVX-NEXT: vmovddup {{.*#+}} xmm0 = mem[0,0]
|
||||||
; X64-AVX-NEXT: vmovlpd %xmm0, (%rax)
|
; X64-AVX-NEXT: vmovlpd %xmm0, (%rax)
|
||||||
|
; X64-AVX-NEXT: retq
|
||||||
bb:
|
bb:
|
||||||
%tmp13 = load <2 x double>, <2 x double>* undef, align 1
|
%tmp13 = load <2 x double>, <2 x double>* %a0, align 1
|
||||||
%.sroa.3.24.vec.extract = extractelement <2 x double> %tmp13, i32 1
|
%.sroa.3.24.vec.extract = extractelement <2 x double> %tmp13, i32 1
|
||||||
store double %.sroa.3.24.vec.extract, double* undef, align 8
|
store double %.sroa.3.24.vec.extract, double* undef, align 8
|
||||||
unreachable
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
; Case where a load is unary shuffled, then bitcast (to a type with the same
|
; Case where a load is unary shuffled, then bitcast (to a type with the same
|
||||||
|
|
Loading…
Reference in New Issue