xref: /llvm-project/llvm/test/Transforms/LoopVectorize/PowerPC/interleave_IC.ll (revision 1c211bc76e8b6a3261c62e5b6c2b75b7b90386b0)
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