blob: dc2d27bc16da348a4f598485bf94ea2ef54d6a01 [file] [log] [blame]
Daniel Dunbara5728872009-12-15 20:14:24 +00001// RUN: %clang_cc1 -triple i386-unknown-unknown -O3 %s -emit-llvm -o - | FileCheck %s
Devang Patel51b09f22007-10-04 23:45:31 +00002
3int foo(int i) {
4 int j = 0;
5 switch (i) {
Chris Lattnerc69a5812007-11-30 17:44:57 +00006 case -1:
7 j = 1; break;
Daniel Dunbar600d47e2009-11-20 17:23:39 +00008 case 1 :
Devang Patel51b09f22007-10-04 23:45:31 +00009 j = 2; break;
10 case 2:
11 j = 3; break;
12 default:
13 j = 42; break;
14 }
15 j = j + 1;
16 return j;
17}
18
Devang Patel2d79d0f2007-10-05 20:54:07 +000019int foo2(int i) {
20 int j = 0;
21 switch (i) {
Daniel Dunbar600d47e2009-11-20 17:23:39 +000022 case 1 :
Devang Patel2d79d0f2007-10-05 20:54:07 +000023 j = 2; break;
24 case 2 ... 10:
25 j = 3; break;
26 default:
27 j = 42; break;
28 }
29 j = j + 1;
30 return j;
31}
32
Devang Patelc049e4f2007-10-08 20:57:48 +000033int foo3(int i) {
34 int j = 0;
35 switch (i) {
36 default:
37 j = 42; break;
38 case 111:
39 j = 111; break;
40 case 0 ... 100:
41 j = 1; break;
42 case 222:
43 j = 222; break;
44 }
45 return j;
46}
47
48
Daniel Dunbar600d47e2009-11-20 17:23:39 +000049static int foo4(int i) {
Devang Patelc049e4f2007-10-08 20:57:48 +000050 int j = 0;
51 switch (i) {
52 case 111:
53 j = 111; break;
54 case 0 ... 100:
55 j = 1; break;
56 case 222:
57 j = 222; break;
58 default:
59 j = 42; break;
60 case 501 ... 600:
61 j = 5; break;
62 }
63 return j;
64}
Chris Lattner1438b492007-12-01 05:27:33 +000065
Daniel Dunbar600d47e2009-11-20 17:23:39 +000066// CHECK: define i32 @foo4t()
67// CHECK: ret i32 376
68// CHECK: }
69int foo4t() {
70 // 111 + 1 + 222 + 42 = 376
71 return foo4(111) + foo4(99) + foo4(222) + foo4(601);
72}
73
74// CHECK: define void @foo5()
75// CHECK-NOT: switch
76// CHECK: }
Chris Lattner1438b492007-12-01 05:27:33 +000077void foo5(){
78 switch(0){
79 default:
80 if (0) {
81
82 }
83 }
84}
85
Daniel Dunbar600d47e2009-11-20 17:23:39 +000086// CHECK: define void @foo6()
87// CHECK-NOT: switch
88// CHECK: }
Eli Friedmand28a80d2008-05-12 16:08:04 +000089void foo6(){
90 switch(0){
91 }
92}
93
Daniel Dunbar600d47e2009-11-20 17:23:39 +000094// CHECK: define void @foo7()
95// CHECK-NOT: switch
96// CHECK: }
Eli Friedmand28a80d2008-05-12 16:08:04 +000097void foo7(){
98 switch(0){
99 foo7();
100 }
101}
102
Daniel Dunbarfae7bf22010-04-02 22:29:35 +0000103
104// CHECK: define i32 @f8(
105// CHECK: ret i32 3
106// CHECK: }
107int f8(unsigned x) {
108 switch(x) {
109 default:
110 return 3;
111 case 0xFFFFFFFF ... 1: // This range should be empty because x is unsigned.
112 return 0;
113 }
114}
115
116// Ensure that default after a case range is not ignored.
117//
118// CHECK: define i32 @f9()
119// CHECK: ret i32 10
120// CHECK: }
121static int f9_0(unsigned x) {
122 switch(x) {
123 case 10 ... 0xFFFFFFFF:
124 return 0;
125 default:
126 return 10;
127 }
128}
129int f9() {
130 return f9_0(2);
131}
132
133// Ensure that this doesn't compile to infinite loop in g() due to
134// miscompilation of fallthrough from default to a (tested) case
135// range.
136//
137// CHECK: define i32 @f10()
138// CHECK: ret i32 10
139// CHECK: }
140static int f10_0(unsigned x) {
141 switch(x) {
142 default:
143 x += 1;
144 case 10 ... 0xFFFFFFFF:
145 return 0;
146 }
147}
148
149int f10() {
150 f10_0(1);
151 return 10;
152}
153
154// This generated incorrect code because of poor switch chaining.
155//
156// CHECK: define i32 @f11(
157// CHECK: ret i32 3
158// CHECK: }
159int f11(int x) {
160 switch(x) {
161 default:
162 return 3;
163 case 10 ... 0xFFFFFFFF:
164 return 0;
165 }
166}
167
168// This just asserted because of the way case ranges were calculated.
169//
170// CHECK: define i32 @f12(
171// CHECK: ret i32 3
172// CHECK: }
173int f12(int x) {
174 switch (x) {
175 default:
176 return 3;
177 case 10 ... -1:
178 return 0;
179 }
180}
181
182// Make sure return is not constant (if empty range is skipped or miscompiled)
183//
184// CHECK: define i32 @f13(
185// CHECK: ret i32 %
186// CHECK: }
187int f13(unsigned x) {
188 switch(x) {
189 case 2:
190 // fallthrough empty range
191 case 10 ... 9:
192 return 10;
193 default:
194 return 0;
195 }
196}