aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp
diff options
context:
space:
mode:
authorJohannes Doerfert <johannes@jdoerfert.de>2024-07-23 09:28:37 -0700
committerGitHub <noreply@github.com>2024-07-23 09:28:37 -0700
commitf227dc9ca24296cec0878b92d5ad3f853417e264 (patch)
treedb90b86483ceb35285e9024a665ed5dc201034c6 /llvm/lib/Transforms/Utils/BasicBlockUtils.cpp
parentca102b2114fa8a00096d71ff9fc3b1b218f0f01a (diff)
downloadllvm-f227dc9ca24296cec0878b92d5ad3f853417e264.zip
llvm-f227dc9ca24296cec0878b92d5ad3f853417e264.tar.gz
llvm-f227dc9ca24296cec0878b92d5ad3f853417e264.tar.bz2
[UnifyLoopExits] Never generate phis of only `undef` values (#99924)
Diffstat (limited to 'llvm/lib/Transforms/Utils/BasicBlockUtils.cpp')
-rw-r--r--llvm/lib/Transforms/Utils/BasicBlockUtils.cpp11
1 files changed, 9 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp b/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp
index 79911bf..c78965a 100644
--- a/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp
+++ b/llvm/lib/Transforms/Utils/BasicBlockUtils.cpp
@@ -1909,22 +1909,29 @@ static void reconnectPhis(BasicBlock *Out, BasicBlock *GuardBlock,
auto NewPhi =
PHINode::Create(Phi->getType(), Incoming.size(),
Phi->getName() + ".moved", FirstGuardBlock->begin());
+ bool AllUndef = true;
for (auto *In : Incoming) {
Value *V = UndefValue::get(Phi->getType());
if (In == Out) {
V = NewPhi;
} else if (Phi->getBasicBlockIndex(In) != -1) {
V = Phi->removeIncomingValue(In, false);
+ AllUndef &= isa<UndefValue>(V);
}
NewPhi->addIncoming(V, In);
}
assert(NewPhi->getNumIncomingValues() == Incoming.size());
+ Value *NewV = NewPhi;
+ if (AllUndef) {
+ NewPhi->eraseFromParent();
+ NewV = UndefValue::get(Phi->getType());
+ }
if (Phi->getNumOperands() == 0) {
- Phi->replaceAllUsesWith(NewPhi);
+ Phi->replaceAllUsesWith(NewV);
I = Phi->eraseFromParent();
continue;
}
- Phi->addIncoming(NewPhi, GuardBlock);
+ Phi->addIncoming(NewV, GuardBlock);
++I;
}
}