[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / pr40811.ll
blobfca947ad4c703e39f979c7545d247bc4cb757a35
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -o - -mcpu=btver2 -mtriple=x86_64-unknown-linux-gnu | FileCheck %s
4 define <8 x i32> @_Z6test70v(<4 x i32>* %id14793) {
5 ; CHECK-LABEL: _Z6test70v:
6 ; CHECK:       # %bb.0: # %entry
7 ; CHECK-NEXT:    vmovaps (%rdi), %xmm0
8 ; CHECK-NEXT:    vblendps {{.*#+}} xmm1 = xmm0[0],mem[1],xmm0[2,3]
9 ; CHECK-NEXT:    vpermilps {{.*#+}} xmm0 = xmm0[1,3,1,0]
10 ; CHECK-NEXT:    vpermilps {{.*#+}} xmm1 = xmm1[0,2,1,0]
11 ; CHECK-NEXT:    vinsertf128 $1, %xmm0, %ymm1, %ymm0
12 ; CHECK-NEXT:    retq
13 entry:
14   %id14793.0.id14793.0. = load <4 x i32>, <4 x i32>* %id14793, align 16
15   %shuffle = shufflevector <4 x i32> %id14793.0.id14793.0., <4 x i32> <i32 undef, i32 -1052558824, i32 undef, i32 undef>, <8 x i32> <i32 0, i32 2, i32 5, i32 0, i32 1, i32 3, i32 1, i32 0>
16   ret <8 x i32> %shuffle