annotate llvm/test/Transforms/StructurizeCFG/one-loop-multiple-backedges.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: 221
diff changeset
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
150
anatofuz
parents:
diff changeset
2 ; RUN: opt -S -structurizecfg %s -o - | FileCheck %s
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 ; CHECK-NOT: br i1 true
anatofuz
parents:
diff changeset
5
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
6 define void @blam(ptr addrspace(1) nocapture %arg, float %arg1, float %arg2) {
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
7 ; CHECK-LABEL: @blam(
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
8 ; CHECK-NEXT: bb:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
9 ; CHECK-NEXT: br label [[BB3:%.*]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
10 ; CHECK: bb3:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
11 ; CHECK-NEXT: [[TMP:%.*]] = phi i64 [ 0, [[BB:%.*]] ], [ [[TMP2:%.*]], [[FLOW1:%.*]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
12 ; CHECK-NEXT: [[TMP4:%.*]] = fcmp ult float [[ARG1:%.*]], 3.500000e+00
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
13 ; CHECK-NEXT: [[TMP4_INV:%.*]] = xor i1 [[TMP4]], true
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
14 ; CHECK-NEXT: br i1 [[TMP4_INV]], label [[BB5:%.*]], label [[FLOW:%.*]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
15 ; CHECK: bb5:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
16 ; CHECK-NEXT: [[TMP6:%.*]] = fcmp uge float 0.000000e+00, [[ARG2:%.*]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
17 ; CHECK-NEXT: br label [[FLOW]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
18 ; CHECK: Flow:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
19 ; CHECK-NEXT: [[TMP0:%.*]] = phi i32 [ 15, [[BB5]] ], [ undef, [[BB3]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
20 ; CHECK-NEXT: [[TMP1:%.*]] = phi i1 [ [[TMP6]], [[BB5]] ], [ [[TMP4]], [[BB3]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
21 ; CHECK-NEXT: br i1 [[TMP1]], label [[BB7:%.*]], label [[FLOW1]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
22 ; CHECK: bb7:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
23 ; CHECK-NEXT: [[TMP8:%.*]] = add nuw nsw i64 [[TMP]], 1
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
24 ; CHECK-NEXT: [[TMP9:%.*]] = icmp sge i64 [[TMP8]], 5
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
25 ; CHECK-NEXT: br label [[FLOW1]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
26 ; CHECK: Flow1:
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
27 ; CHECK-NEXT: [[TMP2]] = phi i64 [ [[TMP8]], [[BB7]] ], [ undef, [[FLOW]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
28 ; CHECK-NEXT: [[TMP3:%.*]] = phi i32 [ 255, [[BB7]] ], [ [[TMP0]], [[FLOW]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
29 ; CHECK-NEXT: [[TMP4:%.*]] = phi i1 [ [[TMP9]], [[BB7]] ], [ true, [[FLOW]] ]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
30 ; CHECK-NEXT: br i1 [[TMP4]], label [[BB10:%.*]], label [[BB3]]
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
31 ; CHECK: bb10:
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
32 ; CHECK-NEXT: store i32 [[TMP3]], ptr addrspace(1) [[ARG:%.*]], align 4
236
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
33 ; CHECK-NEXT: ret void
c4bab56944e8 LLVM 16
kono
parents: 221
diff changeset
34 ;
150
anatofuz
parents:
diff changeset
35 bb:
anatofuz
parents:
diff changeset
36 br label %bb3
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 bb3: ; preds = %bb7, %bb
anatofuz
parents:
diff changeset
39 %tmp = phi i64 [ 0, %bb ], [ %tmp8, %bb7 ]
anatofuz
parents:
diff changeset
40 %tmp4 = fcmp ult float %arg1, 3.500000e+00
anatofuz
parents:
diff changeset
41 br i1 %tmp4, label %bb7, label %bb5
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 bb5: ; preds = %bb3
anatofuz
parents:
diff changeset
44 %tmp6 = fcmp olt float 0.000000e+00, %arg2
anatofuz
parents:
diff changeset
45 br i1 %tmp6, label %bb10, label %bb7
anatofuz
parents:
diff changeset
46
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 bb7: ; preds = %bb5, %bb3
anatofuz
parents:
diff changeset
49 %tmp8 = add nuw nsw i64 %tmp, 1
anatofuz
parents:
diff changeset
50 %tmp9 = icmp slt i64 %tmp8, 5
anatofuz
parents:
diff changeset
51 br i1 %tmp9, label %bb3, label %bb10
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53
anatofuz
parents:
diff changeset
54 bb10: ; preds = %bb7, %bb5
anatofuz
parents:
diff changeset
55 %tmp11 = phi i32 [ 15, %bb5 ], [ 255, %bb7 ]
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
56 store i32 %tmp11, ptr addrspace(1) %arg, align 4
150
anatofuz
parents:
diff changeset
57 ret void
anatofuz
parents:
diff changeset
58 }