1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
; RUN: opt -S --passes=slp-vectorizer -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s
define void @test({ <2 x float>, float } %0, <2 x float> %1, i1 %2) {
; CHECK-LABEL: define void @test(
; CHECK-SAME: { <2 x float>, float } [[TMP0:%.*]], <2 x float> [[TMP1:%.*]], i1 [[TMP2:%.*]]) {
; CHECK-NEXT: [[TMP4:%.*]] = extractvalue { <2 x float>, float } [[TMP0]], 0
; CHECK-NEXT: [[TMP5:%.*]] = extractelement <2 x float> [[TMP4]], i64 0
; CHECK-NEXT: [[TMP6:%.*]] = extractelement <2 x float> [[TMP1]], i64 1
; CHECK-NEXT: [[TMP7:%.*]] = extractelement <2 x float> [[TMP1]], i64 0
; CHECK-NEXT: br i1 [[TMP2]], label %[[BB9:.*]], label %[[BB8:.*]]
; CHECK: [[BB8]]:
; CHECK-NEXT: br label %[[BB9]]
; CHECK: [[BB9]]:
; CHECK-NEXT: [[TMP10:%.*]] = phi float [ 0.000000e+00, %[[BB8]] ], [ [[TMP7]], [[TMP3:%.*]] ]
; CHECK-NEXT: [[TMP11:%.*]] = phi float [ 0.000000e+00, %[[BB8]] ], [ [[TMP6]], [[TMP3]] ]
; CHECK-NEXT: [[TMP12:%.*]] = phi float [ 0.000000e+00, %[[BB8]] ], [ [[TMP5]], [[TMP3]] ]
; CHECK-NEXT: [[TMP13:%.*]] = fpext float [[TMP12]] to double
; CHECK-NEXT: [[TMP14:%.*]] = fpext float [[TMP11]] to double
; CHECK-NEXT: [[TMP15:%.*]] = tail call i32 (ptr, ptr, ...) @fprintf(ptr null, ptr null, double [[TMP13]], double [[TMP14]], double 0.000000e+00)
; CHECK-NEXT: [[TMP16:%.*]] = fpext float [[TMP10]] to double
; CHECK-NEXT: [[TMP17:%.*]] = tail call i32 (ptr, ptr, ...) @fprintf(ptr null, ptr null, double 0.000000e+00, double [[TMP16]], double 0.000000e+00)
; CHECK-NEXT: ret void
;
%4 = extractvalue { <2 x float>, float } %0, 0
%5 = extractelement <2 x float> %4, i64 0
%6 = extractelement <2 x float> %1, i64 1
%7 = extractelement <2 x float> %1, i64 0
br i1 %2, label %9, label %8
8:
br label %9
9:
%10 = phi float [ 0.000000e+00, %8 ], [ %7, %3 ]
%11 = phi float [ 0.000000e+00, %8 ], [ %6, %3 ]
%12 = phi float [ 0.000000e+00, %8 ], [ %5, %3 ]
%13 = fpext float %12 to double
%14 = fpext float %11 to double
%15 = tail call i32 (ptr, ptr, ...) @fprintf(ptr null, ptr null, double %13, double %14, double 0.000000e+00)
%16 = fpext float %10 to double
%17 = tail call i32 (ptr, ptr, ...) @fprintf(ptr null, ptr null, double 0.000000e+00, double %16, double 0.000000e+00)
ret void
}
declare i32 @fprintf(ptr, ptr, ...)
|