diff options
author | Finn Plummer <50529406+inbelic@users.noreply.github.com> | 2024-11-21 11:04:25 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-11-21 11:04:25 -0800 |
commit | 8663b8777e8108f74f91a2a33115b3a00d57c043 (patch) | |
tree | 0bc597295dadaf7e05bac98ed05b6512ee05b958 /llvm/lib/Analysis/VectorUtils.cpp | |
parent | f7497b10f7face081cc5ae2528276d919a5c6ca2 (diff) | |
download | llvm-8663b8777e8108f74f91a2a33115b3a00d57c043.zip llvm-8663b8777e8108f74f91a2a33115b3a00d57c043.tar.gz llvm-8663b8777e8108f74f91a2a33115b3a00d57c043.tar.bz2 |
[NFC][VectorUtils][TargetTransformInfo] Add `isVectorIntrinsicWithOverloadTypeAtArg` api (#114849)
This changes allows target intrinsics to specify and overwrite overloaded types.
- Updates `ReplaceWithVecLib` to not provide TTI as there most probably won't be a use-case
- Updates `SLPVectorizer` to use available TTI
- Updates `VPTransformState` to pass down TTI
- Updates `VPlanRecipe` to use passed-down TTI
This change will let us add scalarization for `asdouble`: #114847
Diffstat (limited to 'llvm/lib/Analysis/VectorUtils.cpp')
-rw-r--r-- | llvm/lib/Analysis/VectorUtils.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/llvm/lib/Analysis/VectorUtils.cpp b/llvm/lib/Analysis/VectorUtils.cpp index 15e325a..1789671 100644 --- a/llvm/lib/Analysis/VectorUtils.cpp +++ b/llvm/lib/Analysis/VectorUtils.cpp @@ -133,10 +133,13 @@ bool llvm::isVectorIntrinsicWithScalarOpAtArg(Intrinsic::ID ID, } } -bool llvm::isVectorIntrinsicWithOverloadTypeAtArg(Intrinsic::ID ID, - int OpdIdx) { +bool llvm::isVectorIntrinsicWithOverloadTypeAtArg( + Intrinsic::ID ID, int OpdIdx, const TargetTransformInfo *TTI) { assert(ID != Intrinsic::not_intrinsic && "Not an intrinsic!"); + if (TTI && Intrinsic::isTargetIntrinsic(ID)) + return TTI->isVectorIntrinsicWithOverloadTypeAtArg(ID, OpdIdx); + switch (ID) { case Intrinsic::fptosi_sat: case Intrinsic::fptoui_sat: |