# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py # RUN: llc -mtriple=riscv32 -run-pass=regbankselect \ # RUN: -disable-gisel-legality-check -simplify-mir -verify-machineinstrs %s \ # RUN: -o - | FileCheck -check-prefixes=RV32 %s # RUN: llc -mtriple=riscv64 -run-pass=regbankselect \ # RUN: -disable-gisel-legality-check -simplify-mir -verify-machineinstrs %s \ # RUN: -o - | FileCheck -check-prefixes=RV64 %s ... --- name: test_ret_nxv1i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv4i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv8i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv8i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv16i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv16i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv32i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv32i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv32i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv64i8 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv64i8 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv64i8 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv4i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv8i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv8i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv16i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv16i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv32i16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv32i16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv32i16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1i32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1i32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1i32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2i32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2i32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2i32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4i32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4i32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv4i32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv8i32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8i32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv8i32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv16i32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16i32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv16i32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1i64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1i64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1i64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2i64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2i64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv2i64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv4i64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4i64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv4i64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv8i64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8i64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv8i64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv64i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv64i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv64i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv32i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv32i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv32i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv16i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv16i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv8i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv8i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv4i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv1i1 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1i1 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1i1 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv1f32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1f32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1f32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2f32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2f32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2f32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4f32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4f32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv4f32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv8f32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8f32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv8f32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv16f32 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16f32 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv16f32 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1f64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1f64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1f64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2f64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2f64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv2f64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv4f64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4f64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv4f64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv8f64 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8f64 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv8f64 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv4f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv8f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv8f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv16f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv16f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv32f16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv32f16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv32f16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ... --- name: test_ret_nxv1b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv1b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv1b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv2b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv2b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv2b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv4b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv4b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8 ; ; RV64-LABEL: name: test_ret_nxv4b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8 %0:_() = COPY $v8 $v8 = COPY %0() PseudoRET implicit $v8 ... --- name: test_ret_nxv8b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv8b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m2 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m2 ; ; RV64-LABEL: name: test_ret_nxv8b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m2 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m2 %0:_() = COPY $v8 $v8m2 = COPY %0() PseudoRET implicit $v8m2 ... --- name: test_ret_nxv16b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv16b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m4 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m4 ; ; RV64-LABEL: name: test_ret_nxv16b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m4 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m4 %0:_() = COPY $v8 $v8m4 = COPY %0() PseudoRET implicit $v8m4 ... --- name: test_ret_nxv32b16 legalized: true tracksRegLiveness: true body: | bb.1.entry: liveins: $v8 ; RV32-LABEL: name: test_ret_nxv32b16 ; RV32: liveins: $v8 ; RV32-NEXT: {{ $}} ; RV32-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV32-NEXT: $v8m8 = COPY [[COPY]]() ; RV32-NEXT: PseudoRET implicit $v8m8 ; ; RV64-LABEL: name: test_ret_nxv32b16 ; RV64: liveins: $v8 ; RV64-NEXT: {{ $}} ; RV64-NEXT: [[COPY:%[0-9]+]]:vrb() = COPY $v8 ; RV64-NEXT: $v8m8 = COPY [[COPY]]() ; RV64-NEXT: PseudoRET implicit $v8m8 %0:_() = COPY $v8 $v8m8 = COPY %0() PseudoRET implicit $v8m8 ...