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