annotate polly/test/ScopInfo/infeasible-rtc.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-print-detect -disable-output < %s \
150
anatofuz
parents:
diff changeset
2 ; RUN: | FileCheck %s -check-prefix=DETECT
anatofuz
parents:
diff changeset
3
236
c4bab56944e8 LLVM 16
kono
parents: 150
diff changeset
4 ; RUN: opt %loadPolly -polly-print-scops -disable-output < %s \
150
anatofuz
parents:
diff changeset
5 ; RUN: | FileCheck %s -check-prefix=SCOPS
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64-S128"
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 ; DETECT: Valid Region for Scop: test1.header => test1.exit
anatofuz
parents:
diff changeset
10 ; SCOPS-NOT: Region: %test1.header---%test1.exit
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 ; Verify that we detect this scop, but that, due to an infeasible run-time
anatofuz
parents:
diff changeset
13 ; check, we refuse to model it.
anatofuz
parents:
diff changeset
14
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
15 define void @test(ptr %a) nounwind uwtable {
150
anatofuz
parents:
diff changeset
16 preheader:
anatofuz
parents:
diff changeset
17 br label %test1.header
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 test1.header:
anatofuz
parents:
diff changeset
20 %i = phi i56 [ 0, %preheader ], [ %i.1, %test1.header ]
anatofuz
parents:
diff changeset
21 %tmp = zext i56 %i to i64
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
22 %A.addr = getelementptr i64, ptr %a, i64 %tmp
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
23 %A.load = load i64, ptr %A.addr, align 4
150
anatofuz
parents:
diff changeset
24 %A.inc = zext i56 %i to i64
anatofuz
parents:
diff changeset
25 %A.val = add nsw i64 %A.load, %A.inc
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
26 store i64 %A.val, ptr %A.addr, align 4
150
anatofuz
parents:
diff changeset
27 %i.1 = add i56 %i, 1
anatofuz
parents:
diff changeset
28 %exitcond = icmp eq i56 %i.1, 0
anatofuz
parents:
diff changeset
29 br i1 %exitcond, label %test1.exit, label %test1.header
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 test1.exit:
anatofuz
parents:
diff changeset
32 ret void
anatofuz
parents:
diff changeset
33 }
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 ; Old version of the previous test; make sure we compute the trip count
anatofuz
parents:
diff changeset
36 ; correctly.
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 ; SCOPS: { Stmt_header[i0] : 0 <= i0 <= 127 };
anatofuz
parents:
diff changeset
39
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
40 define void @test2(ptr %a) nounwind uwtable {
150
anatofuz
parents:
diff changeset
41 preheader:
anatofuz
parents:
diff changeset
42 br label %header
anatofuz
parents:
diff changeset
43
anatofuz
parents:
diff changeset
44 header:
anatofuz
parents:
diff changeset
45 %i = phi i7 [ 0, %preheader ], [ %i.1, %header ]
anatofuz
parents:
diff changeset
46 %tmp = zext i7 %i to i64
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
47 %A.addr = getelementptr [128 x i32], ptr %a, i64 0, i64 %tmp
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
48 %A.load = load i32, ptr %A.addr, align 4
150
anatofuz
parents:
diff changeset
49 %A.inc = zext i7 %i to i32
anatofuz
parents:
diff changeset
50 %A.val = add nsw i32 %A.load, %A.inc
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
51 store i32 %A.val, ptr %A.addr, align 4
150
anatofuz
parents:
diff changeset
52 %i.1 = add i7 %i, 1
anatofuz
parents:
diff changeset
53 %exitcond = icmp eq i7 %i.1, 0
anatofuz
parents:
diff changeset
54 br i1 %exitcond, label %exit, label %header
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 exit:
anatofuz
parents:
diff changeset
57 ret void
anatofuz
parents:
diff changeset
58 }