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