1 ; RUN: llc < %s -O2 -mattr=avx512f -mtriple=x86_64-unknown | FileCheck %s 2 3 %struct.S1 = type { %struct.S1*, %struct.S1* } 4 5 define %struct.S1** @malloc_init_state(<64 x %struct.S1**> %tmp, i32 %ind) { 6 entry: 7 %Vec = getelementptr inbounds %struct.S1*, <64 x %struct.S1**> %tmp , i64 2 8 %ptr = extractelement <64 x %struct.S1**> %Vec, i32 %ind 9 ret %struct.S1** %ptr 10 } 11 12 ; CHECK: .LCPI0_0: 13 ; CHECK: .quad 16 14 ; CHECK: vpbroadcastq .LCPI0_0(%rip), [[Z1:%zmm[0-9]]] 15 ; CHECK-NEXT: vpaddq [[Z1]], [[Z2:%zmm[0-9]]], [[Z2]] 16 ; CHECK-NEXT: vpaddq [[Z1]], [[Z3:%zmm[0-9]]], [[Z3]] 17 ; CHECK-NEXT: vpaddq [[Z1]], [[Z4:%zmm[0-9]]], [[Z4]] 18 ; CHECK-NEXT: vpaddq [[Z1]], [[Z5:%zmm[0-9]]], [[Z5]] 19 ; CHECK-NEXT: vpaddq [[Z1]], [[Z6:%zmm[0-9]]], [[Z6]] 20 ; CHECK-NEXT: vpaddq [[Z1]], [[Z7:%zmm[0-9]]], [[Z7]] 21 ; CHECK-NEXT: vpaddq [[Z1]], [[Z8:%zmm[0-9]]], [[Z8]] 22 ; CHECK-NEXT: vpaddq [[Z1]], [[Z9:%zmm[0-9]]], [[Z9]] 23 24 25