1; RUN: opt %loadPolly -polly-scops -polly-invariant-load-hoisting=true -analyze < %s | FileCheck %s
2; RUN: opt %loadPolly -polly-codegen -polly-invariant-load-hoisting=true -analyze < %s
3
4; CHECK:      Statements {
5; CHECK-NEXT: 	Stmt_L_4
6; CHECK-NEXT:         Domain :=
7; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] : 0 <= i0 < tmp8 and 0 <= i1 < tmp8 and 0 <= i2 < tmp8 };
8; CHECK-NEXT:         Schedule :=
9; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> [i0, i1, i2] };
10; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
11; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp19[i1, i0] };
12; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
13; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp5[i2, i0] };
14; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
15; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp12[i2, i1] };
16; CHECK-NEXT:         MustWriteAccess :=	[Reduction Type: NONE] [Scalar: 0]
17; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp19[i1, i0] };
18; CHECK-NEXT: }
19
20target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
21
22%jl_value_t = type { %jl_value_t* }
23
24define %jl_value_t* @julia_gemm_22583(%jl_value_t*, %jl_value_t** %tmp1, i32) {
25top:
26  br label %top.split
27
28top.split:                                        ; preds = %top
29  %tmp3 = load %jl_value_t*, %jl_value_t** %tmp1, align 8
30  %tmp4 = bitcast %jl_value_t* %tmp3 to double**
31  %tmp5 = load double*, double** %tmp4, align 8
32  %tmp6 = getelementptr inbounds %jl_value_t, %jl_value_t* %tmp3, i64 3, i32 0
33  %tmp7 = bitcast %jl_value_t** %tmp6 to i64*
34  %tmp8 = load i64, i64* %tmp7, align 8
35  %tmp9 = getelementptr %jl_value_t*, %jl_value_t** %tmp1, i64 1
36  %tmp10 = load %jl_value_t*, %jl_value_t** %tmp9, align 8
37  %tmp11 = bitcast %jl_value_t* %tmp10 to double**
38  %tmp12 = load double*, double** %tmp11, align 8
39  %tmp13 = getelementptr inbounds %jl_value_t, %jl_value_t* %tmp10, i64 3, i32 0
40  %tmp14 = bitcast %jl_value_t** %tmp13 to i64*
41  %tmp15 = load i64, i64* %tmp14, align 8
42  %tmp16 = getelementptr %jl_value_t*, %jl_value_t** %tmp1, i64 2
43  %tmp17 = load %jl_value_t*, %jl_value_t** %tmp16, align 8
44  %tmp18 = bitcast %jl_value_t* %tmp17 to double**
45  %tmp19 = load double*, double** %tmp18, align 8
46  %tmp20 = getelementptr inbounds %jl_value_t, %jl_value_t* %tmp17, i64 3, i32 0
47  %tmp21 = bitcast %jl_value_t** %tmp20 to i64*
48  %tmp22 = load i64, i64* %tmp21, align 8
49  %tmp23 = icmp sgt i64 %tmp8, 0
50  %tmp24 = select i1 %tmp23, i64 %tmp8, i64 0
51  %tmp25 = add i64 %tmp24, 1
52  %tmp26 = icmp eq i64 %tmp24, 0
53  br i1 %tmp26, label %L.11, label %L.preheader
54
55L.preheader:                                      ; preds = %top.split
56  br label %L
57
58L:                                                ; preds = %L.preheader, %L.9
59  %"#s5.0" = phi i64 [ %tmp27, %L.9 ], [ 1, %L.preheader ]
60  %tmp27 = add i64 %"#s5.0", 1
61  br i1 %tmp26, label %L.9, label %L.2.preheader
62
63L.2.preheader:                                    ; preds = %L
64  br label %L.2
65
66L.2:                                              ; preds = %L.2.preheader, %L.7
67  %"#s4.0" = phi i64 [ %tmp28, %L.7 ], [ 1, %L.2.preheader ]
68  %tmp28 = add i64 %"#s4.0", 1
69  br i1 %tmp26, label %L.7, label %L.4.preheader
70
71L.4.preheader:                                    ; preds = %L.2
72  br label %L.4
73
74L.4:                                              ; preds = %L.4.preheader, %L.4
75  %"#s3.0" = phi i64 [ %tmp29, %L.4 ], [ 1, %L.4.preheader ]
76  %tmp29 = add i64 %"#s3.0", 1
77  %tmp30 = add i64 %"#s5.0", -1
78  %tmp31 = add i64 %"#s4.0", -1
79  %tmp32 = mul i64 %tmp31, %tmp22
80  %tmp33 = add i64 %tmp32, %tmp30
81  %tmp34 = getelementptr double, double* %tmp19, i64 %tmp33
82  %tmp35 = load double, double* %tmp34, align 8
83  %tmp36 = add i64 %"#s3.0", -1
84  %tmp37 = mul i64 %tmp36, %tmp8
85  %tmp38 = add i64 %tmp37, %tmp30
86  %tmp39 = getelementptr double, double* %tmp5, i64 %tmp38
87  %tmp40 = load double, double* %tmp39, align 8
88  %tmp41 = mul i64 %tmp36, %tmp15
89  %tmp42 = add i64 %tmp41, %tmp31
90  %tmp43 = getelementptr double, double* %tmp12, i64 %tmp42
91  %tmp44 = load double, double* %tmp43, align 8
92  %tmp45 = fmul double %tmp40, %tmp44
93  %tmp46 = fadd double %tmp35, %tmp45
94  store double %tmp46, double* %tmp34, align 8
95  %tmp47 = icmp eq i64 %tmp29, %tmp25
96  br i1 %tmp47, label %L.7.loopexit, label %L.4
97
98L.7.loopexit:                                     ; preds = %L.4
99  br label %L.7
100
101L.7:                                              ; preds = %L.7.loopexit, %L.2
102  %tmp48 = icmp eq i64 %tmp28, %tmp25
103  br i1 %tmp48, label %L.9.loopexit, label %L.2
104
105L.9.loopexit:                                     ; preds = %L.7
106  br label %L.9
107
108L.9:                                              ; preds = %L.9.loopexit, %L
109  %tmp49 = icmp eq i64 %tmp27, %tmp25
110  br i1 %tmp49, label %L.11.loopexit, label %L
111
112L.11.loopexit:                                    ; preds = %L.9
113  br label %L.11
114
115L.11:                                             ; preds = %L.11.loopexit, %top.split
116  ret %jl_value_t* inttoptr (i64 140220477440016 to %jl_value_t*)
117}
118