xref: /llvm-project/llvm/test/Transforms/SLPVectorizer/ext-after-phi-node.ll (revision 5e67c41a932256e047ae093ae4f7f5a53df1527d)
1*5e67c41aSAlexey Bataev; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 4
2*5e67c41aSAlexey Bataev;RUN: opt -S -S --passes=slp-vectorizer -slp-threshold=-99999 < %s | FileCheck %s
3*5e67c41aSAlexey Bataev
4*5e67c41aSAlexey Bataevdefine double @test() {
5*5e67c41aSAlexey Bataev; CHECK-LABEL: define double @test() {
6*5e67c41aSAlexey Bataev; CHECK-NEXT:  bb:
7*5e67c41aSAlexey Bataev; CHECK-NEXT:    br label [[BB7:%.*]]
8*5e67c41aSAlexey Bataev; CHECK:       bb7:
9*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP0:%.*]] = phi <2 x i32> [ poison, [[BB9:%.*]] ], [ zeroinitializer, [[BB:%.*]] ]
10*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP1:%.*]] = phi <2 x i32> [ zeroinitializer, [[BB9]] ], [ zeroinitializer, [[BB]] ]
11*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP2:%.*]] = zext <2 x i32> [[TMP0]] to <2 x i64>
12*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP3:%.*]] = extractelement <2 x i32> [[TMP0]], i32 0
13*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP4:%.*]] = zext i32 [[TMP3]] to i64
14*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP5:%.*]] = extractelement <2 x i32> [[TMP0]], i32 1
15*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP6:%.*]] = zext i32 [[TMP5]] to i64
16*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[ICMP:%.*]] = icmp ult i64 [[TMP6]], [[TMP4]]
17*5e67c41aSAlexey Bataev; CHECK-NEXT:    [[TMP7:%.*]] = shufflevector <2 x i64> zeroinitializer, <2 x i64> [[TMP2]], <2 x i32> <i32 3, i32 1>
18*5e67c41aSAlexey Bataev; CHECK-NEXT:    ret double 0.000000e+00
19*5e67c41aSAlexey Bataev; CHECK:       bb9:
20*5e67c41aSAlexey Bataev; CHECK-NEXT:    br label [[BB7]]
21*5e67c41aSAlexey Bataev;
22*5e67c41aSAlexey Bataevbb:
23*5e67c41aSAlexey Bataev  br label %bb7
24*5e67c41aSAlexey Bataev
25*5e67c41aSAlexey Bataevbb7:
26*5e67c41aSAlexey Bataev  %0 = phi <2 x i32> [ poison, %bb9 ], [ zeroinitializer, %bb ]
27*5e67c41aSAlexey Bataev  %1 = phi <2 x i32> [ zeroinitializer, %bb9 ], [ zeroinitializer, %bb ]
28*5e67c41aSAlexey Bataev  %2 = extractelement <2 x i32> %0, i32 1
29*5e67c41aSAlexey Bataev  %3 = extractelement <2 x i32> %0, i32 0
30*5e67c41aSAlexey Bataev  %zext8 = zext i32 %3 to i64
31*5e67c41aSAlexey Bataev  %zext = zext i32 %2 to i64
32*5e67c41aSAlexey Bataev  %icmp = icmp ult i64 %zext, %zext8
33*5e67c41aSAlexey Bataev  %4 = insertelement <2 x i64> zeroinitializer, i64 %zext, i32 0
34*5e67c41aSAlexey Bataev  ret double 0.000000e+00
35*5e67c41aSAlexey Bataev
36*5e67c41aSAlexey Bataevbb9:
37*5e67c41aSAlexey Bataev  br label %bb7
38*5e67c41aSAlexey Bataev}
39