aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Transforms/Utils/Local.cpp
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@sifive.com>2021-03-10 09:46:16 -0800
committerCraig Topper <craig.topper@sifive.com>2021-03-10 09:46:18 -0800
commit9106d04554026c94070528d164965e62ff54ceed (patch)
tree7423e407c05eaa5aec93ed3da9e7a761af2d3ccd /llvm/lib/Transforms/Utils/Local.cpp
parent0c73a506e809be24e043856259fc07cef64f02b0 (diff)
downloadllvm-9106d04554026c94070528d164965e62ff54ceed.zip
llvm-9106d04554026c94070528d164965e62ff54ceed.tar.gz
llvm-9106d04554026c94070528d164965e62ff54ceed.tar.bz2
[RISCV][SelectionDAG] Introduce an ISD::SPLAT_VECTOR_PARTS node that can represent a splat of 2 i32 values into a nxvXi64 vector for riscv32.
On riscv32, i64 isn't a legal scalar type but we would like to support scalable vectors of i64. This patch introduces a new node that can represent a splat made of multiple scalar values. I've used this new node to solve the current crashes we experience when getConstant is used after type legalization. For RISCV, we are now default expanding SPLAT_VECTOR to SPLAT_VECTOR_PARTS when needed and then handling the SPLAT_VECTOR_PARTS later during LegalizeOps. I've remove the special case I previously put in for ABS for D97991 as the default expansion is now able to succesfully use getConstant. Reviewed By: frasercrmck Differential Revision: https://reviews.llvm.org/D98004
Diffstat (limited to 'llvm/lib/Transforms/Utils/Local.cpp')
0 files changed, 0 insertions, 0 deletions