xref: /aosp_15_r20/external/llvm/test/CodeGen/NVPTX/convert-int-sm20.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=nvptx64 -mcpu=sm_20 | FileCheck %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker;; Integer conversions happen inplicitly by loading/storing the proper types
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; i16
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine i16 @cvt_i16_i32(i32 %x) {
11*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u16 %r[[R0:[0-9]+]], [cvt_i16_i32_param_{{[0-9]+}}]
12*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b32 [func_retval{{[0-9]+}}+0], %r[[R0]]
13*9880d681SAndroid Build Coastguard Worker; CHECK: ret
14*9880d681SAndroid Build Coastguard Worker  %a = trunc i32 %x to i16
15*9880d681SAndroid Build Coastguard Worker  ret i16 %a
16*9880d681SAndroid Build Coastguard Worker}
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerdefine i16 @cvt_i16_i64(i64 %x) {
19*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u16 %r[[R0:[0-9]+]], [cvt_i16_i64_param_{{[0-9]+}}]
20*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b32 [func_retval{{[0-9]+}}+0], %r[[R0]]
21*9880d681SAndroid Build Coastguard Worker; CHECK: ret
22*9880d681SAndroid Build Coastguard Worker  %a = trunc i64 %x to i16
23*9880d681SAndroid Build Coastguard Worker  ret i16 %a
24*9880d681SAndroid Build Coastguard Worker}
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Worker
28*9880d681SAndroid Build Coastguard Worker; i32
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Workerdefine i32 @cvt_i32_i16(i16 %x) {
31*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u16 %r[[R0:[0-9]+]], [cvt_i32_i16_param_{{[0-9]+}}]
32*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b32 [func_retval{{[0-9]+}}+0], %r[[R0]]
33*9880d681SAndroid Build Coastguard Worker; CHECK: ret
34*9880d681SAndroid Build Coastguard Worker  %a = zext i16 %x to i32
35*9880d681SAndroid Build Coastguard Worker  ret i32 %a
36*9880d681SAndroid Build Coastguard Worker}
37*9880d681SAndroid Build Coastguard Worker
38*9880d681SAndroid Build Coastguard Workerdefine i32 @cvt_i32_i64(i64 %x) {
39*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u32 %r[[R0:[0-9]+]], [cvt_i32_i64_param_{{[0-9]+}}]
40*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b32 [func_retval{{[0-9]+}}+0], %r[[R0]]
41*9880d681SAndroid Build Coastguard Worker; CHECK: ret
42*9880d681SAndroid Build Coastguard Worker  %a = trunc i64 %x to i32
43*9880d681SAndroid Build Coastguard Worker  ret i32 %a
44*9880d681SAndroid Build Coastguard Worker}
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Worker
47*9880d681SAndroid Build Coastguard Worker
48*9880d681SAndroid Build Coastguard Worker; i64
49*9880d681SAndroid Build Coastguard Worker
50*9880d681SAndroid Build Coastguard Workerdefine i64 @cvt_i64_i16(i16 %x) {
51*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u16 %rd[[R0:[0-9]+]], [cvt_i64_i16_param_{{[0-9]+}}]
52*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b64 [func_retval{{[0-9]+}}+0], %rd[[R0]]
53*9880d681SAndroid Build Coastguard Worker; CHECK: ret
54*9880d681SAndroid Build Coastguard Worker  %a = zext i16 %x to i64
55*9880d681SAndroid Build Coastguard Worker  ret i64 %a
56*9880d681SAndroid Build Coastguard Worker}
57*9880d681SAndroid Build Coastguard Worker
58*9880d681SAndroid Build Coastguard Workerdefine i64 @cvt_i64_i32(i32 %x) {
59*9880d681SAndroid Build Coastguard Worker; CHECK: ld.param.u32 %rd[[R0:[0-9]+]], [cvt_i64_i32_param_{{[0-9]+}}]
60*9880d681SAndroid Build Coastguard Worker; CHECK: st.param.b64 [func_retval{{[0-9]+}}+0], %rd[[R0]]
61*9880d681SAndroid Build Coastguard Worker; CHECK: ret
62*9880d681SAndroid Build Coastguard Worker  %a = zext i32 %x to i64
63*9880d681SAndroid Build Coastguard Worker  ret i64 %a
64*9880d681SAndroid Build Coastguard Worker}
65