b82d93455436b4f3926f48f37860e337fd1b8e3e
[oota-llvm.git] / test / Transforms / LowerSwitch / feature.ll
1 ; RUN: opt < %s -lowerswitch -S | FileCheck %s
2
3 ; We have switch on input.
4 ; On output we should got binary comparison tree. Check that all is fine.
5
6 ;CHECK:     entry:
7 ;CHECK-NEXT:  br label %NodeBlock.19
8
9 ;CHECK:     NodeBlock.19:                                      ; preds = %entry
10 ;CHECK-NEXT:  %Pivot.20 = icmp slt i32 %tmp158, 10
11 ;CHECK-NEXT:  br i1 %Pivot.20, label %NodeBlock.5, label %NodeBlock.17
12
13 ;CHECK:     NodeBlock.17:                                      ; preds = %NodeBlock.19
14 ;CHECK-NEXT:  %Pivot.18 = icmp slt i32 %tmp158, 13
15 ;CHECK-NEXT:  br i1 %Pivot.18, label %NodeBlock.9, label %NodeBlock.15
16
17 ;CHECK:     NodeBlock.15:                                      ; preds = %NodeBlock.17
18 ;CHECK-NEXT:  %Pivot.16 = icmp slt i32 %tmp158, 14
19 ;CHECK-NEXT:  br i1 %Pivot.16, label %bb330, label %NodeBlock.13
20
21 ;CHECK:     NodeBlock.13:                                      ; preds = %NodeBlock.15
22 ;CHECK-NEXT:  %Pivot.14 = icmp slt i32 %tmp158, 15
23 ;CHECK-NEXT:  br i1 %Pivot.14, label %bb332, label %LeafBlock.11
24
25 ;CHECK:     LeafBlock.11:                                      ; preds = %NodeBlock.13
26 ;CHECK-NEXT:  %SwitchLeaf12 = icmp eq i32 %tmp158, 15
27 ;CHECK-NEXT:  br i1 %SwitchLeaf12, label %bb334, label %NewDefault
28
29 ;CHECK:     NodeBlock.9:                                       ; preds = %NodeBlock.17
30 ;CHECK-NEXT:  %Pivot.10 = icmp slt i32 %tmp158, 11
31 ;CHECK-NEXT:  br i1 %Pivot.10, label %bb324, label %NodeBlock.7
32
33 ;CHECK:     NodeBlock.7:                                       ; preds = %NodeBlock.9
34 ;CHECK-NEXT:  %Pivot.8 = icmp slt i32 %tmp158, 12
35 ;CHECK-NEXT:  br i1 %Pivot.8, label %bb326, label %bb328
36
37 ;CHECK:     NodeBlock.5:                                       ; preds = %NodeBlock.19
38 ;CHECK-NEXT:  %Pivot.6 = icmp slt i32 %tmp158, 7
39 ;CHECK-NEXT:  br i1 %Pivot.6, label %NodeBlock, label %NodeBlock.3
40
41 ;CHECK:     NodeBlock.3:                                       ; preds = %NodeBlock.5
42 ;CHECK-NEXT:  %Pivot.4 = icmp slt i32 %tmp158, 8
43 ;CHECK-NEXT:  br i1 %Pivot.4, label %bb, label %NodeBlock.1
44
45 ;CHECK:     NodeBlock.1:                                       ; preds = %NodeBlock.3
46 ;CHECK-NEXT:  %Pivot.2 = icmp slt i32 %tmp158, 9
47 ;CHECK-NEXT:  br i1 %Pivot.2, label %bb338, label %bb322
48
49 ;CHECK:     NodeBlock:                                        ; preds = %NodeBlock.5
50 ;CHECK-NEXT:  %Pivot = icmp slt i32 %tmp158, 0
51 ;CHECK-NEXT:  br i1 %Pivot, label %LeafBlock, label %bb338
52
53 ;CHECK:     LeafBlock:                                        ; preds = %NodeBlock
54 ;CHECK-NEXT:  %tmp158.off = add i32 %tmp158, 6
55 ;CHECK-NEXT:  %SwitchLeaf = icmp ule i32 %tmp158.off, 4
56 ;CHECK-NEXT:  br i1 %SwitchLeaf, label %bb338, label %NewDefault
57
58 define i32 @main(i32 %tmp158) {
59 entry:
60
61         switch i32 %tmp158, label %bb336 [
62                  i32 -2, label %bb338
63                  i32 -3, label %bb338
64                  i32 -4, label %bb338
65                  i32 -5, label %bb338
66                  i32 -6, label %bb338
67                  i32 0, label %bb338
68                  i32 1, label %bb338
69                  i32 2, label %bb338
70                  i32 3, label %bb338
71                  i32 4, label %bb338
72                  i32 5, label %bb338
73                  i32 6, label %bb338
74                  i32 7, label %bb
75                  i32 8, label %bb338
76                  i32 9, label %bb322
77                  i32 10, label %bb324
78                  i32 11, label %bb326
79                  i32 12, label %bb328
80                  i32 13, label %bb330
81                  i32 14, label %bb332
82                  i32 15, label %bb334
83         ]
84 bb:
85   ret i32 2
86 bb322:
87   ret i32 3
88 bb324:
89   ret i32 4
90 bb326:
91   ret i32 5
92 bb328:
93   ret i32 6
94 bb330:
95   ret i32 7
96 bb332:
97   ret i32 8
98 bb334:
99   ret i32 9
100 bb336:
101   ret i32 10
102 bb338:
103   ret i32 11
104 }