mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-04 10:30:01 +00:00
Fix future bug. Of course, Chris spotted this.
Handle Argument or Undef as an incoming PHI value. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35821 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
24a1c49172
commit
cfde9594d1
@ -369,7 +369,6 @@ bool LoopRotate::rotateLoop(Loop *Lp, LPPassManager &LPM) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
/// Make sure all Exit block PHINodes have required incoming values.
|
||||
/// If incoming value is constant or defined outside the loop then
|
||||
/// PHINode may not have an entry for new pre-header.
|
||||
@ -382,20 +381,22 @@ void LoopRotate::updateExitBlock() {
|
||||
if (!PN)
|
||||
break;
|
||||
|
||||
if (PN->getBasicBlockIndex(NewPreHeader) == -1) {
|
||||
Value *V = PN->getIncomingValueForBlock(OrigHeader);
|
||||
if (isa<Constant>(V))
|
||||
PN->addIncoming(V, NewPreHeader);
|
||||
else {
|
||||
RenameData *ILoopHeaderInfo = findReplacementData(cast<Instruction>(V));
|
||||
assert (ILoopHeaderInfo && ILoopHeaderInfo->PreHeader && "Missing New Preheader Instruction");
|
||||
PN->addIncoming(ILoopHeaderInfo->PreHeader, NewPreHeader);
|
||||
}
|
||||
// There is already one incoming value from new pre-header block.
|
||||
if (PN->getBasicBlockIndex(NewPreHeader) != -1)
|
||||
return;
|
||||
|
||||
RenameData *ILoopHeaderInfo;
|
||||
Value *V = PN->getIncomingValueForBlock(OrigHeader);
|
||||
if (isa<Instruction>(V) &&
|
||||
(ILoopHeaderInfo = findReplacementData(cast<Instruction>(V)))) {
|
||||
assert (ILoopHeaderInfo->PreHeader && "Missing New Preheader Instruction");
|
||||
PN->addIncoming(ILoopHeaderInfo->PreHeader, NewPreHeader);
|
||||
} else {
|
||||
PN->addIncoming(V, NewPreHeader);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/// Initialize local data
|
||||
void LoopRotate::initialize() {
|
||||
L = NULL;
|
||||
|
Loading…
x
Reference in New Issue
Block a user