1; RUN: llc -march=amdgcn -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
2; RUN: llc -march=amdgcn -mcpu=fiji -verify-machineinstrs < %s | FileCheck -check-prefix=GCN %s
3
4declare i64 @llvm.amdgcn.icmp.i32(i32, i32, i32) #0
5declare i64 @llvm.amdgcn.icmp.i64(i64, i64, i32) #0
6
7; No crash on invalid input
8; GCN-LABEL: {{^}}v_icmp_i32_dynamic_cc:
9; GCN: s_endpgm
10define amdgpu_kernel void @v_icmp_i32_dynamic_cc(i64 addrspace(1)* %out, i32 %src, i32 %cc) {
11  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 %cc)
12  store i64 %result, i64 addrspace(1)* %out
13  ret void
14}
15
16; GCN-LABEL: {{^}}v_icmp_i32_eq:
17; GCN: v_cmp_eq_u32_e64
18define amdgpu_kernel void @v_icmp_i32_eq(i64 addrspace(1)* %out, i32 %src) {
19  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 32)
20  store i64 %result, i64 addrspace(1)* %out
21  ret void
22}
23
24; GCN-LABEL: {{^}}v_icmp:
25; GCN-NOT: v_cmp_eq_u32_e64
26define amdgpu_kernel void @v_icmp(i64 addrspace(1)* %out, i32 %src) {
27  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 30)
28  store i64 %result, i64 addrspace(1)* %out
29  ret void
30}
31; GCN-LABEL: {{^}}v_icmp_i32_ne:
32; GCN: v_cmp_ne_u32_e64
33define amdgpu_kernel void @v_icmp_i32_ne(i64 addrspace(1)* %out, i32 %src) {
34  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 33)
35  store i64 %result, i64 addrspace(1)* %out
36  ret void
37}
38
39; GCN-LABEL: {{^}}v_icmp_u32_ugt:
40; GCN: v_cmp_gt_u32_e64
41define amdgpu_kernel void @v_icmp_u32_ugt(i64 addrspace(1)* %out, i32 %src) {
42  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 34)
43  store i64 %result, i64 addrspace(1)* %out
44  ret void
45}
46
47; GCN-LABEL: {{^}}v_icmp_u32_uge:
48; GCN: v_cmp_ge_u32_e64
49define amdgpu_kernel void @v_icmp_u32_uge(i64 addrspace(1)* %out, i32 %src) {
50  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 35)
51  store i64 %result, i64 addrspace(1)* %out
52  ret void
53}
54
55; GCN-LABEL: {{^}}v_icmp_u32_ult:
56; GCN: v_cmp_lt_u32_e64
57define amdgpu_kernel void @v_icmp_u32_ult(i64 addrspace(1)* %out, i32 %src) {
58  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 36)
59  store i64 %result, i64 addrspace(1)* %out
60  ret void
61}
62
63; GCN-LABEL: {{^}}v_icmp_u32_ule:
64; GCN: v_cmp_le_u32_e64
65define amdgpu_kernel void @v_icmp_u32_ule(i64 addrspace(1)* %out, i32 %src) {
66  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 37)
67  store i64 %result, i64 addrspace(1)* %out
68  ret void
69}
70
71; GCN-LABEL: {{^}}v_icmp_i32_sgt:
72; GCN: v_cmp_gt_i32_e64
73define amdgpu_kernel void @v_icmp_i32_sgt(i64 addrspace(1)* %out, i32 %src) #1 {
74  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 38)
75  store i64 %result, i64 addrspace(1)* %out
76  ret void
77}
78
79; GCN-LABEL: {{^}}v_icmp_i32_sge:
80; GCN: v_cmp_ge_i32_e64
81define amdgpu_kernel void @v_icmp_i32_sge(i64 addrspace(1)* %out, i32 %src) {
82  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 39)
83  store i64 %result, i64 addrspace(1)* %out
84  ret void
85}
86
87; GCN-LABEL: {{^}}v_icmp_i32_slt:
88; GCN: v_cmp_lt_i32_e64
89define amdgpu_kernel void @v_icmp_i32_slt(i64 addrspace(1)* %out, i32 %src) {
90  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 40)
91  store i64 %result, i64 addrspace(1)* %out
92  ret void
93}
94; GCN-LABEL: {{^}}v_icmp_i32_sle:
95; GCN: v_cmp_le_i32_e64
96define amdgpu_kernel void @v_icmp_i32_sle(i64 addrspace(1)* %out, i32 %src) {
97  %result = call i64 @llvm.amdgcn.icmp.i32(i32 %src, i32 100, i32 41)
98  store i64 %result, i64 addrspace(1)* %out
99  ret void
100}
101
102; GCN-LABEL: {{^}}v_icmp_i64_eq:
103; GCN: v_cmp_eq_u64_e64
104define amdgpu_kernel void @v_icmp_i64_eq(i64 addrspace(1)* %out, i64 %src) {
105  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 32)
106  store i64 %result, i64 addrspace(1)* %out
107  ret void
108}
109
110; GCN-LABEL: {{^}}v_icmp_i64_ne:
111; GCN: v_cmp_ne_u64_e64
112define amdgpu_kernel void @v_icmp_i64_ne(i64 addrspace(1)* %out, i64 %src) {
113  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 33)
114  store i64 %result, i64 addrspace(1)* %out
115  ret void
116}
117
118; GCN-LABEL: {{^}}v_icmp_u64_ugt:
119; GCN: v_cmp_gt_u64_e64
120define amdgpu_kernel void @v_icmp_u64_ugt(i64 addrspace(1)* %out, i64 %src) {
121  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 34)
122  store i64 %result, i64 addrspace(1)* %out
123  ret void
124}
125
126; GCN-LABEL: {{^}}v_icmp_u64_uge:
127; GCN: v_cmp_ge_u64_e64
128define amdgpu_kernel void @v_icmp_u64_uge(i64 addrspace(1)* %out, i64 %src) {
129  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 35)
130  store i64 %result, i64 addrspace(1)* %out
131  ret void
132}
133
134; GCN-LABEL: {{^}}v_icmp_u64_ult:
135; GCN: v_cmp_lt_u64_e64
136define amdgpu_kernel void @v_icmp_u64_ult(i64 addrspace(1)* %out, i64 %src) {
137  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 36)
138  store i64 %result, i64 addrspace(1)* %out
139  ret void
140}
141
142; GCN-LABEL: {{^}}v_icmp_u64_ule:
143; GCN: v_cmp_le_u64_e64
144define amdgpu_kernel void @v_icmp_u64_ule(i64 addrspace(1)* %out, i64 %src) {
145  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 37)
146  store i64 %result, i64 addrspace(1)* %out
147  ret void
148}
149
150; GCN-LABEL: {{^}}v_icmp_i64_sgt:
151; GCN: v_cmp_gt_i64_e64
152define amdgpu_kernel void @v_icmp_i64_sgt(i64 addrspace(1)* %out, i64 %src) {
153  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 38)
154  store i64 %result, i64 addrspace(1)* %out
155  ret void
156}
157
158; GCN-LABEL: {{^}}v_icmp_i64_sge:
159; GCN: v_cmp_ge_i64_e64
160define amdgpu_kernel void @v_icmp_i64_sge(i64 addrspace(1)* %out, i64 %src) {
161  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 39)
162  store i64 %result, i64 addrspace(1)* %out
163  ret void
164}
165
166; GCN-LABEL: {{^}}v_icmp_i64_slt:
167; GCN: v_cmp_lt_i64_e64
168define amdgpu_kernel void @v_icmp_i64_slt(i64 addrspace(1)* %out, i64 %src) {
169  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 40)
170  store i64 %result, i64 addrspace(1)* %out
171  ret void
172}
173; GCN-LABEL: {{^}}v_icmp_i64_sle:
174; GCN: v_cmp_le_i64_e64
175define amdgpu_kernel void @v_icmp_i64_sle(i64 addrspace(1)* %out, i64 %src) {
176  %result = call i64 @llvm.amdgcn.icmp.i64(i64 %src, i64 100, i32 41)
177  store i64 %result, i64 addrspace(1)* %out
178  ret void
179}
180
181attributes #0 = { nounwind readnone convergent }
182