1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-unknown-unknown | FileCheck %s --check-prefixes=X86
3 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown | FileCheck %s --check-prefixes=X64
5 ; Check that we recognize this idiom for rotation too:
6 ; a << (b & (OpSize-1)) | a >> ((0 - b) & (OpSize-1))
8 define i32 @rotate_left_32(i32 %a, i32 %b) {
9 ; X86-LABEL: rotate_left_32:
11 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
12 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
13 ; X86-NEXT: roll %cl, %eax
16 ; X64-LABEL: rotate_left_32:
18 ; X64-NEXT: movl %esi, %ecx
19 ; X64-NEXT: movl %edi, %eax
20 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
21 ; X64-NEXT: roll %cl, %eax
24 %shl = shl i32 %a, %and
26 %and3 = and i32 %t0, 31
27 %shr = lshr i32 %a, %and3
28 %or = or i32 %shl, %shr
32 define i32 @rotate_right_32(i32 %a, i32 %b) {
33 ; X86-LABEL: rotate_right_32:
35 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
36 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
37 ; X86-NEXT: rorl %cl, %eax
40 ; X64-LABEL: rotate_right_32:
42 ; X64-NEXT: movl %esi, %ecx
43 ; X64-NEXT: movl %edi, %eax
44 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
45 ; X64-NEXT: rorl %cl, %eax
48 %shl = lshr i32 %a, %and
50 %and3 = and i32 %t0, 31
51 %shr = shl i32 %a, %and3
52 %or = or i32 %shl, %shr
56 define i64 @rotate_left_64(i64 %a, i64 %b) {
57 ; X86-LABEL: rotate_left_64:
59 ; X86-NEXT: pushl %ebx
60 ; X86-NEXT: .cfi_def_cfa_offset 8
61 ; X86-NEXT: pushl %edi
62 ; X86-NEXT: .cfi_def_cfa_offset 12
63 ; X86-NEXT: pushl %esi
64 ; X86-NEXT: .cfi_def_cfa_offset 16
65 ; X86-NEXT: .cfi_offset %esi, -16
66 ; X86-NEXT: .cfi_offset %edi, -12
67 ; X86-NEXT: .cfi_offset %ebx, -8
68 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
69 ; X86-NEXT: movl {{[0-9]+}}(%esp), %esi
70 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edi
71 ; X86-NEXT: movl %esi, %eax
72 ; X86-NEXT: shll %cl, %eax
73 ; X86-NEXT: movl %edi, %edx
74 ; X86-NEXT: shldl %cl, %esi, %edx
75 ; X86-NEXT: testb $32, %cl
76 ; X86-NEXT: je .LBB2_2
78 ; X86-NEXT: movl %eax, %edx
79 ; X86-NEXT: xorl %eax, %eax
82 ; X86-NEXT: movl %edi, %ebx
83 ; X86-NEXT: shrl %cl, %ebx
84 ; X86-NEXT: shrdl %cl, %edi, %esi
85 ; X86-NEXT: testb $32, %cl
86 ; X86-NEXT: je .LBB2_4
88 ; X86-NEXT: movl %ebx, %esi
89 ; X86-NEXT: xorl %ebx, %ebx
91 ; X86-NEXT: orl %ebx, %edx
92 ; X86-NEXT: orl %esi, %eax
94 ; X86-NEXT: .cfi_def_cfa_offset 12
96 ; X86-NEXT: .cfi_def_cfa_offset 8
98 ; X86-NEXT: .cfi_def_cfa_offset 4
101 ; X64-LABEL: rotate_left_64:
103 ; X64-NEXT: movq %rsi, %rcx
104 ; X64-NEXT: movq %rdi, %rax
105 ; X64-NEXT: # kill: def $cl killed $cl killed $rcx
106 ; X64-NEXT: rolq %cl, %rax
108 %and = and i64 %b, 63
109 %shl = shl i64 %a, %and
111 %and3 = and i64 %t0, 63
112 %shr = lshr i64 %a, %and3
113 %or = or i64 %shl, %shr
117 define i64 @rotate_right_64(i64 %a, i64 %b) {
118 ; X86-LABEL: rotate_right_64:
120 ; X86-NEXT: pushl %ebx
121 ; X86-NEXT: .cfi_def_cfa_offset 8
122 ; X86-NEXT: pushl %edi
123 ; X86-NEXT: .cfi_def_cfa_offset 12
124 ; X86-NEXT: pushl %esi
125 ; X86-NEXT: .cfi_def_cfa_offset 16
126 ; X86-NEXT: .cfi_offset %esi, -16
127 ; X86-NEXT: .cfi_offset %edi, -12
128 ; X86-NEXT: .cfi_offset %ebx, -8
129 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
130 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edi
131 ; X86-NEXT: movl {{[0-9]+}}(%esp), %esi
132 ; X86-NEXT: movl %esi, %edx
133 ; X86-NEXT: shrl %cl, %edx
134 ; X86-NEXT: movl %edi, %eax
135 ; X86-NEXT: shrdl %cl, %esi, %eax
136 ; X86-NEXT: testb $32, %cl
137 ; X86-NEXT: je .LBB3_2
139 ; X86-NEXT: movl %edx, %eax
140 ; X86-NEXT: xorl %edx, %edx
143 ; X86-NEXT: movl %edi, %ebx
144 ; X86-NEXT: shll %cl, %ebx
145 ; X86-NEXT: shldl %cl, %edi, %esi
146 ; X86-NEXT: testb $32, %cl
147 ; X86-NEXT: je .LBB3_4
149 ; X86-NEXT: movl %ebx, %esi
150 ; X86-NEXT: xorl %ebx, %ebx
152 ; X86-NEXT: orl %esi, %edx
153 ; X86-NEXT: orl %ebx, %eax
154 ; X86-NEXT: popl %esi
155 ; X86-NEXT: .cfi_def_cfa_offset 12
156 ; X86-NEXT: popl %edi
157 ; X86-NEXT: .cfi_def_cfa_offset 8
158 ; X86-NEXT: popl %ebx
159 ; X86-NEXT: .cfi_def_cfa_offset 4
162 ; X64-LABEL: rotate_right_64:
164 ; X64-NEXT: movq %rsi, %rcx
165 ; X64-NEXT: movq %rdi, %rax
166 ; X64-NEXT: # kill: def $cl killed $cl killed $rcx
167 ; X64-NEXT: rorq %cl, %rax
169 %and = and i64 %b, 63
170 %shl = lshr i64 %a, %and
172 %and3 = and i64 %t0, 63
173 %shr = shl i64 %a, %and3
174 %or = or i64 %shl, %shr
178 ; Also check mem operand.
180 define void @rotate_left_m32(i32 *%pa, i32 %b) {
181 ; X86-LABEL: rotate_left_m32:
183 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
184 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
185 ; X86-NEXT: roll %cl, (%eax)
188 ; X64-LABEL: rotate_left_m32:
190 ; X64-NEXT: movl %esi, %ecx
191 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
192 ; X64-NEXT: roll %cl, (%rdi)
194 %a = load i32, i32* %pa, align 16
195 %and = and i32 %b, 31
196 %shl = shl i32 %a, %and
198 %and3 = and i32 %t0, 31
199 %shr = lshr i32 %a, %and3
200 %or = or i32 %shl, %shr
201 store i32 %or, i32* %pa, align 32
205 define void @rotate_right_m32(i32 *%pa, i32 %b) {
206 ; X86-LABEL: rotate_right_m32:
208 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
209 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
210 ; X86-NEXT: rorl %cl, (%eax)
213 ; X64-LABEL: rotate_right_m32:
215 ; X64-NEXT: movl %esi, %ecx
216 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
217 ; X64-NEXT: rorl %cl, (%rdi)
219 %a = load i32, i32* %pa, align 16
220 %and = and i32 %b, 31
221 %shl = lshr i32 %a, %and
223 %and3 = and i32 %t0, 31
224 %shr = shl i32 %a, %and3
225 %or = or i32 %shl, %shr
226 store i32 %or, i32* %pa, align 32
230 define void @rotate_left_m64(i64 *%pa, i64 %b) {
231 ; X86-LABEL: rotate_left_m64:
233 ; X86-NEXT: pushl %ebp
234 ; X86-NEXT: .cfi_def_cfa_offset 8
235 ; X86-NEXT: pushl %ebx
236 ; X86-NEXT: .cfi_def_cfa_offset 12
237 ; X86-NEXT: pushl %edi
238 ; X86-NEXT: .cfi_def_cfa_offset 16
239 ; X86-NEXT: pushl %esi
240 ; X86-NEXT: .cfi_def_cfa_offset 20
241 ; X86-NEXT: .cfi_offset %esi, -20
242 ; X86-NEXT: .cfi_offset %edi, -16
243 ; X86-NEXT: .cfi_offset %ebx, -12
244 ; X86-NEXT: .cfi_offset %ebp, -8
245 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
246 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
247 ; X86-NEXT: movl (%eax), %edx
248 ; X86-NEXT: movl 4(%eax), %ebx
249 ; X86-NEXT: movl %edx, %esi
250 ; X86-NEXT: shll %cl, %esi
251 ; X86-NEXT: movl %ebx, %edi
252 ; X86-NEXT: shldl %cl, %edx, %edi
253 ; X86-NEXT: testb $32, %cl
254 ; X86-NEXT: je .LBB6_2
256 ; X86-NEXT: movl %esi, %edi
257 ; X86-NEXT: xorl %esi, %esi
260 ; X86-NEXT: movl %ebx, %ebp
261 ; X86-NEXT: shrl %cl, %ebp
262 ; X86-NEXT: shrdl %cl, %ebx, %edx
263 ; X86-NEXT: testb $32, %cl
264 ; X86-NEXT: je .LBB6_4
266 ; X86-NEXT: movl %ebp, %edx
267 ; X86-NEXT: xorl %ebp, %ebp
269 ; X86-NEXT: orl %ebp, %edi
270 ; X86-NEXT: orl %edx, %esi
271 ; X86-NEXT: movl %edi, 4(%eax)
272 ; X86-NEXT: movl %esi, (%eax)
273 ; X86-NEXT: popl %esi
274 ; X86-NEXT: .cfi_def_cfa_offset 16
275 ; X86-NEXT: popl %edi
276 ; X86-NEXT: .cfi_def_cfa_offset 12
277 ; X86-NEXT: popl %ebx
278 ; X86-NEXT: .cfi_def_cfa_offset 8
279 ; X86-NEXT: popl %ebp
280 ; X86-NEXT: .cfi_def_cfa_offset 4
283 ; X64-LABEL: rotate_left_m64:
285 ; X64-NEXT: movq %rsi, %rcx
286 ; X64-NEXT: # kill: def $cl killed $cl killed $rcx
287 ; X64-NEXT: rolq %cl, (%rdi)
289 %a = load i64, i64* %pa, align 16
290 %and = and i64 %b, 63
291 %shl = shl i64 %a, %and
293 %and3 = and i64 %t0, 63
294 %shr = lshr i64 %a, %and3
295 %or = or i64 %shl, %shr
296 store i64 %or, i64* %pa, align 64
300 define void @rotate_right_m64(i64 *%pa, i64 %b) {
301 ; X86-LABEL: rotate_right_m64:
303 ; X86-NEXT: pushl %ebp
304 ; X86-NEXT: .cfi_def_cfa_offset 8
305 ; X86-NEXT: pushl %ebx
306 ; X86-NEXT: .cfi_def_cfa_offset 12
307 ; X86-NEXT: pushl %edi
308 ; X86-NEXT: .cfi_def_cfa_offset 16
309 ; X86-NEXT: pushl %esi
310 ; X86-NEXT: .cfi_def_cfa_offset 20
311 ; X86-NEXT: .cfi_offset %esi, -20
312 ; X86-NEXT: .cfi_offset %edi, -16
313 ; X86-NEXT: .cfi_offset %ebx, -12
314 ; X86-NEXT: .cfi_offset %ebp, -8
315 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
316 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
317 ; X86-NEXT: movl (%eax), %ebx
318 ; X86-NEXT: movl 4(%eax), %esi
319 ; X86-NEXT: movl %esi, %edx
320 ; X86-NEXT: shrl %cl, %edx
321 ; X86-NEXT: movl %ebx, %edi
322 ; X86-NEXT: shrdl %cl, %esi, %edi
323 ; X86-NEXT: testb $32, %cl
324 ; X86-NEXT: je .LBB7_2
326 ; X86-NEXT: movl %edx, %edi
327 ; X86-NEXT: xorl %edx, %edx
330 ; X86-NEXT: movl %ebx, %ebp
331 ; X86-NEXT: shll %cl, %ebp
332 ; X86-NEXT: shldl %cl, %ebx, %esi
333 ; X86-NEXT: testb $32, %cl
334 ; X86-NEXT: je .LBB7_4
336 ; X86-NEXT: movl %ebp, %esi
337 ; X86-NEXT: xorl %ebp, %ebp
339 ; X86-NEXT: orl %esi, %edx
340 ; X86-NEXT: orl %ebp, %edi
341 ; X86-NEXT: movl %edx, 4(%eax)
342 ; X86-NEXT: movl %edi, (%eax)
343 ; X86-NEXT: popl %esi
344 ; X86-NEXT: .cfi_def_cfa_offset 16
345 ; X86-NEXT: popl %edi
346 ; X86-NEXT: .cfi_def_cfa_offset 12
347 ; X86-NEXT: popl %ebx
348 ; X86-NEXT: .cfi_def_cfa_offset 8
349 ; X86-NEXT: popl %ebp
350 ; X86-NEXT: .cfi_def_cfa_offset 4
353 ; X64-LABEL: rotate_right_m64:
355 ; X64-NEXT: movq %rsi, %rcx
356 ; X64-NEXT: # kill: def $cl killed $cl killed $rcx
357 ; X64-NEXT: rorq %cl, (%rdi)
359 %a = load i64, i64* %pa, align 16
360 %and = and i64 %b, 63
361 %shl = lshr i64 %a, %and
363 %and3 = and i64 %t0, 63
364 %shr = shl i64 %a, %and3
365 %or = or i64 %shl, %shr
366 store i64 %or, i64* %pa, align 64
370 ; The next 8 tests include masks of the narrow width shift amounts that should be eliminated.
371 ; These patterns are produced by instcombine after r310509.
373 define i8 @rotate_left_8(i8 %x, i32 %amount) {
374 ; X86-LABEL: rotate_left_8:
376 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
377 ; X86-NEXT: movb {{[0-9]+}}(%esp), %al
378 ; X86-NEXT: rolb %cl, %al
381 ; X64-LABEL: rotate_left_8:
383 ; X64-NEXT: movl %esi, %ecx
384 ; X64-NEXT: movl %edi, %eax
385 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
386 ; X64-NEXT: rolb %cl, %al
387 ; X64-NEXT: # kill: def $al killed $al killed $eax
389 %amt = trunc i32 %amount to i8
390 %sub = sub i8 0, %amt
391 %maskamt = and i8 %amt, 7
392 %masksub = and i8 %sub, 7
393 %shl = shl i8 %x, %maskamt
394 %shr = lshr i8 %x, %masksub
395 %or = or i8 %shl, %shr
399 define i8 @rotate_right_8(i8 %x, i32 %amount) {
400 ; X86-LABEL: rotate_right_8:
402 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
403 ; X86-NEXT: movb {{[0-9]+}}(%esp), %al
404 ; X86-NEXT: rorb %cl, %al
407 ; X64-LABEL: rotate_right_8:
409 ; X64-NEXT: movl %esi, %ecx
410 ; X64-NEXT: movl %edi, %eax
411 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
412 ; X64-NEXT: rorb %cl, %al
413 ; X64-NEXT: # kill: def $al killed $al killed $eax
415 %amt = trunc i32 %amount to i8
416 %sub = sub i8 0, %amt
417 %maskamt = and i8 %amt, 7
418 %masksub = and i8 %sub, 7
419 %shr = lshr i8 %x, %maskamt
420 %shl = shl i8 %x, %masksub
421 %or = or i8 %shr, %shl
425 define i16 @rotate_left_16(i16 %x, i32 %amount) {
426 ; X86-LABEL: rotate_left_16:
428 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
429 ; X86-NEXT: movzwl {{[0-9]+}}(%esp), %eax
430 ; X86-NEXT: rolw %cl, %ax
433 ; X64-LABEL: rotate_left_16:
435 ; X64-NEXT: movl %esi, %ecx
436 ; X64-NEXT: movl %edi, %eax
437 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
438 ; X64-NEXT: rolw %cl, %ax
439 ; X64-NEXT: # kill: def $ax killed $ax killed $eax
441 %amt = trunc i32 %amount to i16
442 %sub = sub i16 0, %amt
443 %maskamt = and i16 %amt, 15
444 %masksub = and i16 %sub, 15
445 %shl = shl i16 %x, %maskamt
446 %shr = lshr i16 %x, %masksub
447 %or = or i16 %shl, %shr
451 define i16 @rotate_right_16(i16 %x, i32 %amount) {
452 ; X86-LABEL: rotate_right_16:
454 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
455 ; X86-NEXT: movzwl {{[0-9]+}}(%esp), %eax
456 ; X86-NEXT: rorw %cl, %ax
459 ; X64-LABEL: rotate_right_16:
461 ; X64-NEXT: movl %esi, %ecx
462 ; X64-NEXT: movl %edi, %eax
463 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
464 ; X64-NEXT: rorw %cl, %ax
465 ; X64-NEXT: # kill: def $ax killed $ax killed $eax
467 %amt = trunc i32 %amount to i16
468 %sub = sub i16 0, %amt
469 %maskamt = and i16 %amt, 15
470 %masksub = and i16 %sub, 15
471 %shr = lshr i16 %x, %maskamt
472 %shl = shl i16 %x, %masksub
473 %or = or i16 %shr, %shl
477 define void @rotate_left_m8(i8* %p, i32 %amount) {
478 ; X86-LABEL: rotate_left_m8:
480 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
481 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
482 ; X86-NEXT: rolb %cl, (%eax)
485 ; X64-LABEL: rotate_left_m8:
487 ; X64-NEXT: movl %esi, %ecx
488 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
489 ; X64-NEXT: rolb %cl, (%rdi)
491 %x = load i8, i8* %p, align 1
492 %amt = trunc i32 %amount to i8
493 %sub = sub i8 0, %amt
494 %maskamt = and i8 %amt, 7
495 %masksub = and i8 %sub, 7
496 %shl = shl i8 %x, %maskamt
497 %shr = lshr i8 %x, %masksub
498 %or = or i8 %shl, %shr
499 store i8 %or, i8* %p, align 1
503 define void @rotate_right_m8(i8* %p, i32 %amount) {
504 ; X86-LABEL: rotate_right_m8:
506 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
507 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
508 ; X86-NEXT: rorb %cl, (%eax)
511 ; X64-LABEL: rotate_right_m8:
513 ; X64-NEXT: movl %esi, %ecx
514 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
515 ; X64-NEXT: rorb %cl, (%rdi)
517 %x = load i8, i8* %p, align 1
518 %amt = trunc i32 %amount to i8
519 %sub = sub i8 0, %amt
520 %maskamt = and i8 %amt, 7
521 %masksub = and i8 %sub, 7
522 %shl = shl i8 %x, %masksub
523 %shr = lshr i8 %x, %maskamt
524 %or = or i8 %shl, %shr
525 store i8 %or, i8* %p, align 1
529 define void @rotate_left_m16(i16* %p, i32 %amount) {
530 ; X86-LABEL: rotate_left_m16:
532 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
533 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
534 ; X86-NEXT: rolw %cl, (%eax)
537 ; X64-LABEL: rotate_left_m16:
539 ; X64-NEXT: movl %esi, %ecx
540 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
541 ; X64-NEXT: rolw %cl, (%rdi)
543 %x = load i16, i16* %p, align 1
544 %amt = trunc i32 %amount to i16
545 %sub = sub i16 0, %amt
546 %maskamt = and i16 %amt, 15
547 %masksub = and i16 %sub, 15
548 %shl = shl i16 %x, %maskamt
549 %shr = lshr i16 %x, %masksub
550 %or = or i16 %shl, %shr
551 store i16 %or, i16* %p, align 1
555 define void @rotate_right_m16(i16* %p, i32 %amount) {
556 ; X86-LABEL: rotate_right_m16:
558 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
559 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
560 ; X86-NEXT: rorw %cl, (%eax)
563 ; X64-LABEL: rotate_right_m16:
565 ; X64-NEXT: movl %esi, %ecx
566 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
567 ; X64-NEXT: rorw %cl, (%rdi)
569 %x = load i16, i16* %p, align 1
570 %amt = trunc i32 %amount to i16
571 %sub = sub i16 0, %amt
572 %maskamt = and i16 %amt, 15
573 %masksub = and i16 %sub, 15
574 %shl = shl i16 %x, %masksub
575 %shr = lshr i16 %x, %maskamt
576 %or = or i16 %shl, %shr
577 store i16 %or, i16* %p, align 1
581 define i32 @rotate_demanded_bits(i32, i32) {
582 ; X86-LABEL: rotate_demanded_bits:
584 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
585 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
586 ; X86-NEXT: andb $30, %cl
587 ; X86-NEXT: roll %cl, %eax
590 ; X64-LABEL: rotate_demanded_bits:
592 ; X64-NEXT: movl %esi, %ecx
593 ; X64-NEXT: movl %edi, %eax
594 ; X64-NEXT: andb $30, %cl
595 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
596 ; X64-NEXT: roll %cl, %eax
600 %5 = sub nsw i32 0, %3
607 define i32 @rotate_demanded_bits_2(i32, i32) {
608 ; X86-LABEL: rotate_demanded_bits_2:
610 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
611 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
612 ; X86-NEXT: andb $23, %cl
613 ; X86-NEXT: roll %cl, %eax
616 ; X64-LABEL: rotate_demanded_bits_2:
618 ; X64-NEXT: movl %esi, %ecx
619 ; X64-NEXT: movl %edi, %eax
620 ; X64-NEXT: andb $23, %cl
621 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
622 ; X64-NEXT: roll %cl, %eax
626 %5 = sub nsw i32 0, %3
633 define i32 @rotate_demanded_bits_3(i32, i32) {
634 ; X86-LABEL: rotate_demanded_bits_3:
636 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
637 ; X86-NEXT: movb {{[0-9]+}}(%esp), %cl
638 ; X86-NEXT: addb %cl, %cl
639 ; X86-NEXT: andb $30, %cl
640 ; X86-NEXT: roll %cl, %eax
643 ; X64-LABEL: rotate_demanded_bits_3:
645 ; X64-NEXT: # kill: def $esi killed $esi def $rsi
646 ; X64-NEXT: movl %edi, %eax
647 ; X64-NEXT: leal (%rsi,%rsi), %ecx
648 ; X64-NEXT: andb $30, %cl
649 ; X64-NEXT: # kill: def $cl killed $cl killed $ecx
650 ; X64-NEXT: roll %cl, %eax