aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis
diff options
context:
space:
mode:
authorLuke Lau <luke@igalia.com>2025-05-29 15:01:28 +0100
committerGitHub <noreply@github.com>2025-05-29 15:01:28 +0100
commit64106581b9d4f68eb4911c402b12b154d77a9eb0 (patch)
tree7661578046ddd74353ed7fc4d3594001917f27ed /llvm/lib/Analysis
parenta5d97ebe8b65f5a94975c013df6dd5fe11e8c652 (diff)
downloadllvm-64106581b9d4f68eb4911c402b12b154d77a9eb0.zip
llvm-64106581b9d4f68eb4911c402b12b154d77a9eb0.tar.gz
llvm-64106581b9d4f68eb4911c402b12b154d77a9eb0.tar.bz2
[Constant] Make Constant::getSplatValue return poison on poison (#141870)
This is a follow up from #141845. TargetTransformInfo::getOperandInfo needs to be updated to check for undef values as otherwise a splat is considered a constant, and some RISC-V cost model tests will start adding a cost to materialize the constant.
Diffstat (limited to 'llvm/lib/Analysis')
-rw-r--r--llvm/lib/Analysis/ConstantFolding.cpp5
-rw-r--r--llvm/lib/Analysis/TargetTransformInfo.cpp4
2 files changed, 4 insertions, 5 deletions
diff --git a/llvm/lib/Analysis/ConstantFolding.cpp b/llvm/lib/Analysis/ConstantFolding.cpp
index 40302fb..2476dc5 100644
--- a/llvm/lib/Analysis/ConstantFolding.cpp
+++ b/llvm/lib/Analysis/ConstantFolding.cpp
@@ -3794,11 +3794,6 @@ static Constant *ConstantFoldScalableVectorCall(
SplatOps.push_back(Op);
continue;
}
- // TODO: Should getSplatValue return a poison scalar for a poison vector?
- if (isa<PoisonValue>(Op)) {
- SplatOps.push_back(PoisonValue::get(Op->getType()->getScalarType()));
- continue;
- }
Constant *Splat = Op->getSplatValue();
if (!Splat)
return nullptr;
diff --git a/llvm/lib/Analysis/TargetTransformInfo.cpp b/llvm/lib/Analysis/TargetTransformInfo.cpp
index 0f85739..2d053e5 100644
--- a/llvm/lib/Analysis/TargetTransformInfo.cpp
+++ b/llvm/lib/Analysis/TargetTransformInfo.cpp
@@ -886,6 +886,10 @@ TargetTransformInfo::getOperandInfo(const Value *V) {
OperandValueKind OpInfo = OK_AnyValue;
OperandValueProperties OpProps = OP_None;
+ // undef/poison don't materialize constants.
+ if (isa<UndefValue>(V))
+ return {OK_AnyValue, OP_None};
+
if (isa<ConstantInt>(V) || isa<ConstantFP>(V)) {
if (const auto *CI = dyn_cast<ConstantInt>(V)) {
if (CI->getValue().isPowerOf2())