mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-07 11:51:13 +00:00
simplify some logic further
llvm-svn: 23408
This commit is contained in:
parent
48df043325
commit
67437dce2c
@ -1041,7 +1041,6 @@ static bool FoldTwoEntryPHINode(PHINode *PN) {
|
||||
// that need to be moved to the dominating block.
|
||||
std::set<Instruction*> AggressiveInsts;
|
||||
|
||||
bool CanPromote = true;
|
||||
BasicBlock::iterator AfterPHIIt = BB->begin();
|
||||
while (isa<PHINode>(AfterPHIIt)) {
|
||||
PHINode *PN = cast<PHINode>(AfterPHIIt++);
|
||||
@ -1054,14 +1053,10 @@ static bool FoldTwoEntryPHINode(PHINode *PN) {
|
||||
&AggressiveInsts) ||
|
||||
!DominatesMergePoint(PN->getIncomingValue(1), BB,
|
||||
&AggressiveInsts)) {
|
||||
CanPromote = false;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
// Did we eliminate all PHI's?
|
||||
if (!CanPromote && AfterPHIIt != BB->begin())
|
||||
return false;
|
||||
|
||||
// If we all PHI nodes are promotable, check to make sure that all
|
||||
// instructions in the predecessor blocks can be promoted as well. If
|
||||
// not, we won't be able to get rid of the control flow, so it's not
|
||||
|
Loading…
Reference in New Issue
Block a user