Revert "[clang][bytecode] Fix some shift edge cases (#119895)"
[llvm-project.git] / llvm / test / CodeGen / RISCV / GlobalISel / instruction-select / fp-ext-trunc.mir
blob9f0de60dab78278c1680d80d52d62f503607c272
1 # NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
2 # RUN: llc -mtriple=riscv32 -mattr=+d -run-pass=instruction-select \
3 # RUN:   -simplify-mir -verify-machineinstrs %s -o - | FileCheck %s
4 # RUN: llc -mtriple=riscv64 -mattr=+d -run-pass=instruction-select \
5 # RUN:   -simplify-mir -verify-machineinstrs %s -o - | FileCheck %s
7 ---
8 name:            fpext
9 legalized:       true
10 regBankSelected: true
11 tracksRegLiveness: true
12 body:             |
13   bb.1:
14     liveins: $f10_f
16     ; CHECK-LABEL: name: fpext
17     ; CHECK: liveins: $f10_f
18     ; CHECK-NEXT: {{  $}}
19     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fpr32 = COPY $f10_f
20     ; CHECK-NEXT: [[FCVT_D_S:%[0-9]+]]:fpr64 = nofpexcept FCVT_D_S [[COPY]], 0
21     ; CHECK-NEXT: $f10_d = COPY [[FCVT_D_S]]
22     ; CHECK-NEXT: PseudoRET implicit $f10_d
23     %0:fprb(s32) = COPY $f10_f
24     %1:fprb(s64) = G_FPEXT %0(s32)
25     $f10_d = COPY %1(s64)
26     PseudoRET implicit $f10_d
28 ...
29 ---
30 name:            fptrunc
31 legalized:       true
32 regBankSelected: true
33 tracksRegLiveness: true
34 body:             |
35   bb.1:
36     liveins: $f10_d
38     ; CHECK-LABEL: name: fptrunc
39     ; CHECK: liveins: $f10_d
40     ; CHECK-NEXT: {{  $}}
41     ; CHECK-NEXT: [[COPY:%[0-9]+]]:fpr64 = COPY $f10_d
42     ; CHECK-NEXT: [[FCVT_S_D:%[0-9]+]]:fpr32 = nofpexcept FCVT_S_D [[COPY]], 7
43     ; CHECK-NEXT: $f10_f = COPY [[FCVT_S_D]]
44     ; CHECK-NEXT: PseudoRET implicit $f10_f
45     %0:fprb(s64) = COPY $f10_d
46     %1:fprb(s32) = G_FPTRUNC %0(s64)
47     $f10_f = COPY %1(s32)
48     PseudoRET implicit $f10_f
50 ...