From: Eric Christopher Date: Tue, 14 Jan 2014 22:44:17 +0000 (+0000) Subject: Enable use of ranges for translation units in the presence of X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6389abdd02bd3d7749770104c99fca76a80c9115;p=oota-llvm.git Enable use of ranges for translation units in the presence of -ffunction-sections and update comments and TODOs about other places that we should enable this. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@199263 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/AsmPrinter/DwarfDebug.cpp b/lib/CodeGen/AsmPrinter/DwarfDebug.cpp index f2cc172efa7..c895f17931d 100644 --- a/lib/CodeGen/AsmPrinter/DwarfDebug.cpp +++ b/lib/CodeGen/AsmPrinter/DwarfDebug.cpp @@ -1050,13 +1050,15 @@ void DwarfDebug::finalizeModuleInfo() { dwarf::DW_FORM_data8, ID); } - // If we've requested ranges and have them emit a DW_AT_ranges attribute - // on the unit that will remain in the .o file, otherwise add a - // DW_AT_low_pc. + // If we have code split among multiple sections or we've requested + // it then emit a DW_AT_ranges attribute on the unit that will remain + // in the .o file, otherwise add a DW_AT_low_pc. // FIXME: Also add a high pc if we can. - // FIXME: We should use ranges if we have multiple compile units. + // FIXME: We should use ranges if we have multiple compile units or + // allow reordering of code ala .subsections_via_symbols in mach-o. DwarfCompileUnit *U = SkCU ? SkCU : static_cast(TheU); - if (DwarfCURanges && TheU->getRanges().size()) + if ((DwarfCURanges || TargetMachine::getFunctionSections()) && + TheU->getRanges().size()) addSectionLabel(Asm, U, U->getUnitDie(), dwarf::DW_AT_ranges, Asm->GetTempSymbol("cu_ranges", U->getUniqueID()), DwarfDebugRangeSectionSym);