From 4f4ef15ade487778e6b290e7ad91bd293662c78d Mon Sep 17 00:00:00 2001 From: Rafael Espindola Date: Mon, 9 Mar 2015 22:08:37 +0000 Subject: Use a MapVector instead of an extra sort. This also has the advantage of not depending on the brittle getLabelBeginName. llvm-svn: 231714 --- llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | 31 ++++++++---------------------- 1 file changed, 8 insertions(+), 23 deletions(-) (limited to 'llvm/lib/CodeGen') diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp index 04dedbd3f65..a4e5b8d3aab 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp @@ -287,13 +287,6 @@ static StringRef getObjCMethodName(StringRef In) { return In.slice(In.find(' ') + 1, In.find(']')); } -// Helper for sorting sections into a stable output order. -static bool SectionSort(const MCSection *A, const MCSection *B) { - std::string LA = (A ? A->getLabelBeginName() : ""); - std::string LB = (B ? B->getLabelBeginName() : ""); - return LA < LB; -} - // Add the various names to the Dwarf accelerator table names. // TODO: Determine whether or not we should add names for programs // that do not have a DW_AT_name or DW_AT_linkage_name field - this @@ -1739,7 +1732,7 @@ struct ArangeSpan { // address we can tie back to a CU. void DwarfDebug::emitDebugARanges() { // Provides a unique id per text section. - DenseMap> SectionMap; + MapVector> SectionMap; // Filter labels by section. for (const SymbolCU &SCU : ArangeLabels) { @@ -1756,20 +1749,10 @@ void DwarfDebug::emitDebugARanges() { } } - // Build a list of sections used. - std::vector Sections; - for (const auto &it : SectionMap) { - const MCSection *Section = it.first; - Sections.push_back(Section); - } - - // Sort the sections into order. - // This is only done to ensure consistent output order across different runs. - std::sort(Sections.begin(), Sections.end(), SectionSort); - // Add terminating symbols for each section. - for (unsigned ID = 0, E = Sections.size(); ID != E; ID++) { - const MCSection *Section = Sections[ID]; + unsigned ID = 0; + for (const auto &I : SectionMap) { + const MCSection *Section = I.first; MCSymbol *Sym = nullptr; if (Section) { @@ -1784,12 +1767,14 @@ void DwarfDebug::emitDebugARanges() { // Insert a final terminator. SectionMap[Section].push_back(SymbolCU(nullptr, Sym)); + ++ID; } DenseMap> Spans; - for (const MCSection *Section : Sections) { - SmallVector &List = SectionMap[Section]; + for (auto &I : SectionMap) { + const MCSection *Section = I.first; + SmallVector &List = I.second; if (List.size() < 2) continue; -- cgit v1.2.3