[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / sse-only.ll
blob6f766b1a4e43160e70f33c901c977f20101d8d23
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-- -mattr=+sse2,-mmx | FileCheck %s
4 ; Test that turning off mmx doesn't turn off sse
6 define void @test1(<2 x double>* %r, <2 x double>* %A, double %B) nounwind  {
7 ; CHECK-LABEL: test1:
8 ; CHECK:       # %bb.0:
9 ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %eax
10 ; CHECK-NEXT:    movl {{[0-9]+}}(%esp), %ecx
11 ; CHECK-NEXT:    movaps (%ecx), %xmm0
12 ; CHECK-NEXT:    movlps {{.*#+}} xmm0 = mem[0,1],xmm0[2,3]
13 ; CHECK-NEXT:    movaps %xmm0, (%eax)
14 ; CHECK-NEXT:    retl
15         %tmp3 = load <2 x double>, <2 x double>* %A, align 16
16         %tmp7 = insertelement <2 x double> undef, double %B, i32 0
17         %tmp9 = shufflevector <2 x double> %tmp3, <2 x double> %tmp7, <2 x i32> < i32 2, i32 1 >
18         store <2 x double> %tmp9, <2 x double>* %r, align 16
19         ret void