1; RUN: opt < %s -passes=loop-vectorize -S -mcpu=pwr9 2>&1 | FileCheck %s 2; RUN: opt < %s -passes='loop-vectorize' -S -mcpu=pwr9 2>&1 | FileCheck %s 3 4; CHECK-LABEL: vector.body 5; CHECK: load double, ptr 6; CHECK-NEXT: load double, ptr 7; CHECK-NEXT: load double, ptr 8; CHECK-NEXT: load double, ptr 9 10; CHECK: fmul fast double 11; CHECK-NEXT: fmul fast double 12; CHECK-NEXT: fmul fast double 13; CHECK-NEXT: fmul fast double 14 15; CHECK: fadd fast double 16; CHECK-NEXT: fadd fast double 17; CHECK-NEXT: fadd fast double 18; CHECK-NEXT: fadd fast double 19 20target datalayout = "e-m:e-i64:64-n32:64" 21target triple = "powerpc64le-unknown-linux-gnu" 22 23define dso_local void @test(ptr %arg, ptr %arg1) align 2 { 24bb: 25 %tpm15 = load ptr, ptr %arg, align 8 26 %tpm19 = load ptr, ptr %arg1, align 8 27 br label %bb22 28bb22: ; preds = %bb33, %bb 29 %tpm26 = add i64 0, 1 30 %tpm10 = alloca i32, align 8 31 %tpm27 = getelementptr inbounds i32, ptr %tpm10, i64 %tpm26 32 %tpm29 = load ptr, ptr %tpm15, align 8 33 %tpm17 = alloca double, align 8 34 %tpm32 = getelementptr inbounds double, ptr %tpm17, i64 %tpm26 35 br label %bb40 36bb33: ; preds = %bb40 37 %tpm37 = fsub fast double 0.000000e+00, %tpm50 38 store double %tpm37, ptr %tpm19, align 8 39 br label %bb22 40bb40: ; preds = %bb40, %bb22 41 %tpm41 = phi ptr [ %tpm51, %bb40 ], [ %tpm27, %bb22 ] 42 %tpm42 = phi ptr [ %tpm52, %bb40 ], [ %tpm32, %bb22 ] 43 %tpm43 = phi double [ %tpm50, %bb40 ], [ 0.000000e+00, %bb22 ] 44 %tpm44 = load double, ptr %tpm42, align 8 45 %tpm45 = load i32, ptr %tpm41, align 4 46 %tpm46 = zext i32 %tpm45 to i64 47 %tpm47 = getelementptr inbounds double, ptr %tpm19, i64 %tpm46 48 %tpm48 = load double, ptr %tpm47, align 8 49 %tpm49 = fmul fast double %tpm48, %tpm44 50 %tpm50 = fadd fast double %tpm49, %tpm43 51 %tpm51 = getelementptr inbounds i32, ptr %tpm41, i64 1 52 %tpm52 = getelementptr inbounds double, ptr %tpm42, i64 1 53 %tpm53 = icmp eq ptr %tpm51, %tpm29 54 br i1 %tpm53, label %bb33, label %bb40 55} 56