llvm-project/llvm/test/CodeGen/X86/gep-expanded-vector.ll

25 lines
839 B
LLVM

; RUN: llc < %s -O2 -mattr=avx512f -mtriple=x86_64-unknown | FileCheck %s
%struct.S1 = type { ptr, ptr }
define ptr @malloc_init_state(<64 x ptr> %tmp, i32 %ind) {
entry:
%Vec = getelementptr inbounds ptr, <64 x ptr> %tmp , i64 2
%ptr = extractelement <64 x ptr> %Vec, i32 %ind
ret ptr %ptr
}
; CHECK: .LCPI0_0:
; CHECK: .quad 16
; CHECK: vpbroadcastq .LCPI0_0(%rip), [[Z1:%zmm[0-9]]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z2:%zmm[0-9]]], [[Z2]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z3:%zmm[0-9]]], [[Z3]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z4:%zmm[0-9]]], [[Z4]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z5:%zmm[0-9]]], [[Z5]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z6:%zmm[0-9]]], [[Z6]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z7:%zmm[0-9]]], [[Z7]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z8:%zmm[0-9]]], [[Z8]]
; CHECK-NEXT: vpaddq [[Z1]], [[Z9:%zmm[0-9]]], [[Z9]]