diff options
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/BranchFolding.cpp | 10 | 
1 files changed, 7 insertions, 3 deletions
| diff --git a/llvm/lib/CodeGen/BranchFolding.cpp b/llvm/lib/CodeGen/BranchFolding.cpp index af5fbd1202a..871d6dc5765 100644 --- a/llvm/lib/CodeGen/BranchFolding.cpp +++ b/llvm/lib/CodeGen/BranchFolding.cpp @@ -197,7 +197,6 @@ bool BranchFolder::OptimizeFunction(MachineFunction &MF,      MadeChange |= OptimizeImpDefsBlock(MBB);    } -    bool MadeChangeThisIteration = true;    while (MadeChangeThisIteration) {      MadeChangeThisIteration = false; @@ -206,10 +205,15 @@ bool BranchFolder::OptimizeFunction(MachineFunction &MF,      MadeChange |= MadeChangeThisIteration;    } -  // Do tail duplication once after tail merging is done.  Otherwise it is +  // Do tail duplication after tail merging is done.  Otherwise it is    // tough to avoid situations where tail duplication and tail merging undo    // each other's transformations ad infinitum. -  MadeChange |= TailDuplicateBlocks(MF); +  MadeChangeThisIteration = true; +  while (MadeChangeThisIteration) { +    MadeChangeThisIteration = false; +    MadeChangeThisIteration |= TailDuplicateBlocks(MF); +    MadeChange |= MadeChangeThisIteration; +  }    // See if any jump tables have become mergable or dead as the code generator    // did its thing. | 

