AMDGPU: Fix verifier assert with out of bounds subregister indexes (#119799)
[llvm-project.git] / llvm / test / CodeGen / RISCV / GlobalISel / regbankselect / fptoi-f16-rv64.mir
blobd63803f8f5bdfb1b8da22263a6949539188ad766
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=riscv64 -mattr=+zfh -run-pass=regbankselect \
3 # RUN:   -simplify-mir -verify-machineinstrs %s \
4 # RUN:   -o - | FileCheck %s
6 ---
7 name:            fptosi_s32_s16
8 legalized:       true
9 tracksRegLiveness: true
10 body:             |
11   bb.1:
12     liveins: $f10_h
14     ; CHECK-LABEL: name: fptosi_s32_s16
15     ; CHECK: liveins: $f10_h
16     ; CHECK-NEXT: {{  $}}
17     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s16) = COPY $f10_h
18     ; CHECK-NEXT: [[FCVT_W_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_W_RV64 [[COPY]](s16), 1
19     ; CHECK-NEXT: $x10 = COPY [[FCVT_W_RV64_]](s64)
20     ; CHECK-NEXT: PseudoRET implicit $x10
21     %0:_(s16) = COPY $f10_h
22     %1:_(s64) = G_FCVT_W_RV64 %0(s16), 1
23     $x10 = COPY %1(s64)
24     PseudoRET implicit $x10
26 ...
27 ---
28 name:            fptoui_s32_s16
29 legalized:       true
30 tracksRegLiveness: true
31 body:             |
32   bb.1:
33     liveins: $f10_h
35     ; CHECK-LABEL: name: fptoui_s32_s16
36     ; CHECK: liveins: $f10_h
37     ; CHECK-NEXT: {{  $}}
38     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s16) = COPY $f10_h
39     ; CHECK-NEXT: [[FCVT_WU_RV64_:%[0-9]+]]:gprb(s64) = G_FCVT_WU_RV64 [[COPY]](s16), 1
40     ; CHECK-NEXT: $x10 = COPY [[FCVT_WU_RV64_]](s64)
41     ; CHECK-NEXT: PseudoRET implicit $x10
42     %0:_(s16) = COPY $f10_h
43     %1:_(s64) = G_FCVT_WU_RV64 %0(s16), 1
44     $x10 = COPY %1(s64)
45     PseudoRET implicit $x10
47 ...
48 ---
49 name:            fptosi_s64_s16
50 legalized:       true
51 tracksRegLiveness: true
52 body:             |
53   bb.1:
54     liveins: $f10_h
56     ; CHECK-LABEL: name: fptosi_s64_s16
57     ; CHECK: liveins: $f10_h
58     ; CHECK-NEXT: {{  $}}
59     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s16) = COPY $f10_h
60     ; CHECK-NEXT: [[FPTOSI:%[0-9]+]]:gprb(s64) = G_FPTOSI [[COPY]](s16)
61     ; CHECK-NEXT: $x10 = COPY [[FPTOSI]](s64)
62     ; CHECK-NEXT: PseudoRET implicit $x10
63     %0:_(s16) = COPY $f10_h
64     %1:_(s64) = G_FPTOSI %0(s16)
65     $x10 = COPY %1(s64)
66     PseudoRET implicit $x10
68 ...
69 ---
70 name:            fptoui_s64_s16
71 legalized:       true
72 tracksRegLiveness: true
73 body:             |
74   bb.1:
75     liveins: $f10_h
77     ; CHECK-LABEL: name: fptoui_s64_s16
78     ; CHECK: liveins: $f10_h
79     ; CHECK-NEXT: {{  $}}
80     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fprb(s16) = COPY $f10_h
81     ; CHECK-NEXT: [[FPTOUI:%[0-9]+]]:gprb(s64) = G_FPTOUI [[COPY]](s16)
82     ; CHECK-NEXT: $x10 = COPY [[FPTOUI]](s64)
83     ; CHECK-NEXT: PseudoRET implicit $x10
84     %0:_(s16) = COPY $f10_h
85     %1:_(s64) = G_FPTOUI %0(s16)
86     $x10 = COPY %1(s64)
87     PseudoRET implicit $x10
89 ...