[llvm] [LV] Use original trip-count as the vector-trip-count if use predicated EVL instructions for tail-folding. (PR #132675)

Alexey Bataev via llvm-commits llvm-commits at lists.llvm.org
Mon Mar 31 04:39:04 PDT 2025


alexey-bataev wrote:

> > > I thought the consensus is that we want to keep canonical IV alive through the entire duration of loop vectorizer. And that's exactly why I chose to add a Pass right after LV to replace canonical IV with EVL IV in #131005
> > 
> > 
> > I understand but why we should keep the canonical IV? I did a similar change based on llvm-epi and haven't encounter any problem yet.
> 
> No bug, but that doesn’t mean it’s reasonable.
> 
> RVV specification defines: `ceil(AVL / 2) ≤ vl ≤ VLMAX` if `AVL < (2 * VLMAX)`. But currently, all RVV implementations simply use `vl = min(AVL, VLMAX)`. At least, I haven't encountered an RVV implementation that isn't done this way.

At least QEMU supports it via `--rvv-vl-half-avl` option. Plus, the spec is the spec, we should generate correct code, which should be portable across different RISC-V hardware, that follows the spec

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


More information about the llvm-commits mailing list