llvm.org GIT mirror llvm / release_90 test / CodeGen / X86 / pr34657.ll
release_90

Tree @release_90 (Download .tar.gz)

pr34657.ll @release_90raw · history · blame

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+avx512f,+avx512bw | FileCheck %s

define <112 x i8> @pr34657(<112 x i8>* %src) local_unnamed_addr {
; CHECK-LABEL: pr34657:
; CHECK:       # %bb.0: # %entry
; CHECK-NEXT:    movq %rdi, %rax
; CHECK-NEXT:    vmovups 64(%rsi), %ymm0
; CHECK-NEXT:    vbroadcastf128 {{.*#+}} ymm1 = mem[0,1,0,1]
; CHECK-NEXT:    vinsertf64x4 $1, %ymm1, %zmm0, %zmm1
; CHECK-NEXT:    vmovups (%rsi), %zmm2
; CHECK-NEXT:    vmovaps %ymm0, 64(%rdi)
; CHECK-NEXT:    vmovaps %zmm2, (%rdi)
; CHECK-NEXT:    vextractf32x4 $2, %zmm1, 96(%rdi)
; CHECK-NEXT:    vzeroupper
; CHECK-NEXT:    retq
entry:
  %wide.vec51 = load <112 x i8>, <112 x i8>* %src, align 2
  ret <112 x i8> %wide.vec51
}