[LLVM][IR] Use splat syntax when printing ConstantExpr based splats. (#116856)
[llvm-project.git] / llvm / test / CodeGen / RISCV / GlobalISel / regbankselect / fptoi-rv64.mir
blobd5c2875d316cb2ef0193462e6f3b8e2de0de5320
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=riscv64 -mattr=+d -run-pass=regbankselect \
3 # RUN:   -simplify-mir -verify-machineinstrs %s \
4 # RUN:   -o - | FileCheck %s
6 ---
7 name:            fptosi_s32_s32
8 legalized:       true
9 tracksRegLiveness: true
10 body:             |
11   bb.1:
12     liveins: $f10_f
14     ; CHECK-LABEL: name: fptosi_s32_s32
15     ; CHECK: liveins: $f10_f
16     ; CHECK-NEXT: {{  $}}
17     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s32) = COPY $f10_f
18     ; CHECK-NEXT: [[FCVT_W_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_W_RV64 [[COPY]](s32), 1
19     ; CHECK-NEXT: $x10 = COPY [[FCVT_W_RV64_]](s64)
20     ; CHECK-NEXT: PseudoRET implicit $x10
21     %0:_(s32) = COPY $f10_f
22     %1:_(s64) = G_FCVT_W_RV64 %0(s32), 1
23     $x10 = COPY %1(s64)
24     PseudoRET implicit $x10
26 ...
27 ---
28 name:            fptoui_s32_s32
29 legalized:       true
30 tracksRegLiveness: true
31 body:             |
32   bb.1:
33     liveins: $f10_f
35     ; CHECK-LABEL: name: fptoui_s32_s32
36     ; CHECK: liveins: $f10_f
37     ; CHECK-NEXT: {{  $}}
38     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s32) = COPY $f10_f
39     ; CHECK-NEXT: [[FCVT_WU_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_WU_RV64 [[COPY]](s32), 1
40     ; CHECK-NEXT: $x10 = COPY [[FCVT_WU_RV64_]](s64)
41     ; CHECK-NEXT: PseudoRET implicit $x10
42     %0:_(s32) = COPY $f10_f
43     %1:_(s64) = G_FCVT_WU_RV64 %0(s32), 1
44     $x10 = COPY %1(s64)
45     PseudoRET implicit $x10
47 ...
48 ---
49 name:            fptosi_s64_s32
50 legalized:       true
51 tracksRegLiveness: true
52 body:             |
53   bb.1:
54     liveins: $f10_f
56     ; CHECK-LABEL: name: fptosi_s64_s32
57     ; CHECK: liveins: $f10_f
58     ; CHECK-NEXT: {{  $}}
59     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s32) = COPY $f10_f
60     ; CHECK-NEXT: [[FPTOSI:%[0-9]+]]:gprb(s64) = G_FPTOSI [[COPY]](s32)
61     ; CHECK-NEXT: $x10 = COPY [[FPTOSI]](s64)
62     ; CHECK-NEXT: PseudoRET implicit $x10
63     %0:_(s32) = COPY $f10_f
64     %1:_(s64) = G_FPTOSI %0(s32)
65     $x10 = COPY %1(s64)
66     PseudoRET implicit $x10
68 ...
69 ---
70 name:            fptoui_s64_s32
71 legalized:       true
72 tracksRegLiveness: true
73 body:             |
74   bb.1:
75     liveins: $f10_f
77     ; CHECK-LABEL: name: fptoui_s64_s32
78     ; CHECK: liveins: $f10_f
79     ; CHECK-NEXT: {{  $}}
80     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s32) = COPY $f10_f
81     ; CHECK-NEXT: [[FPTOUI:%[0-9]+]]:gprb(s64) = G_FPTOUI [[COPY]](s32)
82     ; CHECK-NEXT: $x10 = COPY [[FPTOUI]](s64)
83     ; CHECK-NEXT: PseudoRET implicit $x10
84     %0:_(s32) = COPY $f10_f
85     %1:_(s64) = G_FPTOUI %0(s32)
86     $x10 = COPY %1(s64)
87     PseudoRET implicit $x10
89 ...
90 ---
91 name:            fptosi_s32_s64
92 legalized:       true
93 tracksRegLiveness: true
94 body:             |
95   bb.1:
96     liveins: $f10_d
98     ; CHECK-LABEL: name: fptosi_s32_s64
99     ; CHECK: liveins: $f10_d
100     ; CHECK-NEXT: {{  $}}
101     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s64) = COPY $f10_d
102     ; CHECK-NEXT: [[FCVT_W_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_W_RV64 [[COPY]](s64), 1
103     ; CHECK-NEXT: $x10 = COPY [[FCVT_W_RV64_]](s64)
104     ; CHECK-NEXT: PseudoRET implicit $x10
105     %0:_(s64) = COPY $f10_d
106     %1:_(s64) = G_FCVT_W_RV64 %0(s64), 1
107     $x10 = COPY %1(s64)
108     PseudoRET implicit $x10
112 name:            fptoui_s32_s64
113 legalized:       true
114 tracksRegLiveness: true
115 body:             |
116   bb.1:
117     liveins: $f10_d
119     ; CHECK-LABEL: name: fptoui_s32_s64
120     ; CHECK: liveins: $f10_d
121     ; CHECK-NEXT: {{  $}}
122     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s64) = COPY $f10_d
123     ; CHECK-NEXT: [[FCVT_W_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_W_RV64 [[COPY]](s64), 1
124     ; CHECK-NEXT: $x10 = COPY [[FCVT_W_RV64_]](s64)
125     ; CHECK-NEXT: PseudoRET implicit $x10
126     %0:_(s64) = COPY $f10_d
127     %1:_(s64) = G_FCVT_W_RV64 %0(s64), 1
128     $x10 = COPY %1(s64)
129     PseudoRET implicit $x10
133 name:            fptosi_s64_s64
134 legalized:       true
135 tracksRegLiveness: true
136 body:             |
137   bb.1:
138     liveins: $f10_d
140     ; CHECK-LABEL: name: fptosi_s64_s64
141     ; CHECK: liveins: $f10_d
142     ; CHECK-NEXT: {{  $}}
143     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s64) = COPY $f10_d
144     ; CHECK-NEXT: [[FPTOSI:%[0-9]+]]:gprb(s64) = G_FPTOSI [[COPY]](s64)
145     ; CHECK-NEXT: $x10 = COPY [[FPTOSI]](s64)
146     ; CHECK-NEXT: PseudoRET implicit $x10
147     %0:_(s64) = COPY $f10_d
148     %1:_(s64) = G_FPTOSI %0(s64)
149     $x10 = COPY %1(s64)
150     PseudoRET implicit $x10
154 name:            fptoui_s64_s64
155 legalized:       true
156 tracksRegLiveness: true
157 body:             |
158   bb.1:
159     liveins: $f10_d
161     ; CHECK-LABEL: name: fptoui_s64_s64
162     ; CHECK: liveins: $f10_d
163     ; CHECK-NEXT: {{  $}}
164     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s64) = COPY $f10_d
165     ; CHECK-NEXT: [[FPTOUI:%[0-9]+]]:gprb(s64) = G_FPTOUI [[COPY]](s64)
166     ; CHECK-NEXT: $x10 = COPY [[FPTOUI]](s64)
167     ; CHECK-NEXT: PseudoRET implicit $x10
168     %0:_(s64) = COPY $f10_d
169     %1:_(s64) = G_FPTOUI %0(s64)
170     $x10 = COPY %1(s64)
171     PseudoRET implicit $x10