blob: a35596aff11c678f0a5929e38b9d4d3a5ca378ce [file] [log] [blame]
Jan Wen Voung6dc30762013-03-12 16:27:52 +00001; REQUIRES: asserts
Chad Rosier38876942011-12-22 21:06:36 +00002; RUN: opt -loop-unswitch -disable-output -stats -info-output-file - < %s | FileCheck --check-prefix=STATS %s
Dmitri Gribenkob137c9e2012-12-30 01:28:40 +00003; RUN: opt -S -loop-unswitch -verify-loop-info -verify-dom-info < %s | FileCheck %s
Chad Rosier38876942011-12-22 21:06:36 +00004
5; STATS: 1 loop-simplify - Number of pre-header or exit blocks inserted
6; STATS: 2 loop-unswitch - Number of switches unswitched
7
8; CHECK: %1 = icmp eq i32 %c, 1
9; CHECK-NEXT: br i1 %1, label %.split.us, label %..split_crit_edge
10
11; CHECK: ..split_crit_edge: ; preds = %0
12; CHECK-NEXT: br label %.split
13
14; CHECK: .split.us: ; preds = %0
15; CHECK-NEXT: br label %loop_begin.us
16
17; CHECK: loop_begin.us: ; preds = %loop_begin.backedge.us, %.split.us
David Blaikiea79ac142015-02-27 21:17:42 +000018; CHECK-NEXT: %var_val.us = load i32, i32* %var
Chad Rosier38876942011-12-22 21:06:36 +000019; CHECK-NEXT: switch i32 1, label %default.us-lcssa.us [
20; CHECK-NEXT: i32 1, label %inc.us
21
22; CHECK: inc.us: ; preds = %loop_begin.us
Bill Wendlinga0323742013-02-22 09:09:42 +000023; CHECK-NEXT: call void @incf() [[NOR_NUW:#[0-9]+]]
Chad Rosier38876942011-12-22 21:06:36 +000024; CHECK-NEXT: br label %loop_begin.backedge.us
25
26; CHECK: .split: ; preds = %..split_crit_edge
27; CHECK-NEXT: %2 = icmp eq i32 %c, 2
28; CHECK-NEXT: br i1 %2, label %.split.split.us, label %.split..split.split_crit_edge
29
30; CHECK: .split..split.split_crit_edge: ; preds = %.split
31; CHECK-NEXT: br label %.split.split
32
33; CHECK: .split.split.us: ; preds = %.split
34; CHECK-NEXT: br label %loop_begin.us1
35
36; CHECK: loop_begin.us1: ; preds = %loop_begin.backedge.us5, %.split.split.us
Rafael Espindolad1beb072015-11-22 00:16:24 +000037; CHECK-NEXT: %var_val.us2 = load i32, i32* %var
Chad Rosier38876942011-12-22 21:06:36 +000038; CHECK-NEXT: switch i32 2, label %default.us-lcssa.us-lcssa.us [
Andrew Trickfb2ba3e2012-06-26 04:11:38 +000039; CHECK-NEXT: i32 1, label %inc.us4
40; CHECK-NEXT: i32 2, label %dec.us3
Chad Rosier38876942011-12-22 21:06:36 +000041; CHECK-NEXT: ]
42
Andrew Trickfb2ba3e2012-06-26 04:11:38 +000043; CHECK: dec.us3: ; preds = %loop_begin.us1
Bill Wendlinga0323742013-02-22 09:09:42 +000044; CHECK-NEXT: call void @decf() [[NOR_NUW]]
Chad Rosier38876942011-12-22 21:06:36 +000045; CHECK-NEXT: br label %loop_begin.backedge.us5
46
47; CHECK: .split.split: ; preds = %.split..split.split_crit_edge
48; CHECK-NEXT: br label %loop_begin
49
50; CHECK: loop_begin: ; preds = %loop_begin.backedge, %.split.split
David Blaikiea79ac142015-02-27 21:17:42 +000051; CHECK-NEXT: %var_val = load i32, i32* %var
Chad Rosier38876942011-12-22 21:06:36 +000052; CHECK-NEXT: switch i32 %c, label %default.us-lcssa.us-lcssa [
53; CHECK-NEXT: i32 1, label %inc
54; CHECK-NEXT: i32 2, label %dec
55; CHECK-NEXT: ]
56
57; CHECK: inc: ; preds = %loop_begin
58; CHECK-NEXT: br i1 true, label %us-unreachable.us-lcssa, label %inc.split
59
60; CHECK: dec: ; preds = %loop_begin
61; CHECK-NEXT: br i1 true, label %us-unreachable6, label %dec.split
62
63define i32 @test(i32* %var) {
64 %mem = alloca i32
65 store i32 2, i32* %mem
David Blaikiea79ac142015-02-27 21:17:42 +000066 %c = load i32, i32* %mem
Chad Rosier38876942011-12-22 21:06:36 +000067
68 br label %loop_begin
69
70loop_begin:
71
David Blaikiea79ac142015-02-27 21:17:42 +000072 %var_val = load i32, i32* %var
Chad Rosier38876942011-12-22 21:06:36 +000073
74 switch i32 %c, label %default [
75 i32 1, label %inc
76 i32 2, label %dec
77 ]
78
79inc:
80 call void @incf() noreturn nounwind
81 br label %loop_begin
82dec:
83 call void @decf() noreturn nounwind
84 br label %loop_begin
Andrew Trickfb2ba3e2012-06-26 04:11:38 +000085default:
Chad Rosier38876942011-12-22 21:06:36 +000086 br label %loop_exit
87loop_exit:
88 ret i32 0
89}
90
91declare void @incf() noreturn
92declare void @decf() noreturn
Bill Wendlinga0323742013-02-22 09:09:42 +000093
94; CHECK: attributes #0 = { noreturn }
95; CHECK: attributes [[NOR_NUW]] = { noreturn nounwind }