diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-06-07 18:18:12 +0000 |
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-06-07 18:18:12 +0000 |
| commit | ebe0be9ca46f4c856d42b86354073e492c1eeda8 (patch) | |
| tree | 17c4ff364396f964d6072347304ad3e2445174c9 /llvm/lib | |
| parent | 8d477dc08fa6b5650d68f4025511178671ebbeea (diff) | |
| download | bcm5719-llvm-ebe0be9ca46f4c856d42b86354073e492c1eeda8.tar.gz bcm5719-llvm-ebe0be9ca46f4c856d42b86354073e492c1eeda8.zip | |
Vincent says the element is at most once in the vector, so we don't need a full std::remove.
llvm-svn: 183541
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/R600/R600OptimizeVectorRegisters.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/llvm/lib/Target/R600/R600OptimizeVectorRegisters.cpp b/llvm/lib/Target/R600/R600OptimizeVectorRegisters.cpp index 0c123a101e7..726cfbcdf3e 100644 --- a/llvm/lib/Target/R600/R600OptimizeVectorRegisters.cpp +++ b/llvm/lib/Target/R600/R600OptimizeVectorRegisters.cpp @@ -198,9 +198,13 @@ MachineInstr *R600VectorRegMerger::RebuildVector( .addReg(SubReg) .addImm(Chan); UpdatedRegToChan[SubReg] = Chan; - UpdatedUndef.erase( - std::remove(UpdatedUndef.begin(), UpdatedUndef.end(), Chan), - UpdatedUndef.end()); + std::vector<unsigned>::iterator ChanPos = + std::find(UpdatedUndef.begin(), UpdatedUndef.end(), Chan); + if (ChanPos != UpdatedUndef.end()) + UpdatedUndef.erase(ChanPos); + assert(std::find(UpdatedUndef.begin(), UpdatedUndef.end(), Chan) == + UpdatedUndef.end() && + "UpdatedUndef shouldn't contain Chan more than once!"); DEBUG(dbgs() << " ->"; Tmp->dump();); (void)Tmp; SrcVec = DstReg; |

