Skip to content

Commit 46a1908

Browse files
committed
[AArch64] Add some tests for setcc known bits fold. NFC
1 parent b8e9450 commit 46a1908

File tree

1 file changed

+84
-0
lines changed

1 file changed

+84
-0
lines changed
Lines changed: 84 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,84 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 3
2+
; RUN: llc < %s -mtriple=aarch64-none-eabi | FileCheck %s
3+
4+
define i1 @load_bv_v4i8(i1 zeroext %a) {
5+
; CHECK-LABEL: load_bv_v4i8:
6+
; CHECK: // %bb.0:
7+
; CHECK-NEXT: cmp w0, #0
8+
; CHECK-NEXT: cset w0, ne
9+
; CHECK-NEXT: ret
10+
%b = zext i1 %a to i32
11+
%c = icmp eq i32 %b, 1
12+
ret i1 %c
13+
}
14+
15+
define noundef i1 @logger(i32 noundef %logLevel, ptr %ea, ptr %pll) {
16+
; CHECK-LABEL: logger:
17+
; CHECK: // %bb.0: // %entry
18+
; CHECK-NEXT: ldr w8, [x2]
19+
; CHECK-NEXT: cmp w8, w0
20+
; CHECK-NEXT: b.ls .LBB1_2
21+
; CHECK-NEXT: // %bb.1:
22+
; CHECK-NEXT: mov w0, wzr
23+
; CHECK-NEXT: ret
24+
; CHECK-NEXT: .LBB1_2: // %land.rhs
25+
; CHECK-NEXT: ldr x8, [x1]
26+
; CHECK-NEXT: ldrb w8, [x8]
27+
; CHECK-NEXT: cmp w8, #0
28+
; CHECK-NEXT: cset w0, ne
29+
; CHECK-NEXT: ret
30+
entry:
31+
%0 = load i32, ptr %pll, align 4
32+
%cmp.not = icmp ugt i32 %0, %logLevel
33+
br i1 %cmp.not, label %land.end, label %land.rhs
34+
35+
land.rhs: ; preds = %entry
36+
%1 = load ptr, ptr %ea, align 8
37+
%2 = load i8, ptr %1, align 1, !range !14, !noundef !15
38+
%tobool.i = icmp ne i8 %2, 0
39+
br label %land.end
40+
41+
land.end: ; preds = %land.rhs, %entry
42+
%3 = phi i1 [ false, %entry ], [ %tobool.i, %land.rhs ]
43+
ret i1 %3
44+
}
45+
!14 = !{i8 0, i8 2}
46+
!15 = !{}
47+
48+
49+
declare i64 @llvm.ctlz.i64(i64 %in, i1)
50+
define i1 @lshr_ctlz_undef_cmpeq_one_i64(i64 %in) {
51+
; CHECK-LABEL: lshr_ctlz_undef_cmpeq_one_i64:
52+
; CHECK: // %bb.0:
53+
; CHECK-NEXT: clz x8, x0
54+
; CHECK-NEXT: lsr x8, x8, #6
55+
; CHECK-NEXT: cmp x8, #1
56+
; CHECK-NEXT: cset w0, eq
57+
; CHECK-NEXT: ret
58+
%ctlz = call i64 @llvm.ctlz.i64(i64 %in, i1 -1)
59+
%lshr = lshr i64 %ctlz, 6
60+
%icmp = icmp eq i64 %lshr, 1
61+
ret i1 %icmp
62+
}
63+
64+
define i32 @PR17487(i1 %tobool) {
65+
; CHECK-LABEL: PR17487:
66+
; CHECK: // %bb.0:
67+
; CHECK-NEXT: dup v0.2s, w0
68+
; CHECK-NEXT: mov w8, #1 // =0x1
69+
; CHECK-NEXT: dup v1.2d, x8
70+
; CHECK-NEXT: ushll v0.2d, v0.2s, #0
71+
; CHECK-NEXT: bic v0.16b, v1.16b, v0.16b
72+
; CHECK-NEXT: mov x8, v0.d[1]
73+
; CHECK-NEXT: cmp x8, #1
74+
; CHECK-NEXT: cset w0, ne
75+
; CHECK-NEXT: ret
76+
%tmp = insertelement <2 x i1> undef, i1 %tobool, i32 1
77+
%tmp1 = zext <2 x i1> %tmp to <2 x i64>
78+
%tmp2 = xor <2 x i64> %tmp1, <i64 1, i64 1>
79+
%tmp3 = extractelement <2 x i64> %tmp2, i32 1
80+
%add = add nsw i64 0, %tmp3
81+
%cmp6 = icmp ne i64 %add, 1
82+
%conv7 = zext i1 %cmp6 to i32
83+
ret i32 %conv7
84+
}

0 commit comments

Comments
 (0)