forked from OSchip/llvm-project
25 lines
908 B
LLVM
25 lines
908 B
LLVM
|
; RUN: llc < %s -O2 -mattr=avx512f -mtriple=x86_64-unknown | FileCheck %s
|
||
|
|
||
|
%struct.S1 = type { %struct.S1*, %struct.S1* }
|
||
|
|
||
|
define %struct.S1** @malloc_init_state(<64 x %struct.S1**> %tmp, i32 %ind) {
|
||
|
entry:
|
||
|
%Vec = getelementptr inbounds %struct.S1*, <64 x %struct.S1**> %tmp , i64 2
|
||
|
%ptr = extractelement <64 x %struct.S1**> %Vec, i32 %ind
|
||
|
ret %struct.S1** %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]]
|
||
|
|
||
|
|