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 p0, r1, r2;
5 ; CHECK-NEXT: cvt.u32.pred r0, 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 p0, r1, r2;
14 ; CHECK-NEXT: cvt.u32.pred r0, 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 p0, r1, r2;
23 ; CHECK-NEXT: cvt.u32.pred r0, 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 p0, r1, r2;
32 ; CHECK-NEXT: cvt.u32.pred r0, 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 p0, r1, r2;
41 ; CHECK-NEXT: cvt.u32.pred r0, 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 p0, r1, r2;
50 ; CHECK-NEXT: cvt.u32.pred r0, p0;
52 %p = icmp uge i32 %x, %y
53 %z = zext i1 %p to i32
57 define ptx_device i32 @test_setp_eq_u32_ri(i32 %x) {
58 ; CHECK: setp.eq.u32 p0, r1, 1;
59 ; CHECK-NEXT: cvt.u32.pred r0, p0;
61 %p = icmp eq i32 %x, 1
62 %z = zext i1 %p to i32
66 define ptx_device i32 @test_setp_ne_u32_ri(i32 %x) {
67 ; CHECK: setp.ne.u32 p0, r1, 1;
68 ; CHECK-NEXT: cvt.u32.pred r0, p0;
70 %p = icmp ne i32 %x, 1
71 %z = zext i1 %p to i32
75 define ptx_device i32 @test_setp_lt_u32_ri(i32 %x) {
76 ; CHECK: setp.eq.u32 p0, r1, 0;
77 ; CHECK-NEXT: cvt.u32.pred r0, p0;
79 %p = icmp ult i32 %x, 1
80 %z = zext i1 %p to i32
84 define ptx_device i32 @test_setp_le_u32_ri(i32 %x) {
85 ; CHECK: setp.lt.u32 p0, r1, 2;
86 ; CHECK-NEXT: cvt.u32.pred r0, p0;
88 %p = icmp ule i32 %x, 1
89 %z = zext i1 %p to i32
93 define ptx_device i32 @test_setp_gt_u32_ri(i32 %x) {
94 ; CHECK: setp.gt.u32 p0, r1, 1;
95 ; CHECK-NEXT: cvt.u32.pred r0, p0;
97 %p = icmp ugt i32 %x, 1
98 %z = zext i1 %p to i32
102 define ptx_device i32 @test_setp_ge_u32_ri(i32 %x) {
103 ; CHECK: setp.ne.u32 p0, r1, 0;
104 ; CHECK-NEXT: cvt.u32.pred r0, p0;
106 %p = icmp uge i32 %x, 1
107 %z = zext i1 %p to i32
111 define ptx_device i32 @test_setp_4_op_format_1(i32 %x, i32 %y, i32 %u, i32 %v) {
112 ; CHECK: setp.gt.u32 p0, r3, r4;
113 ; CHECK-NEXT: setp.eq.and.u32 p0, r1, r2, p0;
114 ; CHECK-NEXT: cvt.u32.pred r0, p0;
116 %c = icmp eq i32 %x, %y
117 %d = icmp ugt i32 %u, %v
119 %z = zext i1 %e to i32
123 define ptx_device i32 @test_setp_4_op_format_2(i32 %x, i32 %y, i32 %w) {
124 ; CHECK: cvt.pred.u32 p0, r3;
125 ; CHECK-NEXT: setp.eq.and.u32 p0, r1, r2, !p0;
126 ; CHECK-NEXT: cvt.u32.pred r0, p0;
128 %c = trunc i32 %w to i1
129 %d = icmp eq i32 %x, %y
132 %z = zext i1 %f to i32