[llvm] r222965 - Make MultiClass::DefPrototypes own their Records to fix memory leaks.
David Blaikie
dblaikie at gmail.com
Wed Dec 3 13:04:54 PST 2014
On Sat, Nov 29, 2014 at 4:19 PM, Craig Topper <craig.topper at gmail.com>
wrote:
> Author: ctopper
> Date: Sat Nov 29 18:19:28 2014
> New Revision: 222965
>
> URL: http://llvm.org/viewvc/llvm-project?rev=222965&view=rev
> Log:
> Make MultiClass::DefPrototypes own their Records to fix memory leaks.
>
> Modified:
> llvm/trunk/include/llvm/TableGen/Record.h
> llvm/trunk/lib/TableGen/TGParser.cpp
>
> Modified: llvm/trunk/include/llvm/TableGen/Record.h
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/TableGen/Record.h?rev=222965&r1=222964&r2=222965&view=diff
>
> ==============================================================================
> --- llvm/trunk/include/llvm/TableGen/Record.h (original)
> +++ llvm/trunk/include/llvm/TableGen/Record.h Sat Nov 29 18:19:28 2014
> @@ -1663,7 +1663,7 @@ raw_ostream &operator<<(raw_ostream &OS,
>
> struct MultiClass {
> Record Rec; // Placeholder for template args and Name.
> - typedef std::vector<Record*> RecordVector;
> + typedef std::vector<std::unique_ptr<Record>> RecordVector;
>
Any chance of deque<Record> (or forward_list<Record> or list<Record>) here?
> RecordVector DefPrototypes;
>
> void dump() const;
>
> Modified: llvm/trunk/lib/TableGen/TGParser.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/TableGen/TGParser.cpp?rev=222965&r1=222964&r2=222965&view=diff
>
> ==============================================================================
> --- llvm/trunk/lib/TableGen/TGParser.cpp (original)
> +++ llvm/trunk/lib/TableGen/TGParser.cpp Sat Nov 29 18:19:28 2014
> @@ -239,7 +239,7 @@ bool TGParser::AddSubMultiClass(MultiCla
> if (AddValue(NewDef.get(), SubMultiClass.RefRange.Start, MCVals[i]))
> return true;
>
> - CurMC->DefPrototypes.push_back(NewDef.release());
> + CurMC->DefPrototypes.push_back(std::move(NewDef));
> }
>
> const std::vector<Init *> &SMCTArgs = SMC->Rec.getTemplateArgs();
> @@ -274,7 +274,7 @@ bool TGParser::AddSubMultiClass(MultiCla
> jend = CurMC->DefPrototypes.end();
> j != jend;
> ++j) {
> - Record *Def = *j;
> + Record *Def = j->get();
>
> if (SetValue(Def, SubMultiClass.RefRange.Start, SMCTArgs[i],
> std::vector<unsigned>(),
> @@ -1258,7 +1258,7 @@ Init *TGParser::ParseSimpleValue(Record
> // known before any use.
> NewRec->setResolveFirst(true);
> // Otherwise, we're inside a multiclass, add it to the multiclass.
> - CurMultiClass->DefPrototypes.push_back(NewRecOwner.release());
> + CurMultiClass->DefPrototypes.push_back(std::move(NewRecOwner));
>
> // Copy the template arguments for the multiclass into the def.
> const std::vector<Init *> &TArgs =
> @@ -2063,7 +2063,7 @@ bool TGParser::ParseDef(MultiClass *CurM
> == CurRec->getNameInit())
> return Error(DefLoc, "def '" + CurRec->getNameInitAsString() +
> "' already defined in this multiclass!");
> - CurMultiClass->DefPrototypes.push_back(CurRecOwner.release());
> + CurMultiClass->DefPrototypes.push_back(std::move(CurRecOwner));
> } else if (ParseObjectBody(CurRec)) {
> return true;
> }
> @@ -2507,7 +2507,7 @@ bool TGParser::ResolveMulticlassDef(Mult
> == CurRec->getNameInit())
> return Error(DefmPrefixLoc, "defm '" +
> CurRec->getNameInitAsString() +
> "' already defined in this multiclass!");
> - CurMultiClass->DefPrototypes.push_back(CurRec);
> + CurMultiClass->DefPrototypes.push_back(std::unique_ptr<Record>(CurRec));
>
> // Copy the template arguments for the multiclass into the new def.
> const std::vector<Init *> &TA =
> @@ -2570,7 +2570,7 @@ bool TGParser::ParseDefm(MultiClass *Cur
>
> // Loop over all the def's in the multiclass, instantiating each one.
> for (unsigned i = 0, e = MC->DefPrototypes.size(); i != e; ++i) {
> - Record *DefProto = MC->DefPrototypes[i];
> + Record *DefProto = MC->DefPrototypes[i].get();
>
> Record *CurRec = InstantiateMulticlassDef(*MC, DefProto, DefmPrefix,
> SMRange(DefmLoc,
>
>
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20141203/4dd5b685/attachment.html>
More information about the llvm-commits
mailing list