From: Juergen Ributzka Date: Thu, 9 Jul 2015 17:11:15 +0000 (+0000) Subject: [StackMap] Use lambdas to specify the sort and erase conditions. NFC. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=c014920a89f39e9606e42ced600ef70caaca64c1;p=oota-llvm.git [StackMap] Use lambdas to specify the sort and erase conditions. NFC. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241823 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/CodeGen/StackMaps.h b/include/llvm/CodeGen/StackMaps.h index ff552237610..fdc1a9143ed 100644 --- a/include/llvm/CodeGen/StackMaps.h +++ b/include/llvm/CodeGen/StackMaps.h @@ -152,13 +152,6 @@ public: unsigned short DwarfRegNum; unsigned short Size; - void MarkInvalid() { Reg = 0; } - - // Only sort by the dwarf register number. - bool operator<(const LiveOutReg &LO) const { - return DwarfRegNum < LO.DwarfRegNum; - } - static bool IsInvalid(const LiveOutReg &LO) { return LO.Reg == 0; } LiveOutReg() : Reg(0), DwarfRegNum(0), Size(0) {} LiveOutReg(unsigned short Reg, unsigned short DwarfRegNum, unsigned short Size) diff --git a/lib/CodeGen/StackMaps.cpp b/lib/CodeGen/StackMaps.cpp index 5fe17a1889b..116eef66c58 100644 --- a/lib/CodeGen/StackMaps.cpp +++ b/lib/CodeGen/StackMaps.cpp @@ -248,10 +248,15 @@ StackMaps::parseRegisterLiveOutMask(const uint32_t *Mask) const { // We don't need to keep track of a register if its super-register is already // in the list. Merge entries that refer to the same dwarf register and use // the maximum size that needs to be spilled. - std::sort(LiveOuts.begin(), LiveOuts.end()); - for (LiveOutVec::iterator I = LiveOuts.begin(), E = LiveOuts.end(); I != E; - ++I) { - for (LiveOutVec::iterator II = std::next(I); II != E; ++II) { + + std::sort(LiveOuts.begin(), LiveOuts.end(), + [](const LiveOutReg &LHS, const LiveOutReg &RHS) { + // Only sort by the dwarf register number. + return LHS.DwarfRegNum < RHS.DwarfRegNum; + }); + + for (auto I = LiveOuts.begin(), E = LiveOuts.end(); I != E; ++I) { + for (auto II = std::next(I); II != E; ++II) { if (I->DwarfRegNum != II->DwarfRegNum) { // Skip all the now invalid entries. I = --II; @@ -260,12 +265,15 @@ StackMaps::parseRegisterLiveOutMask(const uint32_t *Mask) const { I->Size = std::max(I->Size, II->Size); if (TRI->isSuperRegister(I->Reg, II->Reg)) I->Reg = II->Reg; - II->MarkInvalid(); + II->Reg = 0; // mark for deletion. } } + LiveOuts.erase( - std::remove_if(LiveOuts.begin(), LiveOuts.end(), LiveOutReg::IsInvalid), + std::remove_if(LiveOuts.begin(), LiveOuts.end(), + [](const LiveOutReg &LO) { return LO.Reg == 0; }), LiveOuts.end()); + return LiveOuts; }