aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
Diffstat (limited to 'lib')
-rw-r--r--lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp17
1 files changed, 12 insertions, 5 deletions
diff --git a/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp b/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
index 59e433b..00b91e7 100644
--- a/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
+++ b/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
@@ -1349,12 +1349,19 @@ void CompileUnit::createGlobalVariableDIE(const MDNode *N) {
// Add linkage name.
StringRef LinkageName = GV.getLinkageName();
if (!LinkageName.empty() && isGlobalVariable) {
- addString(VariableDIE, dwarf::DW_AT_MIPS_linkage_name,
+ // From dwarf-4: DIE to which DW_AT_linkage_name may apply include:
+ // TAG_commono_block, TAG_constant, TAG_entry_point, TAG_subporgram and
+ // TAG_variable. For static member variables, gcc 4.7 puts
+ // MIPS_linkage_name on the definition DIE only, but Darwin gdb needs
+ // MIPS_linkage_name at both places.
+ // Per discussion with Eric, for static member variables, we put
+ // MIPS_linkage_name on the definition DIE (TAG_variable) and conditionaly
+ // put MIPS_linkage_name on TAG_member when DarwinGDBCompat is on.
+ addString(IsStaticMember && VariableSpecDIE ?
+ VariableSpecDIE : VariableDIE, dwarf::DW_AT_MIPS_linkage_name,
getRealLinkageName(LinkageName));
- // To make old GDB happy, for static member variables, we add
- // AT_MIPS_linkage_name to the definition DIE as well.
- if (IsStaticMember && VariableSpecDIE)
- addString(VariableSpecDIE, dwarf::DW_AT_MIPS_linkage_name,
+ if (IsStaticMember && VariableSpecDIE && DD->useDarwinGDBCompat())
+ addString(VariableDIE, dwarf::DW_AT_MIPS_linkage_name,
getRealLinkageName(LinkageName));
}
} else if (const ConstantInt *CI =