|
2 | 2 | ; RUN: %if ptxas %{ llc < %s -march=nvptx64 -mcpu=sm_20 | %ptxas-verify %} |
3 | 3 |
|
4 | 4 | ; CHECK-LABEL: foo |
5 | | -; CHECK: setp |
6 | | -; CHECK: selp |
7 | | -; CHECK: cvt.rn.f32.u32 |
| 5 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 6 | +; CHECK: selp.u32 %[[R:r[0-9]+]], 1, 0, %[[P]]; |
| 7 | +; CHECK: cvt.rn.f32.u32 %f{{.*}}, %[[R]] |
8 | 8 | define float @foo(i1 %a) { |
9 | 9 | %ret = uitofp i1 %a to float |
10 | 10 | ret float %ret |
11 | 11 | } |
12 | 12 |
|
13 | 13 | ; CHECK-LABEL: foo2 |
14 | | -; CHECK: setp |
15 | | -; CHECK: selp |
16 | | -; CHECK: cvt.rn.f32.s32 |
| 14 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 15 | +; CHECK: selp.s32 %[[R:r[0-9]+]], -1, 0, %[[P]]; |
| 16 | +; CHECK: cvt.rn.f32.s32 %f{{.*}}, %[[R]] |
17 | 17 | define float @foo2(i1 %a) { |
18 | 18 | %ret = sitofp i1 %a to float |
19 | 19 | ret float %ret |
20 | 20 | } |
21 | 21 |
|
22 | 22 | ; CHECK-LABEL: foo3 |
23 | | -; CHECK: setp |
24 | | -; CHECK: selp |
25 | | -; CHECK: cvt.rn.f64.u32 |
| 23 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 24 | +; CHECK: selp.u32 %[[R:r[0-9]+]], 1, 0, %[[P]]; |
| 25 | +; CHECK: cvt.rn.f64.u32 %fd{{.*}}, %[[R]] |
26 | 26 | define double @foo3(i1 %a) { |
27 | 27 | %ret = uitofp i1 %a to double |
28 | 28 | ret double %ret |
29 | 29 | } |
30 | 30 |
|
31 | 31 | ; CHECK-LABEL: foo4 |
32 | | -; CHECK: setp |
33 | | -; CHECK: selp |
34 | | -; CHECK: cvt.rn.f64.s32 |
| 32 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 33 | +; CHECK: selp.s32 %[[R:r[0-9]+]], -1, 0, %[[P]]; |
| 34 | +; CHECK: cvt.rn.f64.s32 %fd{{.*}}, %[[R]] |
35 | 35 | define double @foo4(i1 %a) { |
36 | 36 | %ret = sitofp i1 %a to double |
37 | 37 | ret double %ret |
38 | 38 | } |
| 39 | + |
| 40 | +; CHECK-LABEL: foo5 |
| 41 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 42 | +; CHECK: selp.u32 %[[R:r[0-9]+]], 1, 0, %[[P]]; |
| 43 | +; CHECK: cvt.rn.f16.u32 %{{.*}}, %[[R]] |
| 44 | +define half @foo5(i1 %a) { |
| 45 | + %ret = uitofp i1 %a to half |
| 46 | + ret half %ret |
| 47 | +} |
| 48 | + |
| 49 | +; CHECK-LABEL: foo6 |
| 50 | +; CHECK: setp.eq.b16 %[[P:p[0-9]+]], %{{.*}}, 1; |
| 51 | +; CHECK: selp.s32 %[[R:r[0-9]+]], -1, 0, %[[P]]; |
| 52 | +; CHECK: cvt.rn.f16.s32 %{{.*}}, %[[R]] |
| 53 | +define half @foo6(i1 %a) { |
| 54 | + %ret = sitofp i1 %a to half |
| 55 | + ret half %ret |
| 56 | +} |
0 commit comments