Skip to content

Commit cb69e12

Browse files
RKSimonSchrodingerZhu
authored andcommitted
[X86] Add regression test for insert_subvector(x,extract_subvector(broadcast)) pattern identified in llvm#133083
Infinite loop check
1 parent 3447209 commit cb69e12

File tree

1 file changed

+29
-0
lines changed

1 file changed

+29
-0
lines changed
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2+
; RUN: llc < %s -mtriple=x86_64-- -mcpu=skx | FileCheck %s
3+
4+
define void @insert_subvector_broadcast_as_blend() {
5+
; CHECK-LABEL: insert_subvector_broadcast_as_blend:
6+
; CHECK: # %bb.0:
7+
; CHECK-NEXT: movq (%rax), %rax
8+
; CHECK-NEXT: incq %rax
9+
; CHECK-NEXT: vpbroadcastq %rax, %zmm0
10+
; CHECK-NEXT: vpslldq {{.*#+}} xmm1 = zero,zero,zero,zero,zero,zero,zero,zero,xmm0[0,1,2,3,4,5,6,7]
11+
; CHECK-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm1
12+
; CHECK-NEXT: vinsertf64x4 $1, %ymm0, %zmm1, %zmm1
13+
; CHECK-NEXT: vpcmpltq {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %zmm1, %k0
14+
; CHECK-NEXT: vpcmpltq {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %zmm0, %k1
15+
; CHECK-NEXT: kunpckbw %k0, %k1, %k1
16+
; CHECK-NEXT: vmovdqu8 {{.*#+}} xmm0 {%k1} {z} = [1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1]
17+
; CHECK-NEXT: vmovdqa %xmm0, (%rax)
18+
; CHECK-NEXT: vzeroupper
19+
; CHECK-NEXT: retq
20+
%load4 = load i64, ptr poison, align 32
21+
%add = add i64 %load4, 1
22+
%insertelement5 = insertelement <16 x i64> zeroinitializer, i64 %add, i64 1
23+
%shufflevector = shufflevector <16 x i64> %insertelement5, <16 x i64> poison, <16 x i32> <i32 0, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>
24+
%icmp6 = icmp slt <16 x i64> %shufflevector, <i64 9223372036854775806, i64 2, i64 3, i64 4, i64 5, i64 6, i64 7, i64 8, i64 9, i64 10, i64 11, i64 12, i64 13, i64 14, i64 15, i64 16>
25+
%shufflevector7 = shufflevector <16 x i1> poison, <16 x i1> %icmp6, <16 x i32> <i32 0, i32 17, i32 18, i32 19, i32 20, i32 21, i32 22, i32 23, i32 24, i32 25, i32 26, i32 27, i32 28, i32 29, i32 30, i32 31>
26+
%zext = zext <16 x i1> %shufflevector7 to <16 x i8>
27+
store <16 x i8> %zext, ptr poison, align 32
28+
ret void
29+
}

0 commit comments

Comments
 (0)