[X86] combineTargetShuffle - commute VPERMV3 shuffles so any load is on the RHS
[llvm-project.git] / llvm / test / CodeGen / SystemZ / vec-move-19.ll
blobec0386879a155449791f9a3b519819e9af49068a
1 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z13 | FileCheck %s
3 ; Test that a loaded value which is replicated is not inserted also in any
4 ; elements.
6 ; CHECK:      vlvgp   %v0, %r0, %r0
7 ; CHECK-NEXT: vrepf   %v24, %v0, 1
8 ; CHECK-NOT:  vlvgf   %v24, %r0, 1
9 ; CHECK-NOT:  vlvgf   %v24, %r0, 2
11 define <4 x i32> @fun(i32 %arg, ptr %dst) {
12   %tmp = load i32, ptr undef
13   %tmp8 = insertelement <4 x i32> undef, i32 %tmp, i32 0
14   %tmp9 = insertelement <4 x i32> %tmp8, i32 %tmp, i32 1
15   %tmp10 = insertelement <4 x i32> %tmp9, i32 %tmp, i32 2
16   %tmp11 = insertelement <4 x i32> %tmp10, i32 %arg, i32 3
17   store i32 %tmp, ptr %dst
18   ret <4 x i32> %tmp11