annotate polly/test/CodeGen/uninitialized_scalar_memory.ll @ 252:1f2b6ac9f198 llvm-original

LLVM16-1
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 18 Aug 2023 09:04:13 +0900
parents c4bab56944e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
1 ; RUN: opt %loadPolly -S -polly-codegen < %s | FileCheck %s
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
2 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
3 ; Verify we initialize the scalar locations reserved for the incoming phi
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
4 ; values.
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
5 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
6 ; CHECK: polly.start:
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
7 ; CHECK-NEXT: store float %ebig.0, ptr %ebig.0.s2a
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
8 ; CHECK-NEXT: br label %polly.stmt.if.end.entry
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
9 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
10 ; int g(void);
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
11 ; float M;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
12 ; int max(float *restrict xbig, int eres, int bres, float *restrict indx) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
13 ; int i, iebig;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
14 ; float ebig;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
15 ; for (i = 0; i < 4 + eres; i++) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
16 ; if (g())
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
17 ; break;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
18 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
19 ; if (xbig[i] > ebig) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
20 ; ebig = xbig[i];
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
21 ; iebig = (int)(indx[i] + bres);
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
22 ; }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
23 ; }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
24 ; return (iebig);
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
25 ; }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
26 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
27 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
28
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
29 @M = common global float 0.000000e+00, align 4
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
30
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
31 define i32 @max(ptr noalias %xbig, i32 %eres, i32 %bres, ptr noalias %indx) {
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
32 entry:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
33 br label %for.cond
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
34
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
35 for.cond: ; preds = %for.inc, %entry
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
36 %indvars.iv = phi i64 [ %indvars.iv.next, %for.inc ], [ 0, %entry ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
37 %iebig.0 = phi i32 [ undef, %entry ], [ %iebig.1, %for.inc ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
38 %ebig.0 = phi float [ undef, %entry ], [ %ebig.1, %for.inc ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
39 %add = add nsw i32 %eres, 4
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
40 %tmp = sext i32 %add to i64
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
41 %cmp = icmp slt i64 %indvars.iv, %tmp
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
42 br i1 %cmp, label %for.body, label %for.end.loopexit
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
43
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
44 for.body: ; preds = %for.cond
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
45 %call = call i32 @g() #2
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
46 %tobool = icmp eq i32 %call, 0
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
47 br i1 %tobool, label %if.end, label %if.then
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
48
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
49 if.then: ; preds = %for.body
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
50 %iebig.0.lcssa1 = phi i32 [ %iebig.0, %for.body ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
51 br label %for.end
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
52
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
53 if.end: ; preds = %for.body
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
54 %arrayidx = getelementptr inbounds float, ptr %xbig, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
55 %tmp3 = load float, ptr %arrayidx, align 4
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
56 %cmp1 = fcmp ogt float %tmp3, %ebig.0
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
57 br i1 %cmp1, label %if.then.2, label %if.end.9
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
58
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
59 if.then.2: ; preds = %if.end
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
60 %arrayidx4 = getelementptr inbounds float, ptr %xbig, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
61 %tmp4 = load float, ptr %arrayidx4, align 4
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
62 %arrayidx6 = getelementptr inbounds float, ptr %indx, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
63 %tmp5 = load float, ptr %arrayidx6, align 4
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
64 %conv = sitofp i32 %bres to float
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
65 %add7 = fadd float %tmp5, %conv
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
66 %conv8 = fptosi float %add7 to i32
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
67 br label %if.end.9
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
68
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
69 if.end.9: ; preds = %if.then.2, %if.end
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
70 %iebig.1 = phi i32 [ %conv8, %if.then.2 ], [ %iebig.0, %if.end ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
71 %ebig.1 = phi float [ %tmp4, %if.then.2 ], [ %ebig.0, %if.end ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
72 br label %for.inc
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
73
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
74 for.inc: ; preds = %if.end.9
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
75 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
76 br label %for.cond
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
77
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
78 for.end.loopexit: ; preds = %for.cond
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
79 %iebig.0.lcssa = phi i32 [ %iebig.0, %for.cond ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
80 br label %for.end
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
81
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
82 for.end: ; preds = %for.end.loopexit, %if.then
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
83 %iebig.02 = phi i32 [ %iebig.0.lcssa, %for.end.loopexit ], [ %iebig.0.lcssa1, %if.then ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
84 ret i32 %iebig.02
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
85 }
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
86
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
87 declare i32 @g() #1