From a2495d9c5ab976232edf677ef147d6dee63fcb8c Mon Sep 17 00:00:00 2001 From: "Duncan P. N. Exon Smith" Date: Wed, 20 Apr 2016 20:03:59 +0000 Subject: [PATCH] IR: Stop copying vectors of TrackingMDRef in DIBuilder No real functionality change here, just avoiding an unnecessary copy of std::vector for every subprogram with variables. llvm-svn: 266907 --- llvm/lib/IR/DIBuilder.cpp | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/llvm/lib/IR/DIBuilder.cpp b/llvm/lib/IR/DIBuilder.cpp index 23a822b577b3..690918ce8a69 100644 --- a/llvm/lib/IR/DIBuilder.cpp +++ b/llvm/lib/IR/DIBuilder.cpp @@ -97,12 +97,18 @@ void DIBuilder::finalize() { DISubprogramArray SPs = MDTuple::get(VMContext, AllSubprograms); auto resolveVariables = [&](DISubprogram *SP) { - if (MDTuple *Temp = SP->getVariables().get()) { - const auto &PV = PreservedVariables.lookup(SP); - SmallVector Variables(PV.begin(), PV.end()); - DINodeArray AV = getOrCreateArray(Variables); - TempMDTuple(Temp)->replaceAllUsesWith(AV.get()); - } + MDTuple *Temp = SP->getVariables().get(); + if (!Temp) + return; + + SmallVector Variables; + + auto PV = PreservedVariables.find(SP); + if (PV != PreservedVariables.end()) + Variables.append(PV->second.begin(), PV->second.end()); + + DINodeArray AV = getOrCreateArray(Variables); + TempMDTuple(Temp)->replaceAllUsesWith(AV.get()); }; for (auto *SP : SPs) resolveVariables(SP);