diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2023-04-12 19:09:17 -0400 |
---|---|---|
committer | Matt Arsenault <arsenm2@gmail.com> | 2023-04-14 14:36:56 -0400 |
commit | 409ef45000185d74b695a7dc94f5aeac0c4422d7 (patch) | |
tree | 7800823ee6444a0de10eb6b950ea278f99d816e0 /llvm/lib/Analysis/ValueTracking.cpp | |
parent | c603fd2f39beab13cd1df700467afcc324ec1d85 (diff) | |
download | llvm-409ef45000185d74b695a7dc94f5aeac0c4422d7.zip llvm-409ef45000185d74b695a7dc94f5aeac0c4422d7.tar.gz llvm-409ef45000185d74b695a7dc94f5aeac0c4422d7.tar.bz2 |
ValueTracking: Handle extractelement and extractvalue in computeKnownFPClass
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index 48a9dc1..545ff49 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -4524,6 +4524,29 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts, break; } + case Instruction::ExtractElement: { + // Look through extract element. If the index is non-constant or + // out-of-range demand all elements, otherwise just the extracted element. + const Value *Vec = Op->getOperand(0); + const Value *Idx = Op->getOperand(1); + auto *CIdx = dyn_cast<ConstantInt>(Idx); + + if (auto *VecTy = dyn_cast<FixedVectorType>(Vec->getType())) { + unsigned NumElts = VecTy->getNumElements(); + APInt DemandedVecElts = APInt::getAllOnes(NumElts); + if (CIdx && CIdx->getValue().ult(NumElts)) + DemandedVecElts = APInt::getOneBitSet(NumElts, CIdx->getZExtValue()); + return computeKnownFPClass(Vec, DemandedVecElts, InterestedClasses, Known, + Depth + 1, Q, TLI); + } + + break; + } + case Instruction::ExtractValue: { + computeKnownFPClass(Op->getOperand(0), DemandedElts, InterestedClasses, + Known, Depth + 1, Q, TLI); + break; + } default: break; } |