1; RUN: llc < %s -march=aarch64
2
3define i8 @test_minsize_uu8(i8 %x) minsize optsize {
4entry:
5  %0 = udiv i8 %x, 10
6  %1 = urem i8 %x, 10
7  %res = add i8 %0, %1
8  ret i8 %res
9}
10
11define i8 @test_minsize_ss8(i8 %x) minsize optsize {
12entry:
13  %0 = sdiv i8 %x, 10
14  %1 = srem i8 %x, 10
15  %res = add i8 %0, %1
16  ret i8 %res
17}
18
19define i8 @test_minsize_us8(i8 %x) minsize optsize {
20entry:
21  %0 = udiv i8 %x, 10
22  %1 = srem i8 %x, 10
23  %res = add i8 %0, %1
24  ret i8 %res
25}
26
27define i8 @test_minsize_su8(i8 %x) minsize optsize {
28entry:
29  %0 = sdiv i8 %x, 10
30  %1 = urem i8 %x, 10
31  %res = add i8 %0, %1
32  ret i8 %res
33}
34
35define i16 @test_minsize_uu16(i16 %x) minsize optsize {
36entry:
37  %0 = udiv i16 %x, 10
38  %1 = urem i16 %x, 10
39  %res = add i16 %0, %1
40  ret i16 %res
41}
42
43define i16 @test_minsize_ss16(i16 %x) minsize optsize {
44entry:
45  %0 = sdiv i16 %x, 10
46  %1 = srem i16 %x, 10
47  %res = add i16 %0, %1
48  ret i16 %res
49}
50
51define i16 @test_minsize_us16(i16 %x) minsize optsize {
52entry:
53  %0 = udiv i16 %x, 10
54  %1 = srem i16 %x, 10
55  %res = add i16 %0, %1
56  ret i16 %res
57}
58
59define i16 @test_minsize_su16(i16 %x) minsize optsize {
60entry:
61  %0 = sdiv i16 %x, 10
62  %1 = urem i16 %x, 10
63  %res = add i16 %0, %1
64  ret i16 %res
65}
66
67define i32 @test_minsize_uu32(i32 %x) minsize optsize {
68entry:
69  %0 = udiv i32 %x, 10
70  %1 = urem i32 %x, 10
71  %res = add i32 %0, %1
72  ret i32 %res
73}
74
75define i32 @test_minsize_ss32(i32 %x) minsize optsize {
76entry:
77  %0 = sdiv i32 %x, 10
78  %1 = srem i32 %x, 10
79  %res = add i32 %0, %1
80  ret i32 %res
81}
82
83define i32 @test_minsize_us32(i32 %x) minsize optsize {
84entry:
85  %0 = udiv i32 %x, 10
86  %1 = srem i32 %x, 10
87  %res = add i32 %0, %1
88  ret i32 %res
89}
90
91define i32 @test_minsize_su32(i32 %x) minsize optsize {
92entry:
93  %0 = sdiv i32 %x, 10
94  %1 = urem i32 %x, 10
95  %res = add i32 %0, %1
96  ret i32 %res
97}
98
99define i64 @test_minsize_uu64(i64 %x) minsize optsize {
100entry:
101  %0 = udiv i64 %x, 10
102  %1 = urem i64 %x, 10
103  %res = add i64 %0, %1
104  ret i64 %res
105}
106
107define i64 @test_minsize_ss64(i64 %x) minsize optsize {
108entry:
109  %0 = sdiv i64 %x, 10
110  %1 = srem i64 %x, 10
111  %res = add i64 %0, %1
112  ret i64 %res
113}
114
115define i64 @test_minsize_us64(i64 %x) minsize optsize {
116entry:
117  %0 = udiv i64 %x, 10
118  %1 = srem i64 %x, 10
119  %res = add i64 %0, %1
120  ret i64 %res
121}
122
123define i64 @test_minsize_su64(i64 %x) minsize optsize {
124entry:
125  %0 = sdiv i64 %x, 10
126  %1 = urem i64 %x, 10
127  %res = add i64 %0, %1
128  ret i64 %res
129}
130
131define i8 @test_uu8(i8 %x) optsize {
132entry:
133  %0 = udiv i8 %x, 10
134  %1 = urem i8 %x, 10
135  %res = add i8 %0, %1
136  ret i8 %res
137}
138
139define i8 @test_ss8(i8 %x) optsize {
140entry:
141  %0 = sdiv i8 %x, 10
142  %1 = srem i8 %x, 10
143  %res = add i8 %0, %1
144  ret i8 %res
145}
146
147define i8 @test_us8(i8 %x) optsize {
148entry:
149  %0 = udiv i8 %x, 10
150  %1 = srem i8 %x, 10
151  %res = add i8 %0, %1
152  ret i8 %res
153}
154
155define i8 @test_su8(i8 %x) optsize {
156entry:
157  %0 = sdiv i8 %x, 10
158  %1 = urem i8 %x, 10
159  %res = add i8 %0, %1
160  ret i8 %res
161}
162
163define i16 @test_uu16(i16 %x) optsize {
164entry:
165  %0 = udiv i16 %x, 10
166  %1 = urem i16 %x, 10
167  %res = add i16 %0, %1
168  ret i16 %res
169}
170
171define i16 @test_ss16(i16 %x) optsize {
172entry:
173  %0 = sdiv i16 %x, 10
174  %1 = srem i16 %x, 10
175  %res = add i16 %0, %1
176  ret i16 %res
177}
178
179define i16 @test_us16(i16 %x) optsize {
180entry:
181  %0 = udiv i16 %x, 10
182  %1 = srem i16 %x, 10
183  %res = add i16 %0, %1
184  ret i16 %res
185}
186
187define i16 @test_su16(i16 %x) optsize {
188entry:
189  %0 = sdiv i16 %x, 10
190  %1 = urem i16 %x, 10
191  %res = add i16 %0, %1
192  ret i16 %res
193}
194
195define i32 @test_uu32(i32 %x) optsize {
196entry:
197  %0 = udiv i32 %x, 10
198  %1 = urem i32 %x, 10
199  %res = add i32 %0, %1
200  ret i32 %res
201}
202
203define i32 @test_ss32(i32 %x) optsize {
204entry:
205  %0 = sdiv i32 %x, 10
206  %1 = srem i32 %x, 10
207  %res = add i32 %0, %1
208  ret i32 %res
209}
210
211define i32 @test_us32(i32 %x) optsize {
212entry:
213  %0 = udiv i32 %x, 10
214  %1 = srem i32 %x, 10
215  %res = add i32 %0, %1
216  ret i32 %res
217}
218
219define i32 @test_su32(i32 %x) optsize {
220entry:
221  %0 = sdiv i32 %x, 10
222  %1 = urem i32 %x, 10
223  %res = add i32 %0, %1
224  ret i32 %res
225}
226
227define i64 @test_uu64(i64 %x) optsize {
228entry:
229  %0 = udiv i64 %x, 10
230  %1 = urem i64 %x, 10
231  %res = add i64 %0, %1
232  ret i64 %res
233}
234
235define i64 @test_ss64(i64 %x) optsize {
236entry:
237  %0 = sdiv i64 %x, 10
238  %1 = srem i64 %x, 10
239  %res = add i64 %0, %1
240  ret i64 %res
241}
242
243define i64 @test_us64(i64 %x) optsize {
244entry:
245  %0 = udiv i64 %x, 10
246  %1 = srem i64 %x, 10
247  %res = add i64 %0, %1
248  ret i64 %res
249}
250
251define i64 @test_su64(i64 %x) optsize {
252entry:
253  %0 = sdiv i64 %x, 10
254  %1 = urem i64 %x, 10
255  %res = add i64 %0, %1
256  ret i64 %res
257}
258