diff options
author | Johannes Doerfert <johannes@jdoerfert.de> | 2024-07-23 09:28:37 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-07-23 09:28:37 -0700 |
commit | f227dc9ca24296cec0878b92d5ad3f853417e264 (patch) | |
tree | db90b86483ceb35285e9024a665ed5dc201034c6 /llvm/lib/Transforms/Utils/BasicBlockUtils.cpp | |
parent | ca102b2114fa8a00096d71ff9fc3b1b218f0f01a (diff) | |
download | llvm-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.cpp | 11 |
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; } } |