diff options
author | Hal Finkel <hfinkel@anl.gov> | 2013-04-10 22:05:25 +0000 |
---|---|---|
committer | Hal Finkel <hfinkel@anl.gov> | 2013-04-10 22:05:25 +0000 |
commit | 9af7014019c971368d541870b108aef1f12a24ba (patch) | |
tree | ee3ba7278d270093bd1fe0e2a49fe5ed145671e0 /unittests | |
parent | 3c08eef20b9cfc31d4ae3a43f1c9a57a4ab2cad7 (diff) | |
download | external_llvm-9af7014019c971368d541870b108aef1f12a24ba.zip external_llvm-9af7014019c971368d541870b108aef1f12a24ba.tar.gz external_llvm-9af7014019c971368d541870b108aef1f12a24ba.tar.bz2 |
Manually remove successors in if conversion when CopyAndPredicateBlock is used
In the simple and triangle if-conversion cases, when CopyAndPredicateBlock is
used because the to-be-predicated block has other predecessors, we need to
explicitly remove the old copied block from the successors list. Normally if
conversion relies on TII->AnalyzeBranch combined with BB->CorrectExtraCFGEdges
to cleanup the successors list, but if the predicated block contained an
un-analyzable branch (such as a now-predicated return), then this will fail.
These extra successors were causing a problem on PPC because it was causing
later passes (such as PPCEarlyReturm) to leave dead return-only basic blocks in
the code.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@179227 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'unittests')
0 files changed, 0 insertions, 0 deletions