[llvm] [RISCV] Move RISCVVMV0Elimination past pre-ra scheduling (PR #132057)

Philip Reames via llvm-commits llvm-commits at lists.llvm.org
Wed Mar 19 13:12:21 PDT 2025


preames wrote:

> 3\. We need to handle subregisters now whereas previously they didn't seem to show up

I went and looked into this.  The one and only case in check-llvm is the following:
```
  (function entry)
  %0:vrm2_with_sub_vrm1_0_in_vmv0 = COPY $v8m2
  ...
  %15:vrm8nov0 = PseudoVMERGE_VIM_M8 undef %15:vrm8nov0(tied-def 0), %12:vrm8, 1, %0.sub_vrm1_0:vrm2_with_sub_vrm1_0_in_vmv0, -1, 3
```
There doesn't seem to be anything too oddly specific about @foo from test/CodeGen/RISCV/rvv/pr88576.ll (which is where this came from).  This looks correct (i.e. is a valid subreg usage).  It is interesting that the use of the subregister bit ends up so narrow here.  Tracing through print-after-all, it looks like RegisterCoalescer eliminates a copy and creates the sub-register use.  


https://github.com/llvm/llvm-project/pull/132057


More information about the llvm-commits mailing list