xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/wide-integer-cmp.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=i686-linux-gnu %s -o - | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_eq(i64 %a, i64 %b) {
5*9880d681SAndroid Build Coastguard Workerentry:
6*9880d681SAndroid Build Coastguard Worker  %cmp = icmp eq i64 %a, %b
7*9880d681SAndroid Build Coastguard Worker	br i1 %cmp, label %bb1, label %bb2
8*9880d681SAndroid Build Coastguard Workerbb1:
9*9880d681SAndroid Build Coastguard Worker  ret i32 1
10*9880d681SAndroid Build Coastguard Workerbb2:
11*9880d681SAndroid Build Coastguard Worker  ret i32 2
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_eq:
14*9880d681SAndroid Build Coastguard Worker; CHECK: movl 4(%esp), [[LHSLo:%[a-z]+]]
15*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]]
16*9880d681SAndroid Build Coastguard Worker; CHECK: xorl 16(%esp), [[LHSHi]]
17*9880d681SAndroid Build Coastguard Worker; CHECK: xorl 12(%esp), [[LHSLo]]
18*9880d681SAndroid Build Coastguard Worker; CHECK: orl [[LHSHi]], [[LHSLo]]
19*9880d681SAndroid Build Coastguard Worker; CHECK: jne [[FALSE:.LBB[0-9_]+]]
20*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax
21*9880d681SAndroid Build Coastguard Worker; CHECK: retl
22*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]:
23*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax
24*9880d681SAndroid Build Coastguard Worker; CHECK: retl
25*9880d681SAndroid Build Coastguard Worker}
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_slt(i64 %a, i64 %b) {
28*9880d681SAndroid Build Coastguard Workerentry:
29*9880d681SAndroid Build Coastguard Worker  %cmp = icmp slt i64 %a, %b
30*9880d681SAndroid Build Coastguard Worker	br i1 %cmp, label %bb1, label %bb2
31*9880d681SAndroid Build Coastguard Workerbb1:
32*9880d681SAndroid Build Coastguard Worker  ret i32 1
33*9880d681SAndroid Build Coastguard Workerbb2:
34*9880d681SAndroid Build Coastguard Worker  ret i32 2
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_slt:
37*9880d681SAndroid Build Coastguard Worker; CHECK: movl 4(%esp), [[LHSLo:%[a-z]+]]
38*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]]
39*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 12(%esp), [[LHSLo]]
40*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 16(%esp), [[LHSHi]]
41*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]]
42*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax
43*9880d681SAndroid Build Coastguard Worker; CHECK: retl
44*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]:
45*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax
46*9880d681SAndroid Build Coastguard Worker; CHECK: retl
47*9880d681SAndroid Build Coastguard Worker}
48*9880d681SAndroid Build Coastguard Worker
49*9880d681SAndroid Build Coastguard Workerdefine i32 @branch_ule(i64 %a, i64 %b) {
50*9880d681SAndroid Build Coastguard Workerentry:
51*9880d681SAndroid Build Coastguard Worker  %cmp = icmp ule i64 %a, %b
52*9880d681SAndroid Build Coastguard Worker	br i1 %cmp, label %bb1, label %bb2
53*9880d681SAndroid Build Coastguard Workerbb1:
54*9880d681SAndroid Build Coastguard Worker  ret i32 1
55*9880d681SAndroid Build Coastguard Workerbb2:
56*9880d681SAndroid Build Coastguard Worker  ret i32 2
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: branch_ule:
59*9880d681SAndroid Build Coastguard Worker; CHECK: movl 12(%esp), [[RHSLo:%[a-z]+]]
60*9880d681SAndroid Build Coastguard Worker; CHECK: movl 16(%esp), [[RHSHi:%[a-z]+]]
61*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 4(%esp), [[RHSLo]]
62*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 8(%esp), [[RHSHi]]
63*9880d681SAndroid Build Coastguard Worker; CHECK: jb [[FALSE:.LBB[0-9_]+]]
64*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax
65*9880d681SAndroid Build Coastguard Worker; CHECK: retl
66*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]:
67*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax
68*9880d681SAndroid Build Coastguard Worker; CHECK: retl
69*9880d681SAndroid Build Coastguard Worker}
70*9880d681SAndroid Build Coastguard Worker
71*9880d681SAndroid Build Coastguard Workerdefine i32 @set_gt(i64 %a, i64 %b) {
72*9880d681SAndroid Build Coastguard Workerentry:
73*9880d681SAndroid Build Coastguard Worker  %cmp = icmp sgt i64 %a, %b
74*9880d681SAndroid Build Coastguard Worker  %res = select i1 %cmp, i32 1, i32 0
75*9880d681SAndroid Build Coastguard Worker  ret i32 %res
76*9880d681SAndroid Build Coastguard Worker
77*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: set_gt:
78*9880d681SAndroid Build Coastguard Worker; CHECK: movl 12(%esp), [[RHSLo:%[a-z]+]]
79*9880d681SAndroid Build Coastguard Worker; CHECK: movl 16(%esp), [[RHSHi:%[a-z]+]]
80*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 4(%esp), [[RHSLo]]
81*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 8(%esp), [[RHSHi]]
82*9880d681SAndroid Build Coastguard Worker; CHECK: setl %al
83*9880d681SAndroid Build Coastguard Worker; CHECK: retl
84*9880d681SAndroid Build Coastguard Worker}
85*9880d681SAndroid Build Coastguard Worker
86*9880d681SAndroid Build Coastguard Workerdefine i32 @test_wide(i128 %a, i128 %b) {
87*9880d681SAndroid Build Coastguard Workerentry:
88*9880d681SAndroid Build Coastguard Worker  %cmp = icmp slt i128 %a, %b
89*9880d681SAndroid Build Coastguard Worker	br i1 %cmp, label %bb1, label %bb2
90*9880d681SAndroid Build Coastguard Workerbb1:
91*9880d681SAndroid Build Coastguard Worker  ret i32 1
92*9880d681SAndroid Build Coastguard Workerbb2:
93*9880d681SAndroid Build Coastguard Worker  ret i32 2
94*9880d681SAndroid Build Coastguard Worker
95*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test_wide:
96*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 24(%esp)
97*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 28(%esp)
98*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 32(%esp)
99*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl 36(%esp)
100*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]]
101*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax
102*9880d681SAndroid Build Coastguard Worker; CHECK: retl
103*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]:
104*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax
105*9880d681SAndroid Build Coastguard Worker; CHECK: retl
106*9880d681SAndroid Build Coastguard Worker}
107*9880d681SAndroid Build Coastguard Worker
108*9880d681SAndroid Build Coastguard Workerdefine i32 @test_carry_false(i64 %a, i64 %b) {
109*9880d681SAndroid Build Coastguard Workerentry:
110*9880d681SAndroid Build Coastguard Worker  %x = and i64 %a, -4294967296 ;0xffffffff00000000
111*9880d681SAndroid Build Coastguard Worker  %y = and i64 %b, -4294967296
112*9880d681SAndroid Build Coastguard Worker  %cmp = icmp slt i64 %x, %y
113*9880d681SAndroid Build Coastguard Worker	br i1 %cmp, label %bb1, label %bb2
114*9880d681SAndroid Build Coastguard Workerbb1:
115*9880d681SAndroid Build Coastguard Worker  ret i32 1
116*9880d681SAndroid Build Coastguard Workerbb2:
117*9880d681SAndroid Build Coastguard Worker  ret i32 2
118*9880d681SAndroid Build Coastguard Worker
119*9880d681SAndroid Build Coastguard Worker; The comparison of the low bits will be folded to a CARRY_FALSE node. Make
120*9880d681SAndroid Build Coastguard Worker; sure the code can handle that.
121*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: carry_false:
122*9880d681SAndroid Build Coastguard Worker; CHECK: movl 8(%esp), [[LHSHi:%[a-z]+]]
123*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl 16(%esp), [[LHSHi]]
124*9880d681SAndroid Build Coastguard Worker; CHECK: jge [[FALSE:.LBB[0-9_]+]]
125*9880d681SAndroid Build Coastguard Worker; CHECK: movl $1, %eax
126*9880d681SAndroid Build Coastguard Worker; CHECK: retl
127*9880d681SAndroid Build Coastguard Worker; CHECK: [[FALSE]]:
128*9880d681SAndroid Build Coastguard Worker; CHECK: movl $2, %eax
129*9880d681SAndroid Build Coastguard Worker; CHECK: retl
130*9880d681SAndroid Build Coastguard Worker}
131