1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-apple-darwin | FileCheck %s --check-prefixes=X86
3 ; RUN: llc < %s -mtriple=x86_64-apple-darwin | FileCheck %s --check-prefixes=X64,X64-NOTBM,X64-NOBMI2
4 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=+tbm | FileCheck %s --check-prefixes=X64,X64-NOBMI2,X64-TBM
5 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mattr=+bmi2 | FileCheck %s --check-prefixes=X64,X64-NOTBM,X64-BMI2
8 define zeroext i16 @t1(i16 zeroext %x) nounwind readnone ssp {
11 ; X86-NEXT: xorl %eax, %eax
12 ; X86-NEXT: cmpw $27, {{[0-9]+}}(%esp)
14 ; X86-NEXT: shll $5, %eax
19 ; X64-NEXT: xorl %eax, %eax
20 ; X64-NEXT: cmpw $27, %di
22 ; X64-NEXT: shll $5, %eax
24 %t0 = icmp ugt i16 %x, 26
25 %if = select i1 %t0, i16 32, i16 0
29 define zeroext i16 @t2(i16 zeroext %x) nounwind readnone ssp {
32 ; X86-NEXT: xorl %eax, %eax
33 ; X86-NEXT: cmpw $26, {{[0-9]+}}(%esp)
35 ; X86-NEXT: shll $5, %eax
40 ; X64-NEXT: xorl %eax, %eax
41 ; X64-NEXT: cmpw $26, %di
43 ; X64-NEXT: shll $5, %eax
45 %t0 = icmp ult i16 %x, 26
46 %if = select i1 %t0, i16 32, i16 0
50 define i64 @t3(i64 %x) nounwind readnone ssp {
53 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
54 ; X86-NEXT: cmpl $18, {{[0-9]+}}(%esp)
55 ; X86-NEXT: sbbl $0, %eax
57 ; X86-NEXT: movzbl %al, %eax
58 ; X86-NEXT: shll $6, %eax
59 ; X86-NEXT: xorl %edx, %edx
64 ; X64-NEXT: xorl %eax, %eax
65 ; X64-NEXT: cmpq $18, %rdi
67 ; X64-NEXT: shlq $6, %rax
69 %t0 = icmp ult i64 %x, 18
70 %if = select i1 %t0, i64 64, i64 0
74 @v4 = common global i32 0, align 4
76 define i32 @t4(i32 %a) {
79 ; X86-NEXT: movl L_v4$non_lazy_ptr, %ecx
80 ; X86-NEXT: xorl %eax, %eax
81 ; X86-NEXT: cmpl $1, (%ecx)
82 ; X86-NEXT: adcw $1, %ax
83 ; X86-NEXT: shll $16, %eax
88 ; X64-NEXT: movq _v4@GOTPCREL(%rip), %rcx
89 ; X64-NEXT: xorl %eax, %eax
90 ; X64-NEXT: cmpl $1, (%rcx)
91 ; X64-NEXT: adcw $1, %ax
92 ; X64-NEXT: shll $16, %eax
94 %t0 = load i32, ptr @v4, align 4
95 %not.tobool = icmp eq i32 %t0, 0
96 %conv.i = sext i1 %not.tobool to i16
97 %call.lobit = lshr i16 %conv.i, 15
98 %add.i.1 = add nuw nsw i16 %call.lobit, 1
99 %conv4.2 = zext i16 %add.i.1 to i32
100 %add = shl nuw nsw i32 %conv4.2, 16
104 define i8 @t5(i32 %a) {
107 ; X86-NEXT: cmpl $0, {{[0-9]+}}(%esp)
108 ; X86-NEXT: setns %al
113 ; X64-NEXT: testl %edi, %edi
114 ; X64-NEXT: setns %al
116 %.lobit = lshr i32 %a, 31
117 %trunc = trunc i32 %.lobit to i8
118 %.not = xor i8 %trunc, 1
122 define zeroext i1 @t6(i32 %a) {
125 ; X86-NEXT: cmpl $0, {{[0-9]+}}(%esp)
126 ; X86-NEXT: setns %al
131 ; X64-NEXT: testl %edi, %edi
132 ; X64-NEXT: setns %al
134 %.lobit = lshr i32 %a, 31
135 %trunc = trunc i32 %.lobit to i1
136 %.not = xor i1 %trunc, 1
141 define zeroext i1 @t7(i32 %0) {
144 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
145 ; X86-NEXT: movl $19, %ecx
146 ; X86-NEXT: btl %eax, %ecx
152 ; X64-NEXT: movl $19, %eax
153 ; X64-NEXT: btl %edi, %eax
156 %2 = trunc i32 %0 to i5
159 %5 = icmp ne i5 %4, 0
163 define zeroext i1 @t8(i8 %0, i8 %1) {
166 ; X86-NEXT: movl {{[0-9]+}}(%esp), %eax
167 ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
168 ; X86-NEXT: btl %eax, %ecx
174 ; X64-NEXT: btl %esi, %edi
179 %5 = icmp ne i8 %4, 0
183 define i64 @t9(i32 %0, i32 %1) {
186 ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
187 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
188 ; X86-NEXT: xorl %eax, %eax
189 ; X86-NEXT: btl %edx, %ecx
191 ; X86-NEXT: xorl %edx, %edx
194 ; X64-NOBMI2-LABEL: t9:
195 ; X64-NOBMI2: ## %bb.0:
196 ; X64-NOBMI2-NEXT: xorl %eax, %eax
197 ; X64-NOBMI2-NEXT: btl %esi, %edi
198 ; X64-NOBMI2-NEXT: setb %al
199 ; X64-NOBMI2-NEXT: retq
201 ; X64-BMI2-LABEL: t9:
202 ; X64-BMI2: ## %bb.0:
203 ; X64-BMI2-NEXT: shrxl %esi, %edi, %eax
204 ; X64-BMI2-NEXT: andl $1, %eax
205 ; X64-BMI2-NEXT: retq
208 %5 = icmp ne i32 %4, 0
209 %6 = zext i1 %5 to i64
213 define i32 @t10(i32 %0, i32 %1) {
216 ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
217 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
218 ; X86-NEXT: xorl %eax, %eax
219 ; X86-NEXT: btl %edx, %ecx
220 ; X86-NEXT: setae %al
225 ; X64-NEXT: xorl %eax, %eax
226 ; X64-NEXT: btl %esi, %edi
227 ; X64-NEXT: setae %al
235 define i32 @t11(i32 %0, i32 %1) {
238 ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
239 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
240 ; X86-NEXT: xorl %eax, %eax
241 ; X86-NEXT: btl %edx, %ecx
242 ; X86-NEXT: setae %al
247 ; X64-NEXT: xorl %eax, %eax
248 ; X64-NEXT: btl %esi, %edi
249 ; X64-NEXT: setae %al
257 define i32 @t12(i32 %0, i32 %1) {
260 ; X86-NEXT: movl {{[0-9]+}}(%esp), %ecx
261 ; X86-NEXT: movl {{[0-9]+}}(%esp), %edx
262 ; X86-NEXT: xorl %eax, %eax
263 ; X86-NEXT: btl %edx, %ecx
269 ; X64-NEXT: xorl %eax, %eax
270 ; X64-NEXT: btl %esi, %edi
280 define i16 @shift_and(i16 %a) {
281 ; X86-LABEL: shift_and:
283 ; X86-NEXT: movzbl {{[0-9]+}}(%esp), %eax
284 ; X86-NEXT: andb $4, %al
285 ; X86-NEXT: shrb $2, %al
286 ; X86-NEXT: movzbl %al, %eax
287 ; X86-NEXT: ## kill: def $ax killed $ax killed $eax
290 ; X64-NOTBM-LABEL: shift_and:
291 ; X64-NOTBM: ## %bb.0:
292 ; X64-NOTBM-NEXT: movl %edi, %eax
293 ; X64-NOTBM-NEXT: shrl $10, %eax
294 ; X64-NOTBM-NEXT: andl $1, %eax
295 ; X64-NOTBM-NEXT: ## kill: def $ax killed $ax killed $eax
296 ; X64-NOTBM-NEXT: retq
298 ; X64-TBM-LABEL: shift_and:
300 ; X64-TBM-NEXT: bextrl $266, %edi, %eax ## imm = 0x10A
301 ; X64-TBM-NEXT: ## kill: def $ax killed $ax killed $eax
303 %and = and i16 %a, 1024
304 %cmp = icmp ne i16 %and, 0
305 %conv = zext i1 %cmp to i16
309 define i32 @PR55138(i32 %x) {
310 ; X86-LABEL: PR55138:
312 ; X86-NEXT: movzbl {{[0-9]+}}(%esp), %ecx
313 ; X86-NEXT: andl $15, %ecx
314 ; X86-NEXT: movl $27030, %edx ## imm = 0x6996
315 ; X86-NEXT: xorl %eax, %eax
316 ; X86-NEXT: btl %ecx, %edx
320 ; X64-NOBMI2-LABEL: PR55138:
321 ; X64-NOBMI2: ## %bb.0:
322 ; X64-NOBMI2-NEXT: andl $15, %edi
323 ; X64-NOBMI2-NEXT: movl $27030, %ecx ## imm = 0x6996
324 ; X64-NOBMI2-NEXT: xorl %eax, %eax
325 ; X64-NOBMI2-NEXT: btl %edi, %ecx
326 ; X64-NOBMI2-NEXT: setb %al
327 ; X64-NOBMI2-NEXT: retq
329 ; X64-BMI2-LABEL: PR55138:
330 ; X64-BMI2: ## %bb.0:
331 ; X64-BMI2-NEXT: andb $15, %dil
332 ; X64-BMI2-NEXT: movl $27030, %eax ## imm = 0x6996
333 ; X64-BMI2-NEXT: shrxl %edi, %eax, %eax
334 ; X64-BMI2-NEXT: andl $1, %eax
335 ; X64-BMI2-NEXT: retq
336 %urem = and i32 %x, 15
337 %shr = lshr i32 27030, %urem
338 %and = and i32 %shr, 1
342 define i64 @pr63055(double %arg) {
343 ; X86-LABEL: pr63055:
345 ; X86-NEXT: movl $1, %eax
346 ; X86-NEXT: xorl %edx, %edx
349 ; X64-LABEL: pr63055:
351 ; X64-NEXT: movl $1, %eax
353 %fcmp = fcmp une double 0x7FF8000000000000, %arg
354 %ext = zext i1 %fcmp to i64