aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2023-04-12 19:09:17 -0400
committerMatt Arsenault <arsenm2@gmail.com>2023-04-14 14:36:56 -0400
commit409ef45000185d74b695a7dc94f5aeac0c4422d7 (patch)
tree7800823ee6444a0de10eb6b950ea278f99d816e0 /llvm/lib/Analysis/ValueTracking.cpp
parentc603fd2f39beab13cd1df700467afcc324ec1d85 (diff)
downloadllvm-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.cpp23
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;
}