aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/PowerPC/pr141642.ll
blob: 61bda4dfaf533ad93b99e8358be425467680fd95 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
; RUN: llc -mcpu=pwr8 -mtriple=powerpc64le-unknown-linux-gnu -O0 -debug-only=selectiondag -o - < %s 2>&1 | \
; RUN:  FileCheck %s
; CHECK-NOT: lxvdsx
; CHECK-NOT: LD_SPLAT
; REQUIRES: asserts

define weak_odr dso_local void @unpack(ptr noalias noundef %packed_in) local_unnamed_addr {
entry:
  %ld = load <2 x i32>, ptr %packed_in, align 2
  %shuf = shufflevector <2 x i32> %ld, <2 x i32> poison, <4 x i32> <i32 0, i32 1, i32 poison, i32 0>
  %ie = insertelement <4 x i32> %shuf, i32 7, i32 2
  store <4 x i32> %shuf, ptr %packed_in, align 2
  ret void
}