summaryrefslogtreecommitdiff
path: root/polly/test/ScopInfo/invariant-loads-leave-read-only-statements.ll
blob: b97fe22e076e3c5dfe738c2429fc8ae80fbb2a0f (plain)
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
; RUN: opt %loadPolly -polly-print-scops -polly-invariant-load-hoisting=true -disable-output < %s | FileCheck %s
; RUN: opt %loadPolly -polly-codegen -polly-invariant-load-hoisting=true -disable-output < %s

; CHECK:      Statements {
; CHECK-NEXT: 	Stmt_L_4
; CHECK-NEXT:         Domain :=
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] : 0 <= i0 < tmp8 and 0 <= i1 < tmp8 and 0 <= i2 < tmp8 };
; CHECK-NEXT:         Schedule :=
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> [i0, i1, i2] };
; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp19[i1, i0] };
; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp5[i2, i0] };
; CHECK-NEXT:         ReadAccess :=	[Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp12[i2, i1] };
; CHECK-NEXT:         MustWriteAccess :=	[Reduction Type: NONE] [Scalar: 0]
; CHECK-NEXT:             [tmp8, tmp22, tmp15] -> { Stmt_L_4[i0, i1, i2] -> MemRef_tmp19[i1, i0] };
; CHECK-NEXT: }

target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"

%jl_value_t = type { ptr }

define ptr @julia_gemm_22583(ptr, ptr %tmp1, i32) {
top:
  br label %top.split

top.split:                                        ; preds = %top
  %tmp3 = load ptr, ptr %tmp1, align 8
  %tmp5 = load ptr, ptr %tmp3, align 8
  %tmp6 = getelementptr inbounds %jl_value_t, ptr %tmp3, i64 3, i32 0
  %tmp8 = load i64, ptr %tmp6, align 8
  %tmp9 = getelementptr ptr, ptr %tmp1, i64 1
  %tmp10 = load ptr, ptr %tmp9, align 8
  %tmp12 = load ptr, ptr %tmp10, align 8
  %tmp13 = getelementptr inbounds %jl_value_t, ptr %tmp10, i64 3, i32 0
  %tmp15 = load i64, ptr %tmp13, align 8
  %tmp16 = getelementptr ptr, ptr %tmp1, i64 2
  %tmp17 = load ptr, ptr %tmp16, align 8
  %tmp19 = load ptr, ptr %tmp17, align 8
  %tmp20 = getelementptr inbounds %jl_value_t, ptr %tmp17, i64 3, i32 0
  %tmp22 = load i64, ptr %tmp20, align 8
  %tmp23 = icmp sgt i64 %tmp8, 0
  %tmp24 = select i1 %tmp23, i64 %tmp8, i64 0
  %tmp25 = add i64 %tmp24, 1
  %tmp26 = icmp eq i64 %tmp24, 0
  br i1 %tmp26, label %L.11, label %L.preheader

L.preheader:                                      ; preds = %top.split
  br label %L

L:                                                ; preds = %L.preheader, %L.9
  %"#s5.0" = phi i64 [ %tmp27, %L.9 ], [ 1, %L.preheader ]
  %tmp27 = add i64 %"#s5.0", 1
  br i1 %tmp26, label %L.9, label %L.2.preheader

L.2.preheader:                                    ; preds = %L
  br label %L.2

L.2:                                              ; preds = %L.2.preheader, %L.7
  %"#s4.0" = phi i64 [ %tmp28, %L.7 ], [ 1, %L.2.preheader ]
  %tmp28 = add i64 %"#s4.0", 1
  br i1 %tmp26, label %L.7, label %L.4.preheader

L.4.preheader:                                    ; preds = %L.2
  br label %L.4

L.4:                                              ; preds = %L.4.preheader, %L.4
  %"#s3.0" = phi i64 [ %tmp29, %L.4 ], [ 1, %L.4.preheader ]
  %tmp29 = add i64 %"#s3.0", 1
  %tmp30 = add i64 %"#s5.0", -1
  %tmp31 = add i64 %"#s4.0", -1
  %tmp32 = mul i64 %tmp31, %tmp22
  %tmp33 = add i64 %tmp32, %tmp30
  %tmp34 = getelementptr double, ptr %tmp19, i64 %tmp33
  %tmp35 = load double, ptr %tmp34, align 8
  %tmp36 = add i64 %"#s3.0", -1
  %tmp37 = mul i64 %tmp36, %tmp8
  %tmp38 = add i64 %tmp37, %tmp30
  %tmp39 = getelementptr double, ptr %tmp5, i64 %tmp38
  %tmp40 = load double, ptr %tmp39, align 8
  %tmp41 = mul i64 %tmp36, %tmp15
  %tmp42 = add i64 %tmp41, %tmp31
  %tmp43 = getelementptr double, ptr %tmp12, i64 %tmp42
  %tmp44 = load double, ptr %tmp43, align 8
  %tmp45 = fmul double %tmp40, %tmp44
  %tmp46 = fadd double %tmp35, %tmp45
  store double %tmp46, ptr %tmp34, align 8
  %tmp47 = icmp eq i64 %tmp29, %tmp25
  br i1 %tmp47, label %L.7.loopexit, label %L.4

L.7.loopexit:                                     ; preds = %L.4
  br label %L.7

L.7:                                              ; preds = %L.7.loopexit, %L.2
  %tmp48 = icmp eq i64 %tmp28, %tmp25
  br i1 %tmp48, label %L.9.loopexit, label %L.2

L.9.loopexit:                                     ; preds = %L.7
  br label %L.9

L.9:                                              ; preds = %L.9.loopexit, %L
  %tmp49 = icmp eq i64 %tmp27, %tmp25
  br i1 %tmp49, label %L.11.loopexit, label %L

L.11.loopexit:                                    ; preds = %L.9
  br label %L.11

L.11:                                             ; preds = %L.11.loopexit, %top.split
  ret ptr inttoptr (i64 140220477440016 to ptr)
}