1 ; RUN: llc < %s -march=ptx32 | FileCheck %s
3 define ptx_device i32 @test_setp_eq_u32_rr(i32 %x, i32 %y) {
4 ; CHECK: setp.eq.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
5 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
7 %p = icmp eq i32 %x, %y
12 define ptx_device i32 @test_setp_ne_u32_rr(i32 %x, i32 %y) {
13 ; CHECK: setp.ne.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
14 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
16 %p = icmp ne i32 %x, %y
17 %z = zext i1 %p to i32
21 define ptx_device i32 @test_setp_lt_u32_rr(i32 %x, i32 %y) {
22 ; CHECK: setp.lt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
23 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
25 %p = icmp ult i32 %x, %y
26 %z = zext i1 %p to i32
30 define ptx_device i32 @test_setp_le_u32_rr(i32 %x, i32 %y) {
31 ; CHECK: setp.le.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
32 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
34 %p = icmp ule i32 %x, %y
35 %z = zext i1 %p to i32
39 define ptx_device i32 @test_setp_gt_u32_rr(i32 %x, i32 %y) {
40 ; CHECK: setp.gt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
41 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
43 %p = icmp ugt i32 %x, %y
44 %z = zext i1 %p to i32
48 define ptx_device i32 @test_setp_ge_u32_rr(i32 %x, i32 %y) {
49 ; CHECK: setp.ge.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
50 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
52 %p = icmp uge i32 %x, %y
53 %z = zext i1 %p to i32
57 define ptx_device i32 @test_setp_lt_s32_rr(i32 %x, i32 %y) {
58 ; CHECK: setp.lt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
59 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
61 %p = icmp slt i32 %x, %y
62 %z = zext i1 %p to i32
66 define ptx_device i32 @test_setp_le_s32_rr(i32 %x, i32 %y) {
67 ; CHECK: setp.le.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
68 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
70 %p = icmp sle i32 %x, %y
71 %z = zext i1 %p to i32
75 define ptx_device i32 @test_setp_gt_s32_rr(i32 %x, i32 %y) {
76 ; CHECK: setp.gt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
77 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
79 %p = icmp sgt i32 %x, %y
80 %z = zext i1 %p to i32
84 define ptx_device i32 @test_setp_ge_s32_rr(i32 %x, i32 %y) {
85 ; CHECK: setp.ge.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
86 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
88 %p = icmp sge i32 %x, %y
89 %z = zext i1 %p to i32
93 define ptx_device i32 @test_setp_eq_u32_ri(i32 %x) {
94 ; CHECK: setp.eq.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 1;
95 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
97 %p = icmp eq i32 %x, 1
98 %z = zext i1 %p to i32
102 define ptx_device i32 @test_setp_ne_u32_ri(i32 %x) {
103 ; CHECK: setp.ne.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 1;
104 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
106 %p = icmp ne i32 %x, 1
107 %z = zext i1 %p to i32
111 define ptx_device i32 @test_setp_lt_u32_ri(i32 %x) {
112 ; CHECK: setp.eq.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 0;
113 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
115 %p = icmp ult i32 %x, 1
116 %z = zext i1 %p to i32
120 define ptx_device i32 @test_setp_le_u32_ri(i32 %x) {
121 ; CHECK: setp.lt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 2;
122 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
124 %p = icmp ule i32 %x, 1
125 %z = zext i1 %p to i32
129 define ptx_device i32 @test_setp_gt_u32_ri(i32 %x) {
130 ; CHECK: setp.gt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 1;
131 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
133 %p = icmp ugt i32 %x, 1
134 %z = zext i1 %p to i32
138 define ptx_device i32 @test_setp_ge_u32_ri(i32 %x) {
139 ; CHECK: setp.ne.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 0;
140 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
142 %p = icmp uge i32 %x, 1
143 %z = zext i1 %p to i32
147 define ptx_device i32 @test_setp_lt_s32_ri(i32 %x) {
148 ; CHECK: setp.lt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 1;
149 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
151 %p = icmp slt i32 %x, 1
152 %z = zext i1 %p to i32
156 define ptx_device i32 @test_setp_le_s32_ri(i32 %x) {
157 ; CHECK: setp.lt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 2;
158 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
160 %p = icmp sle i32 %x, 1
161 %z = zext i1 %p to i32
165 define ptx_device i32 @test_setp_gt_s32_ri(i32 %x) {
166 ; CHECK: setp.gt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 1;
167 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
169 %p = icmp sgt i32 %x, 1
170 %z = zext i1 %p to i32
174 define ptx_device i32 @test_setp_ge_s32_ri(i32 %x) {
175 ; CHECK: setp.gt.s32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 0;
176 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p[[P0]];
178 %p = icmp sge i32 %x, 1
179 %z = zext i1 %p to i32
183 define ptx_device i32 @test_setp_4_op_format_1(i32 %x, i32 %y, i32 %u, i32 %v) {
184 ; CHECK: setp.gt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, %r{{[0-9]+}};
185 ; CHECK: setp.eq.and.u32 %p1, %r{{[0-9]+}}, %r{{[0-9]+}}, %p[[P0]];
186 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p1;
188 %c = icmp eq i32 %x, %y
189 %d = icmp ugt i32 %u, %v
191 %z = zext i1 %e to i32
195 define ptx_device i32 @test_setp_4_op_format_2(i32 %x, i32 %y, i32 %w) {
196 ; CHECK: setp.gt.u32 %p[[P0:[0-9]+]], %r{{[0-9]+}}, 0;
197 ; CHECK: setp.eq.and.u32 %p1, %r{{[0-9]+}}, %r{{[0-9]+}}, !%p[[P0]];
198 ; CHECK: selp.u32 %ret{{[0-9]+}}, 1, 0, %p1;
200 %c = trunc i32 %w to i1
201 %d = icmp eq i32 %x, %y
204 %z = zext i1 %f to i32