Skip to content

Commit b882c97

Browse files
committedAug 25, 2019
[Hexagon][x86] add tests for bit-test; NFC
More coverage for D66687 (assuming we make this a generic combine with TLI hook). llvm-svn: 369874
1 parent c955e4a commit b882c97

File tree

2 files changed

+114
-1
lines changed

2 files changed

+114
-1
lines changed
 

‎llvm/test/CodeGen/Hexagon/tstbit.ll

+98-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2-
; RUN: llc -march=hexagon < %s | FileCheck %s
2+
; RUN: llc -mtriple=hexagon < %s | FileCheck %s
33

44
; Function Attrs: nounwind readnone
55
define i32 @f0(i32 %a0, i32 %a1) #0 {
@@ -20,4 +20,101 @@ b0:
2020
ret i32 %v3
2121
}
2222

23+
define i64 @is_upper_bit_clear_i64(i64 %x) {
24+
; CHECK-LABEL: is_upper_bit_clear_i64:
25+
; CHECK: .cfi_startproc
26+
; CHECK-NEXT: // %bb.0:
27+
; CHECK-NEXT: {
28+
; CHECK-NEXT: r1:0 = extractu(r1:0,#1,#37)
29+
; CHECK-NEXT: }
30+
; CHECK-NEXT: {
31+
; CHECK-NEXT: r0 = togglebit(r0,#0)
32+
; CHECK-NEXT: r1 = #0
33+
; CHECK-NEXT: jumpr r31
34+
; CHECK-NEXT: }
35+
%sh = lshr i64 %x, 37
36+
%m = and i64 %sh, 1
37+
%r = xor i64 %m, 1
38+
ret i64 %r
39+
}
40+
41+
define i64 @is_lower_bit_clear_i64(i64 %x) {
42+
; CHECK-LABEL: is_lower_bit_clear_i64:
43+
; CHECK: .cfi_startproc
44+
; CHECK-NEXT: // %bb.0:
45+
; CHECK-NEXT: {
46+
; CHECK-NEXT: r1:0 = extractu(r1:0,#1,#27)
47+
; CHECK-NEXT: }
48+
; CHECK-NEXT: {
49+
; CHECK-NEXT: r0 = togglebit(r0,#0)
50+
; CHECK-NEXT: r1 = #0
51+
; CHECK-NEXT: jumpr r31
52+
; CHECK-NEXT: }
53+
%sh = lshr i64 %x, 27
54+
%m = and i64 %sh, 1
55+
%r = xor i64 %m, 1
56+
ret i64 %r
57+
}
58+
59+
define i32 @is_bit_clear_i32(i32 %x) {
60+
; CHECK-LABEL: is_bit_clear_i32:
61+
; CHECK: .cfi_startproc
62+
; CHECK-NEXT: // %bb.0:
63+
; CHECK-NEXT: {
64+
; CHECK-NEXT: r1 = #-1
65+
; CHECK-NEXT: }
66+
; CHECK-NEXT: {
67+
; CHECK-NEXT: r1 ^= lsr(r0,#27)
68+
; CHECK-NEXT: }
69+
; CHECK-NEXT: {
70+
; CHECK-NEXT: r0 = and(r1,#1)
71+
; CHECK-NEXT: jumpr r31
72+
; CHECK-NEXT: }
73+
%sh = lshr i32 %x, 27
74+
%n = xor i32 %sh, -1
75+
%r = and i32 %n, 1
76+
ret i32 %r
77+
}
78+
79+
define i16 @is_bit_clear_i16(i16 %x) {
80+
; CHECK-LABEL: is_bit_clear_i16:
81+
; CHECK: .cfi_startproc
82+
; CHECK-NEXT: // %bb.0:
83+
; CHECK-NEXT: {
84+
; CHECK-NEXT: r1 = #-1
85+
; CHECK-NEXT: }
86+
; CHECK-NEXT: {
87+
; CHECK-NEXT: r1 ^= lsr(r0,#7)
88+
; CHECK-NEXT: }
89+
; CHECK-NEXT: {
90+
; CHECK-NEXT: r0 = and(r1,#1)
91+
; CHECK-NEXT: jumpr r31
92+
; CHECK-NEXT: }
93+
%sh = lshr i16 %x, 7
94+
%m = and i16 %sh, 1
95+
%r = xor i16 %m, 1
96+
ret i16 %r
97+
}
98+
99+
define i8 @is_bit_clear_i8(i8 %x) {
100+
; CHECK-LABEL: is_bit_clear_i8:
101+
; CHECK: .cfi_startproc
102+
; CHECK-NEXT: // %bb.0:
103+
; CHECK-NEXT: {
104+
; CHECK-NEXT: r1 = #-1
105+
; CHECK-NEXT: }
106+
; CHECK-NEXT: {
107+
; CHECK-NEXT: r1 ^= lsr(r0,#3)
108+
; CHECK-NEXT: }
109+
; CHECK-NEXT: {
110+
; CHECK-NEXT: r0 = and(r1,#1)
111+
; CHECK-NEXT: jumpr r31
112+
; CHECK-NEXT: }
113+
%sh = lshr i8 %x, 3
114+
%m = and i8 %sh, 1
115+
%r = xor i8 %m, 1
116+
ret i8 %r
117+
}
118+
119+
23120
attributes #0 = { nounwind readnone }

‎llvm/test/CodeGen/X86/test-vs-bittest.ll

+16
Original file line numberDiff line numberDiff line change
@@ -462,6 +462,22 @@ define i8 @is_bit_clear_i8(i8 %x) {
462462
ret i8 %r
463463
}
464464

465+
define i8 @overshift(i64 %x) {
466+
; CHECK-LABEL: overshift:
467+
; CHECK: # %bb.0:
468+
; CHECK-NEXT: movq %rdi, %rax
469+
; CHECK-NEXT: shrq $42, %rax
470+
; CHECK-NEXT: notb %al
471+
; CHECK-NEXT: andb $1, %al
472+
; CHECK-NEXT: # kill: def $al killed $al killed $rax
473+
; CHECK-NEXT: retq
474+
%a = lshr i64 %x, 42
475+
%t = trunc i64 %a to i8
476+
%n = xor i8 %t, -1
477+
%r = and i8 %n, 1
478+
ret i8 %r
479+
}
480+
465481
define i32 @setcc_is_bit_clear(i32 %x) {
466482
; CHECK-LABEL: setcc_is_bit_clear:
467483
; CHECK: # %bb.0:

0 commit comments

Comments
 (0)
Please sign in to comment.