annotate polly/test/ScopInfo/multidim_with_bitcast.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: 150
diff changeset
1 ; RUN: opt %loadPolly -polly-stmt-granularity=bb -polly-print-scops -disable-output < %s | FileCheck %s
150
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 ; Verify that we can look through a bitcast when delinearizing multi-dimensional
anatofuz
parents:
diff changeset
6 ; arrays.
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 ; CHECK: Stmt_bb7[i0, i1] -> MemRef_B[i0, i1]
anatofuz
parents:
diff changeset
9 ; CHECK: Stmt_bb7[i0, i1] -> MemRef_B[i0, i1]
anatofuz
parents:
diff changeset
10 ; CHECK: Stmt_bb17[i0] -> MemRef_B[i0, 100]
anatofuz
parents:
diff changeset
11
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
12 define void @kernel(ptr %A, ptr %B, ptr %C, ptr %D) {
150
anatofuz
parents:
diff changeset
13 bb:
anatofuz
parents:
diff changeset
14 br label %bb4
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 bb4: ; preds = %bb21, %bb
anatofuz
parents:
diff changeset
17 %indvars.iv1 = phi i64 [ %indvars.iv.next2, %bb21 ], [ 0, %bb ]
anatofuz
parents:
diff changeset
18 %exitcond3 = icmp eq i64 %indvars.iv1, 100
anatofuz
parents:
diff changeset
19 br i1 %exitcond3, label %bb22, label %bb5
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 bb5: ; preds = %bb4
anatofuz
parents:
diff changeset
22 br label %bb6
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 bb6: ; preds = %bb16, %bb5
anatofuz
parents:
diff changeset
25 %indvars.iv = phi i64 [ %indvars.iv.next, %bb16 ], [ 0, %bb5 ]
anatofuz
parents:
diff changeset
26 %exitcond = icmp eq i64 %indvars.iv, 100
anatofuz
parents:
diff changeset
27 br i1 %exitcond, label %bb17, label %bb7
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 bb7: ; preds = %bb6
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
30 %tmp = getelementptr inbounds float, ptr %D, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
31 %tmp8 = load float, ptr %tmp, align 4
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
32 %tmp9 = getelementptr inbounds [101 x float], ptr %B, i64 %indvars.iv1, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
33 %tmp10 = load float, ptr %tmp9, align 4
150
anatofuz
parents:
diff changeset
34 %tmp11 = fmul float %tmp8, %tmp10
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
35 %tmp12 = getelementptr inbounds [101 x float], ptr %C, i64 %indvars.iv1, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
36 store float %tmp11, ptr %tmp12, align 4
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
37 %tmp13 = getelementptr inbounds float, ptr %A, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
38 %tmp141 = load i32, ptr %tmp13, align 4
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
39 %tmp15 = getelementptr inbounds [101 x float], ptr %B, i64 %indvars.iv1, i64 %indvars.iv
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
40 store i32 %tmp141, ptr %tmp15, align 4
150
anatofuz
parents:
diff changeset
41 br label %bb16
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 bb16: ; preds = %bb7
anatofuz
parents:
diff changeset
44 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
anatofuz
parents:
diff changeset
45 br label %bb6
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47 bb17: ; preds = %bb6
anatofuz
parents:
diff changeset
48 %tmp18 = trunc i64 %indvars.iv1 to i32
anatofuz
parents:
diff changeset
49 %tmp19 = sitofp i32 %tmp18 to float
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
50 %tmp20 = getelementptr inbounds [101 x float], ptr %B, i64 %indvars.iv1, i64 100
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
51 store float %tmp19, ptr %tmp20, align 4
150
anatofuz
parents:
diff changeset
52 br label %bb21
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 bb21: ; preds = %bb17
anatofuz
parents:
diff changeset
55 %indvars.iv.next2 = add nuw nsw i64 %indvars.iv1, 1
anatofuz
parents:
diff changeset
56 br label %bb4
anatofuz
parents:
diff changeset
57
anatofuz
parents:
diff changeset
58 bb22: ; preds = %bb4
anatofuz
parents:
diff changeset
59 ret void
anatofuz
parents:
diff changeset
60 }