forked from OSchip/llvm-project
Add basic fission support to SymbolFileDWARF
* Create new dwo symbol file class * Add handling for .dwo sections * Change indexes in SymbolFileDWARF to store compile unit offset next to DIE offset * Propagate queries from dwarf compile unit to the dwo compile unit where applicable Differential revision: http://reviews.llvm.org/D12291 llvm-svn: 247132
This commit is contained in:
parent
715cbe8939
commit
eb882fc1f8
|
@ -368,7 +368,7 @@ public:
|
||||||
/// The list of sections contained in this object file.
|
/// The list of sections contained in this object file.
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
virtual SectionList *
|
virtual SectionList *
|
||||||
GetSectionList ();
|
GetSectionList (bool update_module_section_list = true);
|
||||||
|
|
||||||
virtual void
|
virtual void
|
||||||
CreateSections (SectionList &unified_section_list) = 0;
|
CreateSections (SectionList &unified_section_list) = 0;
|
||||||
|
|
|
@ -708,6 +708,9 @@
|
||||||
6D55BAEE1A8CD0B200A70529 /* PlatformAndroidRemoteGDBServer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D55BAEB1A8CD08C00A70529 /* PlatformAndroidRemoteGDBServer.cpp */; };
|
6D55BAEE1A8CD0B200A70529 /* PlatformAndroidRemoteGDBServer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D55BAEB1A8CD08C00A70529 /* PlatformAndroidRemoteGDBServer.cpp */; };
|
||||||
6D762BEE1B1605D2006C929D /* LLDBServerUtilities.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D762BEC1B1605CD006C929D /* LLDBServerUtilities.cpp */; };
|
6D762BEE1B1605D2006C929D /* LLDBServerUtilities.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D762BEC1B1605CD006C929D /* LLDBServerUtilities.cpp */; };
|
||||||
6D86CEA01B440F8500A7FBFA /* CommandObjectBugreport.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D86CE9E1B440F6B00A7FBFA /* CommandObjectBugreport.cpp */; };
|
6D86CEA01B440F8500A7FBFA /* CommandObjectBugreport.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D86CE9E1B440F6B00A7FBFA /* CommandObjectBugreport.cpp */; };
|
||||||
|
6D95DC001B9DC057000E318A /* DIERef.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D95DBFD1B9DC057000E318A /* DIERef.cpp */; };
|
||||||
|
6D95DC011B9DC057000E318A /* HashedNameToDIE.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D95DBFE1B9DC057000E318A /* HashedNameToDIE.cpp */; };
|
||||||
|
6D95DC021B9DC057000E318A /* SymbolFileDWARFDwo.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 6D95DBFF1B9DC057000E318A /* SymbolFileDWARFDwo.cpp */; };
|
||||||
8C2D6A53197A1EAF006989C9 /* MemoryHistory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8C2D6A52197A1EAF006989C9 /* MemoryHistory.cpp */; };
|
8C2D6A53197A1EAF006989C9 /* MemoryHistory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8C2D6A52197A1EAF006989C9 /* MemoryHistory.cpp */; };
|
||||||
8C2D6A5E197A250F006989C9 /* MemoryHistoryASan.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8C2D6A5A197A1FDC006989C9 /* MemoryHistoryASan.cpp */; };
|
8C2D6A5E197A250F006989C9 /* MemoryHistoryASan.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8C2D6A5A197A1FDC006989C9 /* MemoryHistoryASan.cpp */; };
|
||||||
8CCB017E19BA28A80009FD44 /* ThreadCollection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8CCB017A19BA283D0009FD44 /* ThreadCollection.cpp */; };
|
8CCB017E19BA28A80009FD44 /* ThreadCollection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 8CCB017A19BA283D0009FD44 /* ThreadCollection.cpp */; };
|
||||||
|
@ -2385,6 +2388,11 @@
|
||||||
6D762BED1B1605CD006C929D /* LLDBServerUtilities.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = LLDBServerUtilities.h; path = "tools/lldb-server/LLDBServerUtilities.h"; sourceTree = "<group>"; };
|
6D762BED1B1605CD006C929D /* LLDBServerUtilities.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = LLDBServerUtilities.h; path = "tools/lldb-server/LLDBServerUtilities.h"; sourceTree = "<group>"; };
|
||||||
6D86CE9E1B440F6B00A7FBFA /* CommandObjectBugreport.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = CommandObjectBugreport.cpp; path = source/Commands/CommandObjectBugreport.cpp; sourceTree = "<group>"; };
|
6D86CE9E1B440F6B00A7FBFA /* CommandObjectBugreport.cpp */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.cpp; name = CommandObjectBugreport.cpp; path = source/Commands/CommandObjectBugreport.cpp; sourceTree = "<group>"; };
|
||||||
6D86CE9F1B440F6B00A7FBFA /* CommandObjectBugreport.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = CommandObjectBugreport.h; path = source/Commands/CommandObjectBugreport.h; sourceTree = "<group>"; };
|
6D86CE9F1B440F6B00A7FBFA /* CommandObjectBugreport.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = CommandObjectBugreport.h; path = source/Commands/CommandObjectBugreport.h; sourceTree = "<group>"; };
|
||||||
|
6D95DBFD1B9DC057000E318A /* DIERef.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = DIERef.cpp; sourceTree = "<group>"; };
|
||||||
|
6D95DBFE1B9DC057000E318A /* HashedNameToDIE.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = HashedNameToDIE.cpp; sourceTree = "<group>"; };
|
||||||
|
6D95DBFF1B9DC057000E318A /* SymbolFileDWARFDwo.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = SymbolFileDWARFDwo.cpp; sourceTree = "<group>"; };
|
||||||
|
6D95DC031B9DC06F000E318A /* DIERef.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = DIERef.h; sourceTree = "<group>"; };
|
||||||
|
6D95DC041B9DC06F000E318A /* SymbolFileDWARFDwo.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = SymbolFileDWARFDwo.h; sourceTree = "<group>"; };
|
||||||
8C2D6A52197A1EAF006989C9 /* MemoryHistory.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = MemoryHistory.cpp; path = source/Target/MemoryHistory.cpp; sourceTree = "<group>"; };
|
8C2D6A52197A1EAF006989C9 /* MemoryHistory.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = MemoryHistory.cpp; path = source/Target/MemoryHistory.cpp; sourceTree = "<group>"; };
|
||||||
8C2D6A54197A1EBE006989C9 /* MemoryHistory.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = MemoryHistory.h; path = include/lldb/Target/MemoryHistory.h; sourceTree = "<group>"; };
|
8C2D6A54197A1EBE006989C9 /* MemoryHistory.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = MemoryHistory.h; path = include/lldb/Target/MemoryHistory.h; sourceTree = "<group>"; };
|
||||||
8C2D6A5A197A1FDC006989C9 /* MemoryHistoryASan.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MemoryHistoryASan.cpp; sourceTree = "<group>"; };
|
8C2D6A5A197A1FDC006989C9 /* MemoryHistoryASan.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = MemoryHistoryASan.cpp; sourceTree = "<group>"; };
|
||||||
|
@ -3115,6 +3123,11 @@
|
||||||
260C89B210F57C5600BB2B04 /* DWARF */ = {
|
260C89B210F57C5600BB2B04 /* DWARF */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
6D95DC031B9DC06F000E318A /* DIERef.h */,
|
||||||
|
6D95DC041B9DC06F000E318A /* SymbolFileDWARFDwo.h */,
|
||||||
|
6D95DBFD1B9DC057000E318A /* DIERef.cpp */,
|
||||||
|
6D95DBFE1B9DC057000E318A /* HashedNameToDIE.cpp */,
|
||||||
|
6D95DBFF1B9DC057000E318A /* SymbolFileDWARFDwo.cpp */,
|
||||||
260C89B310F57C5600BB2B04 /* DWARFAbbreviationDeclaration.cpp */,
|
260C89B310F57C5600BB2B04 /* DWARFAbbreviationDeclaration.cpp */,
|
||||||
260C89B410F57C5600BB2B04 /* DWARFAbbreviationDeclaration.h */,
|
260C89B410F57C5600BB2B04 /* DWARFAbbreviationDeclaration.h */,
|
||||||
269DDD451B8FD01A00D0DBD8 /* DWARFASTParser.h */,
|
269DDD451B8FD01A00D0DBD8 /* DWARFASTParser.h */,
|
||||||
|
@ -6258,6 +6271,7 @@
|
||||||
2689005C13353E0400698AC0 /* ValueObjectVariable.cpp in Sources */,
|
2689005C13353E0400698AC0 /* ValueObjectVariable.cpp in Sources */,
|
||||||
264A58EE1A7DBCAD00A6B1B0 /* OptionValueFormatEntity.cpp in Sources */,
|
264A58EE1A7DBCAD00A6B1B0 /* OptionValueFormatEntity.cpp in Sources */,
|
||||||
8C2D6A53197A1EAF006989C9 /* MemoryHistory.cpp in Sources */,
|
8C2D6A53197A1EAF006989C9 /* MemoryHistory.cpp in Sources */,
|
||||||
|
6D95DC021B9DC057000E318A /* SymbolFileDWARFDwo.cpp in Sources */,
|
||||||
942612F71B95000000EF842E /* LanguageCategory.cpp in Sources */,
|
942612F71B95000000EF842E /* LanguageCategory.cpp in Sources */,
|
||||||
2689005D13353E0400698AC0 /* VMRange.cpp in Sources */,
|
2689005D13353E0400698AC0 /* VMRange.cpp in Sources */,
|
||||||
2689005E13353E0E00698AC0 /* ClangASTSource.cpp in Sources */,
|
2689005E13353E0E00698AC0 /* ClangASTSource.cpp in Sources */,
|
||||||
|
@ -6319,6 +6333,7 @@
|
||||||
2689008313353E2200698AC0 /* CommandObjectMultiword.cpp in Sources */,
|
2689008313353E2200698AC0 /* CommandObjectMultiword.cpp in Sources */,
|
||||||
2689008413353E2200698AC0 /* CommandObjectRegexCommand.cpp in Sources */,
|
2689008413353E2200698AC0 /* CommandObjectRegexCommand.cpp in Sources */,
|
||||||
2689008513353E2200698AC0 /* CommandReturnObject.cpp in Sources */,
|
2689008513353E2200698AC0 /* CommandReturnObject.cpp in Sources */,
|
||||||
|
6D95DC001B9DC057000E318A /* DIERef.cpp in Sources */,
|
||||||
3FDFE53519A29327009756A7 /* HostInfoBase.cpp in Sources */,
|
3FDFE53519A29327009756A7 /* HostInfoBase.cpp in Sources */,
|
||||||
26474CBE18D0CB2D0073DEBA /* RegisterContextMach_i386.cpp in Sources */,
|
26474CBE18D0CB2D0073DEBA /* RegisterContextMach_i386.cpp in Sources */,
|
||||||
2689008613353E2200698AC0 /* Options.cpp in Sources */,
|
2689008613353E2200698AC0 /* Options.cpp in Sources */,
|
||||||
|
@ -6487,6 +6502,7 @@
|
||||||
26744EF31338317700EF765A /* GDBRemoteCommunicationServer.cpp in Sources */,
|
26744EF31338317700EF765A /* GDBRemoteCommunicationServer.cpp in Sources */,
|
||||||
264A97BF133918BC0017F0BE /* PlatformRemoteGDBServer.cpp in Sources */,
|
264A97BF133918BC0017F0BE /* PlatformRemoteGDBServer.cpp in Sources */,
|
||||||
EB8375E71B553DE800BA907D /* ThreadPlanCallFunctionUsingABI.cpp in Sources */,
|
EB8375E71B553DE800BA907D /* ThreadPlanCallFunctionUsingABI.cpp in Sources */,
|
||||||
|
6D95DC011B9DC057000E318A /* HashedNameToDIE.cpp in Sources */,
|
||||||
2697A54D133A6305004E4240 /* PlatformDarwin.cpp in Sources */,
|
2697A54D133A6305004E4240 /* PlatformDarwin.cpp in Sources */,
|
||||||
26651A18133BF9E0005B64B7 /* Opcode.cpp in Sources */,
|
26651A18133BF9E0005B64B7 /* Opcode.cpp in Sources */,
|
||||||
3FDFED0B19B7C8DE009756A7 /* HostThreadMacOSX.mm in Sources */,
|
3FDFED0B19B7C8DE009756A7 /* HostThreadMacOSX.mm in Sources */,
|
||||||
|
|
|
@ -1684,6 +1684,12 @@ ObjectFileELF::CreateSections(SectionList &unified_section_list)
|
||||||
static ConstString g_sect_name_dwarf_debug_ranges (".debug_ranges");
|
static ConstString g_sect_name_dwarf_debug_ranges (".debug_ranges");
|
||||||
static ConstString g_sect_name_dwarf_debug_str (".debug_str");
|
static ConstString g_sect_name_dwarf_debug_str (".debug_str");
|
||||||
static ConstString g_sect_name_dwarf_debug_str_offsets (".debug_str_offsets");
|
static ConstString g_sect_name_dwarf_debug_str_offsets (".debug_str_offsets");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_abbrev_dwo (".debug_abbrev.dwo");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_info_dwo (".debug_info.dwo");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_line_dwo (".debug_line.dwo");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_loc_dwo (".debug_loc.dwo");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_str_dwo (".debug_str.dwo");
|
||||||
|
static ConstString g_sect_name_dwarf_debug_str_offsets_dwo (".debug_str_offsets.dwo");
|
||||||
static ConstString g_sect_name_eh_frame (".eh_frame");
|
static ConstString g_sect_name_eh_frame (".eh_frame");
|
||||||
|
|
||||||
SectionType sect_type = eSectionTypeOther;
|
SectionType sect_type = eSectionTypeOther;
|
||||||
|
@ -1717,20 +1723,26 @@ ObjectFileELF::CreateSections(SectionList &unified_section_list)
|
||||||
// MISSING? .gnu_debugdata - "mini debuginfo / MiniDebugInfo" section, http://sourceware.org/gdb/onlinedocs/gdb/MiniDebugInfo.html
|
// MISSING? .gnu_debugdata - "mini debuginfo / MiniDebugInfo" section, http://sourceware.org/gdb/onlinedocs/gdb/MiniDebugInfo.html
|
||||||
// MISSING? .debug-index - http://src.chromium.org/viewvc/chrome/trunk/src/build/gdb-add-index?pathrev=144644
|
// MISSING? .debug-index - http://src.chromium.org/viewvc/chrome/trunk/src/build/gdb-add-index?pathrev=144644
|
||||||
// MISSING? .debug_types - Type descriptions from DWARF 4? See http://gcc.gnu.org/wiki/DwarfSeparateTypeInfo
|
// MISSING? .debug_types - Type descriptions from DWARF 4? See http://gcc.gnu.org/wiki/DwarfSeparateTypeInfo
|
||||||
else if (name == g_sect_name_dwarf_debug_abbrev) sect_type = eSectionTypeDWARFDebugAbbrev;
|
else if (name == g_sect_name_dwarf_debug_abbrev) sect_type = eSectionTypeDWARFDebugAbbrev;
|
||||||
else if (name == g_sect_name_dwarf_debug_addr) sect_type = eSectionTypeDWARFDebugAddr;
|
else if (name == g_sect_name_dwarf_debug_addr) sect_type = eSectionTypeDWARFDebugAddr;
|
||||||
else if (name == g_sect_name_dwarf_debug_aranges) sect_type = eSectionTypeDWARFDebugAranges;
|
else if (name == g_sect_name_dwarf_debug_aranges) sect_type = eSectionTypeDWARFDebugAranges;
|
||||||
else if (name == g_sect_name_dwarf_debug_frame) sect_type = eSectionTypeDWARFDebugFrame;
|
else if (name == g_sect_name_dwarf_debug_frame) sect_type = eSectionTypeDWARFDebugFrame;
|
||||||
else if (name == g_sect_name_dwarf_debug_info) sect_type = eSectionTypeDWARFDebugInfo;
|
else if (name == g_sect_name_dwarf_debug_info) sect_type = eSectionTypeDWARFDebugInfo;
|
||||||
else if (name == g_sect_name_dwarf_debug_line) sect_type = eSectionTypeDWARFDebugLine;
|
else if (name == g_sect_name_dwarf_debug_line) sect_type = eSectionTypeDWARFDebugLine;
|
||||||
else if (name == g_sect_name_dwarf_debug_loc) sect_type = eSectionTypeDWARFDebugLoc;
|
else if (name == g_sect_name_dwarf_debug_loc) sect_type = eSectionTypeDWARFDebugLoc;
|
||||||
else if (name == g_sect_name_dwarf_debug_macinfo) sect_type = eSectionTypeDWARFDebugMacInfo;
|
else if (name == g_sect_name_dwarf_debug_macinfo) sect_type = eSectionTypeDWARFDebugMacInfo;
|
||||||
else if (name == g_sect_name_dwarf_debug_pubnames) sect_type = eSectionTypeDWARFDebugPubNames;
|
else if (name == g_sect_name_dwarf_debug_pubnames) sect_type = eSectionTypeDWARFDebugPubNames;
|
||||||
else if (name == g_sect_name_dwarf_debug_pubtypes) sect_type = eSectionTypeDWARFDebugPubTypes;
|
else if (name == g_sect_name_dwarf_debug_pubtypes) sect_type = eSectionTypeDWARFDebugPubTypes;
|
||||||
else if (name == g_sect_name_dwarf_debug_ranges) sect_type = eSectionTypeDWARFDebugRanges;
|
else if (name == g_sect_name_dwarf_debug_ranges) sect_type = eSectionTypeDWARFDebugRanges;
|
||||||
else if (name == g_sect_name_dwarf_debug_str) sect_type = eSectionTypeDWARFDebugStr;
|
else if (name == g_sect_name_dwarf_debug_str) sect_type = eSectionTypeDWARFDebugStr;
|
||||||
else if (name == g_sect_name_dwarf_debug_str_offsets) sect_type = eSectionTypeDWARFDebugStrOffsets;
|
else if (name == g_sect_name_dwarf_debug_str_offsets) sect_type = eSectionTypeDWARFDebugStrOffsets;
|
||||||
else if (name == g_sect_name_eh_frame) sect_type = eSectionTypeEHFrame;
|
else if (name == g_sect_name_dwarf_debug_abbrev_dwo) sect_type = eSectionTypeDWARFDebugAbbrev;
|
||||||
|
else if (name == g_sect_name_dwarf_debug_info_dwo) sect_type = eSectionTypeDWARFDebugInfo;
|
||||||
|
else if (name == g_sect_name_dwarf_debug_line_dwo) sect_type = eSectionTypeDWARFDebugLine;
|
||||||
|
else if (name == g_sect_name_dwarf_debug_loc_dwo) sect_type = eSectionTypeDWARFDebugLoc;
|
||||||
|
else if (name == g_sect_name_dwarf_debug_str_dwo) sect_type = eSectionTypeDWARFDebugStr;
|
||||||
|
else if (name == g_sect_name_dwarf_debug_str_offsets_dwo) sect_type = eSectionTypeDWARFDebugStrOffsets;
|
||||||
|
else if (name == g_sect_name_eh_frame) sect_type = eSectionTypeEHFrame;
|
||||||
|
|
||||||
switch (header.sh_type)
|
switch (header.sh_type)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
add_lldb_library(lldbPluginSymbolFileDWARF
|
add_lldb_library(lldbPluginSymbolFileDWARF
|
||||||
|
DIERef.cpp
|
||||||
DWARFAbbreviationDeclaration.cpp
|
DWARFAbbreviationDeclaration.cpp
|
||||||
DWARFASTParserClang.cpp
|
DWARFASTParserClang.cpp
|
||||||
DWARFAttribute.cpp
|
DWARFAttribute.cpp
|
||||||
|
@ -26,6 +27,7 @@ add_lldb_library(lldbPluginSymbolFileDWARF
|
||||||
LogChannelDWARF.cpp
|
LogChannelDWARF.cpp
|
||||||
NameToDIE.cpp
|
NameToDIE.cpp
|
||||||
SymbolFileDWARF.cpp
|
SymbolFileDWARF.cpp
|
||||||
|
SymbolFileDWARFDwo.cpp
|
||||||
SymbolFileDWARFDebugMap.cpp
|
SymbolFileDWARFDebugMap.cpp
|
||||||
UniqueDWARFASTType.cpp
|
UniqueDWARFASTType.cpp
|
||||||
)
|
)
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
//===-- DIERef.cpp ----------------------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "DIERef.h"
|
||||||
|
#include "DWARFCompileUnit.h"
|
||||||
|
#include "DWARFFormValue.h"
|
||||||
|
|
||||||
|
DIERef::DIERef() :
|
||||||
|
cu_offset(DW_INVALID_OFFSET),
|
||||||
|
die_offset(DW_INVALID_OFFSET)
|
||||||
|
{}
|
||||||
|
|
||||||
|
DIERef::DIERef(dw_offset_t d) :
|
||||||
|
cu_offset(DW_INVALID_OFFSET),
|
||||||
|
die_offset(d)
|
||||||
|
{}
|
||||||
|
|
||||||
|
DIERef::DIERef(dw_offset_t c, dw_offset_t d) :
|
||||||
|
cu_offset(c),
|
||||||
|
die_offset(d)
|
||||||
|
{}
|
||||||
|
|
||||||
|
DIERef::DIERef(lldb::user_id_t uid) :
|
||||||
|
cu_offset(uid>>32),
|
||||||
|
die_offset(uid&0xffffffff)
|
||||||
|
{}
|
||||||
|
|
||||||
|
DIERef::DIERef(const DWARFFormValue& form_value) :
|
||||||
|
cu_offset(DW_INVALID_OFFSET),
|
||||||
|
die_offset(DW_INVALID_OFFSET)
|
||||||
|
{
|
||||||
|
if (form_value.IsValid())
|
||||||
|
{
|
||||||
|
const DWARFCompileUnit* dwarf_cu = form_value.GetCompileUnit();
|
||||||
|
if (dwarf_cu)
|
||||||
|
{
|
||||||
|
if (dwarf_cu->GetBaseObjOffset() != DW_INVALID_OFFSET)
|
||||||
|
cu_offset = dwarf_cu->GetBaseObjOffset();
|
||||||
|
else
|
||||||
|
cu_offset = dwarf_cu->GetOffset();
|
||||||
|
}
|
||||||
|
die_offset = form_value.Reference();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lldb::user_id_t
|
||||||
|
DIERef::GetUID() const
|
||||||
|
{
|
||||||
|
return ((lldb::user_id_t)cu_offset) << 32 | die_offset;
|
||||||
|
}
|
|
@ -0,0 +1,42 @@
|
||||||
|
//===-- DIERef.h ------------------------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef SymbolFileDWARF_DIERef_h_
|
||||||
|
#define SymbolFileDWARF_DIERef_h_
|
||||||
|
|
||||||
|
#include "lldb/Core/dwarf.h"
|
||||||
|
#include "lldb/lldb-defines.h"
|
||||||
|
|
||||||
|
class DWARFFormValue;
|
||||||
|
|
||||||
|
struct DIERef
|
||||||
|
{
|
||||||
|
DIERef();
|
||||||
|
|
||||||
|
explicit
|
||||||
|
DIERef(dw_offset_t d);
|
||||||
|
|
||||||
|
DIERef(dw_offset_t c, dw_offset_t d);
|
||||||
|
|
||||||
|
explicit
|
||||||
|
DIERef(lldb::user_id_t uid);
|
||||||
|
|
||||||
|
explicit
|
||||||
|
DIERef(const DWARFFormValue& form_value);
|
||||||
|
|
||||||
|
lldb::user_id_t
|
||||||
|
GetUID() const;
|
||||||
|
|
||||||
|
dw_offset_t cu_offset;
|
||||||
|
dw_offset_t die_offset;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef std::vector<DIERef> DIEArray;
|
||||||
|
|
||||||
|
#endif // SymbolFileDWARF_DIERef_h_
|
|
@ -150,7 +150,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
//
|
//
|
||||||
// }
|
// }
|
||||||
|
|
||||||
Type *type_ptr = dwarf->m_die_to_type.lookup (die.GetDIE());
|
Type *type_ptr = dwarf->GetDIEToType().lookup (die.GetDIE());
|
||||||
TypeList* type_list = dwarf->GetTypeList();
|
TypeList* type_list = dwarf->GetTypeList();
|
||||||
if (type_ptr == NULL)
|
if (type_ptr == NULL)
|
||||||
{
|
{
|
||||||
|
@ -186,7 +186,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
case DW_TAG_unspecified_type:
|
case DW_TAG_unspecified_type:
|
||||||
{
|
{
|
||||||
// Set a bit that lets us know that we are currently parsing this
|
// Set a bit that lets us know that we are currently parsing this
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
dwarf->GetDIEToType()[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
||||||
|
|
||||||
const size_t num_attributes = die.GetAttributes (attributes);
|
const size_t num_attributes = die.GetAttributes (attributes);
|
||||||
uint32_t encoding = 0;
|
uint32_t encoding = 0;
|
||||||
|
@ -220,7 +220,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
break;
|
break;
|
||||||
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
||||||
case DW_AT_encoding: encoding = form_value.Unsigned(); break;
|
case DW_AT_encoding: encoding = form_value.Unsigned(); break;
|
||||||
case DW_AT_type: encoding_uid = form_value.Reference(); break;
|
case DW_AT_type: encoding_uid = DIERef(form_value).GetUID(); break;
|
||||||
default:
|
default:
|
||||||
case DW_AT_sibling:
|
case DW_AT_sibling:
|
||||||
break;
|
break;
|
||||||
|
@ -355,7 +355,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
clang_type,
|
clang_type,
|
||||||
resolve_state));
|
resolve_state));
|
||||||
|
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = type_sp.get();
|
dwarf->GetDIEToType()[die.GetDIE()] = type_sp.get();
|
||||||
|
|
||||||
// Type* encoding_type = GetUniquedTypeForDIEOffset(encoding_uid, type_sp, NULL, 0, 0, false);
|
// Type* encoding_type = GetUniquedTypeForDIEOffset(encoding_uid, type_sp, NULL, 0, 0, false);
|
||||||
// if (encoding_type != NULL)
|
// if (encoding_type != NULL)
|
||||||
|
@ -373,7 +373,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
case DW_TAG_class_type:
|
case DW_TAG_class_type:
|
||||||
{
|
{
|
||||||
// Set a bit that lets us know that we are currently parsing this
|
// Set a bit that lets us know that we are currently parsing this
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
dwarf->GetDIEToType()[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
||||||
bool byte_size_valid = false;
|
bool byte_size_valid = false;
|
||||||
|
|
||||||
LanguageType class_language = eLanguageTypeUnknown;
|
LanguageType class_language = eLanguageTypeUnknown;
|
||||||
|
@ -471,7 +471,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
type_sp = unique_ast_entry_ap->m_type_sp;
|
type_sp = unique_ast_entry_ap->m_type_sp;
|
||||||
if (type_sp)
|
if (type_sp)
|
||||||
{
|
{
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = type_sp.get();
|
dwarf->GetDIEToType()[die.GetDIE()] = type_sp.get();
|
||||||
return type_sp;
|
return type_sp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -554,7 +554,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// We found a real definition for this type elsewhere
|
// We found a real definition for this type elsewhere
|
||||||
// so lets use it and cache the fact that we found
|
// so lets use it and cache the fact that we found
|
||||||
// a complete type for this die
|
// a complete type for this die
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = type_sp.get();
|
dwarf->GetDIEToType()[die.GetDIE()] = type_sp.get();
|
||||||
return type_sp;
|
return type_sp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -612,13 +612,13 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// We found a real definition for this type elsewhere
|
// We found a real definition for this type elsewhere
|
||||||
// so lets use it and cache the fact that we found
|
// so lets use it and cache the fact that we found
|
||||||
// a complete type for this die
|
// a complete type for this die
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = type_sp.get();
|
dwarf->GetDIEToType()[die.GetDIE()] = type_sp.get();
|
||||||
return type_sp;
|
return type_sp;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
assert (tag_decl_kind != -1);
|
assert (tag_decl_kind != -1);
|
||||||
bool clang_type_was_created = false;
|
bool clang_type_was_created = false;
|
||||||
clang_type.SetCompilerType(&m_ast, dwarf->m_forward_decl_die_to_clang_type.lookup (die.GetDIE()));
|
clang_type.SetCompilerType(&m_ast, dwarf->GetForwardDeclDieToClangType().lookup (die.GetDIE()));
|
||||||
if (!clang_type)
|
if (!clang_type)
|
||||||
{
|
{
|
||||||
clang::DeclContext *decl_ctx = GetClangDeclContextContainingDIE (die, nullptr);
|
clang::DeclContext *decl_ctx = GetClangDeclContextContainingDIE (die, nullptr);
|
||||||
|
@ -766,21 +766,20 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// will automatically call the SymbolFile virtual function
|
// will automatically call the SymbolFile virtual function
|
||||||
// "SymbolFileDWARF::CompleteType(Type *)"
|
// "SymbolFileDWARF::CompleteType(Type *)"
|
||||||
// When the definition needs to be defined.
|
// When the definition needs to be defined.
|
||||||
dwarf->m_forward_decl_die_to_clang_type[die.GetDIE()] = clang_type.GetOpaqueQualType();
|
dwarf->GetForwardDeclDieToClangType()[die.GetDIE()] = clang_type.GetOpaqueQualType();
|
||||||
dwarf->m_forward_decl_clang_type_to_die[ClangASTContext::RemoveFastQualifiers(clang_type).GetOpaqueQualType()] = die.GetDIE();
|
dwarf->GetForwardDeclClangTypeToDie()[ClangASTContext::RemoveFastQualifiers(clang_type).GetOpaqueQualType()] = die.GetDIERef();
|
||||||
m_ast.SetHasExternalStorage (clang_type.GetOpaqueQualType(), true);
|
m_ast.SetHasExternalStorage (clang_type.GetOpaqueQualType(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_TAG_enumeration_type:
|
case DW_TAG_enumeration_type:
|
||||||
{
|
{
|
||||||
// Set a bit that lets us know that we are currently parsing this
|
// Set a bit that lets us know that we are currently parsing this
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
dwarf->GetDIEToType()[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
||||||
|
|
||||||
lldb::user_id_t encoding_uid = DW_INVALID_OFFSET;
|
DWARFFormValue encoding_form;
|
||||||
|
|
||||||
const size_t num_attributes = die.GetAttributes (attributes);
|
const size_t num_attributes = die.GetAttributes (attributes);
|
||||||
if (num_attributes > 0)
|
if (num_attributes > 0)
|
||||||
|
@ -801,7 +800,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
type_name_cstr = form_value.AsCString();
|
type_name_cstr = form_value.AsCString();
|
||||||
type_name_const_str.SetCString(type_name_cstr);
|
type_name_const_str.SetCString(type_name_cstr);
|
||||||
break;
|
break;
|
||||||
case DW_AT_type: encoding_uid = form_value.Reference(); break;
|
case DW_AT_type: encoding_form = form_value; break;
|
||||||
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
||||||
case DW_AT_accessibility: break; //accessibility = DW_ACCESS_to_AccessType(form_value.Unsigned()); break;
|
case DW_AT_accessibility: break; //accessibility = DW_ACCESS_to_AccessType(form_value.Unsigned()); break;
|
||||||
case DW_AT_declaration: break; //is_forward_declaration = form_value.Boolean(); break;
|
case DW_AT_declaration: break; //is_forward_declaration = form_value.Boolean(); break;
|
||||||
|
@ -824,12 +823,12 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
DEBUG_PRINTF ("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(), DW_TAG_value_to_name(tag), type_name_cstr);
|
DEBUG_PRINTF ("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(), DW_TAG_value_to_name(tag), type_name_cstr);
|
||||||
|
|
||||||
CompilerType enumerator_clang_type;
|
CompilerType enumerator_clang_type;
|
||||||
clang_type.SetCompilerType (&m_ast, dwarf->m_forward_decl_die_to_clang_type.lookup (die.GetDIE()));
|
clang_type.SetCompilerType (&m_ast, dwarf->GetForwardDeclDieToClangType().lookup (die.GetDIE()));
|
||||||
if (!clang_type)
|
if (!clang_type)
|
||||||
{
|
{
|
||||||
if (encoding_uid != DW_INVALID_OFFSET)
|
if (encoding_form.IsValid())
|
||||||
{
|
{
|
||||||
Type *enumerator_type = dwarf->ResolveTypeUID(encoding_uid);
|
Type *enumerator_type = dwarf->ResolveTypeUID(DIERef(encoding_form).GetUID());
|
||||||
if (enumerator_type)
|
if (enumerator_type)
|
||||||
enumerator_clang_type = enumerator_type->GetFullCompilerType ();
|
enumerator_clang_type = enumerator_type->GetFullCompilerType ();
|
||||||
}
|
}
|
||||||
|
@ -856,7 +855,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
type_name_const_str,
|
type_name_const_str,
|
||||||
byte_size,
|
byte_size,
|
||||||
NULL,
|
NULL,
|
||||||
encoding_uid,
|
DIERef(encoding_form).GetUID(),
|
||||||
Type::eEncodingIsUID,
|
Type::eEncodingIsUID,
|
||||||
&decl,
|
&decl,
|
||||||
clang_type,
|
clang_type,
|
||||||
|
@ -880,18 +879,17 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
case DW_TAG_subroutine_type:
|
case DW_TAG_subroutine_type:
|
||||||
{
|
{
|
||||||
// Set a bit that lets us know that we are currently parsing this
|
// Set a bit that lets us know that we are currently parsing this
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
dwarf->GetDIEToType()[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
||||||
|
|
||||||
//const char *mangled = NULL;
|
DWARFFormValue type_die_form;
|
||||||
dw_offset_t type_die_offset = DW_INVALID_OFFSET;
|
|
||||||
bool is_variadic = false;
|
bool is_variadic = false;
|
||||||
bool is_inline = false;
|
bool is_inline = false;
|
||||||
bool is_static = false;
|
bool is_static = false;
|
||||||
bool is_virtual = false;
|
bool is_virtual = false;
|
||||||
bool is_explicit = false;
|
bool is_explicit = false;
|
||||||
bool is_artificial = false;
|
bool is_artificial = false;
|
||||||
dw_offset_t specification_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue specification_die_form;
|
||||||
dw_offset_t abstract_origin_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue abstract_origin_die_form;
|
||||||
dw_offset_t object_pointer_die_offset = DW_INVALID_OFFSET;
|
dw_offset_t object_pointer_die_offset = DW_INVALID_OFFSET;
|
||||||
|
|
||||||
unsigned type_quals = 0;
|
unsigned type_quals = 0;
|
||||||
|
@ -919,7 +917,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
|
|
||||||
case DW_AT_linkage_name:
|
case DW_AT_linkage_name:
|
||||||
case DW_AT_MIPS_linkage_name: break; // mangled = form_value.AsCString(&dwarf->get_debug_str_data()); break;
|
case DW_AT_MIPS_linkage_name: break; // mangled = form_value.AsCString(&dwarf->get_debug_str_data()); break;
|
||||||
case DW_AT_type: type_die_offset = form_value.Reference(); break;
|
case DW_AT_type: type_die_form = form_value; break;
|
||||||
case DW_AT_accessibility: accessibility = DW_ACCESS_to_AccessType(form_value.Unsigned()); break;
|
case DW_AT_accessibility: accessibility = DW_ACCESS_to_AccessType(form_value.Unsigned()); break;
|
||||||
case DW_AT_declaration: break; // is_forward_declaration = form_value.Boolean(); break;
|
case DW_AT_declaration: break; // is_forward_declaration = form_value.Boolean(); break;
|
||||||
case DW_AT_inline: is_inline = form_value.Boolean(); break;
|
case DW_AT_inline: is_inline = form_value.Boolean(); break;
|
||||||
|
@ -939,11 +937,11 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_specification:
|
case DW_AT_specification:
|
||||||
specification_die_offset = form_value.Reference();
|
specification_die_form = form_value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_abstract_origin:
|
case DW_AT_abstract_origin:
|
||||||
abstract_origin_die_offset = form_value.Reference();
|
abstract_origin_die_form = form_value;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_object_pointer:
|
case DW_AT_object_pointer:
|
||||||
|
@ -996,8 +994,8 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
CompilerType return_clang_type;
|
CompilerType return_clang_type;
|
||||||
Type *func_type = NULL;
|
Type *func_type = NULL;
|
||||||
|
|
||||||
if (type_die_offset != DW_INVALID_OFFSET)
|
if (type_die_form.IsValid())
|
||||||
func_type = dwarf->ResolveTypeUID(type_die_offset);
|
func_type = dwarf->ResolveTypeUID(DIERef(type_die_form).GetUID());
|
||||||
|
|
||||||
if (func_type)
|
if (func_type)
|
||||||
return_clang_type = func_type->GetForwardCompilerType ();
|
return_clang_type = func_type->GetForwardCompilerType ();
|
||||||
|
@ -1113,12 +1111,12 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
if (debug_map_symfile)
|
if (debug_map_symfile)
|
||||||
{
|
{
|
||||||
class_symfile = debug_map_symfile->GetSymbolFileByOSOIndex(SymbolFileDWARFDebugMap::GetOSOIndexFromUserID(class_type->GetID()));
|
class_symfile = debug_map_symfile->GetSymbolFileByOSOIndex(SymbolFileDWARFDebugMap::GetOSOIndexFromUserID(class_type->GetID()));
|
||||||
class_type_die = class_symfile->DebugInfo()->GetDIE (class_type->GetID());
|
class_type_die = class_symfile->DebugInfo()->GetDIE (DIERef(class_type->GetID()));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
class_symfile = dwarf;
|
class_symfile = dwarf;
|
||||||
class_type_die = dwarf->DebugInfo()->GetDIE (class_type->GetID());
|
class_type_die = dwarf->DebugInfo()->GetDIE (DIERef(class_type->GetID()));
|
||||||
}
|
}
|
||||||
if (class_type_die)
|
if (class_type_die)
|
||||||
{
|
{
|
||||||
|
@ -1134,7 +1132,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// like having stuff added to them after their definitions are
|
// like having stuff added to them after their definitions are
|
||||||
// complete...
|
// complete...
|
||||||
|
|
||||||
type_ptr = dwarf->m_die_to_type[die.GetDIE()];
|
type_ptr = dwarf->GetDIEToType()[die.GetDIE()];
|
||||||
if (type_ptr && type_ptr != DIE_IS_BEING_PARSED)
|
if (type_ptr && type_ptr != DIE_IS_BEING_PARSED)
|
||||||
{
|
{
|
||||||
type_sp = type_ptr->shared_from_this();
|
type_sp = type_ptr->shared_from_this();
|
||||||
|
@ -1143,7 +1141,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (specification_die_offset != DW_INVALID_OFFSET)
|
if (specification_die_form.IsValid())
|
||||||
{
|
{
|
||||||
// We have a specification which we are going to base our function
|
// We have a specification which we are going to base our function
|
||||||
// prototype off of, so we need this type to be completed so that the
|
// prototype off of, so we need this type to be completed so that the
|
||||||
|
@ -1152,7 +1150,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
class_type->GetForwardCompilerType ();
|
class_type->GetForwardCompilerType ();
|
||||||
// If we have a specification, then the function type should have been
|
// If we have a specification, then the function type should have been
|
||||||
// made with the specification and not with this die.
|
// made with the specification and not with this die.
|
||||||
DWARFDIE spec_die = dwarf->DebugInfo()->GetDIE(specification_die_offset);
|
DWARFDIE spec_die = dwarf->DebugInfo()->GetDIE(DIERef(specification_die_form));
|
||||||
clang::DeclContext *spec_clang_decl_ctx = GetClangDeclContextForDIE (spec_die);
|
clang::DeclContext *spec_clang_decl_ctx = GetClangDeclContextForDIE (spec_die);
|
||||||
if (spec_clang_decl_ctx)
|
if (spec_clang_decl_ctx)
|
||||||
{
|
{
|
||||||
|
@ -1160,13 +1158,13 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
dwarf->GetObjectFile()->GetModule()->ReportWarning ("0x%8.8" PRIx64 ": DW_AT_specification(0x%8.8x) has no decl\n",
|
dwarf->GetObjectFile()->GetModule()->ReportWarning ("0x%8.8" PRIx64 ": DW_AT_specification(0x%8.8" PRIx64 ") has no decl\n",
|
||||||
die.GetID(),
|
die.GetID(),
|
||||||
specification_die_offset);
|
specification_die_form.Reference());
|
||||||
}
|
}
|
||||||
type_handled = true;
|
type_handled = true;
|
||||||
}
|
}
|
||||||
else if (abstract_origin_die_offset != DW_INVALID_OFFSET)
|
else if (abstract_origin_die_form.IsValid())
|
||||||
{
|
{
|
||||||
// We have a specification which we are going to base our function
|
// We have a specification which we are going to base our function
|
||||||
// prototype off of, so we need this type to be completed so that the
|
// prototype off of, so we need this type to be completed so that the
|
||||||
|
@ -1174,7 +1172,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// clang decl context.
|
// clang decl context.
|
||||||
class_type->GetForwardCompilerType ();
|
class_type->GetForwardCompilerType ();
|
||||||
|
|
||||||
DWARFDIE abs_die = dwarf->DebugInfo()->GetDIE (abstract_origin_die_offset);
|
DWARFDIE abs_die = dwarf->DebugInfo()->GetDIE (DIERef(abstract_origin_die_form));
|
||||||
clang::DeclContext *abs_clang_decl_ctx = GetClangDeclContextForDIE (abs_die);
|
clang::DeclContext *abs_clang_decl_ctx = GetClangDeclContextForDIE (abs_die);
|
||||||
if (abs_clang_decl_ctx)
|
if (abs_clang_decl_ctx)
|
||||||
{
|
{
|
||||||
|
@ -1182,9 +1180,9 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
dwarf->GetObjectFile()->GetModule()->ReportWarning ("0x%8.8" PRIx64 ": DW_AT_abstract_origin(0x%8.8x) has no decl\n",
|
dwarf->GetObjectFile()->GetModule()->ReportWarning ("0x%8.8" PRIx64 ": DW_AT_abstract_origin(0x%8.8" PRIx64 ") has no decl\n",
|
||||||
die.GetID(),
|
die.GetID(),
|
||||||
abstract_origin_die_offset);
|
abstract_origin_die_form.Reference());
|
||||||
}
|
}
|
||||||
type_handled = true;
|
type_handled = true;
|
||||||
}
|
}
|
||||||
|
@ -1264,10 +1262,10 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// class hasn't been asked to complete itself through the
|
// class hasn't been asked to complete itself through the
|
||||||
// clang::ExternalASTSource protocol, so we need to just have the
|
// clang::ExternalASTSource protocol, so we need to just have the
|
||||||
// class complete itself and do things the right way, then our
|
// class complete itself and do things the right way, then our
|
||||||
// DIE should then have an entry in the dwarf->m_die_to_type map. First
|
// DIE should then have an entry in the dwarf->GetDIEToType() map. First
|
||||||
// we need to modify the dwarf->m_die_to_type so it doesn't think we are
|
// we need to modify the dwarf->GetDIEToType() so it doesn't think we are
|
||||||
// trying to parse this DIE anymore...
|
// trying to parse this DIE anymore...
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = NULL;
|
dwarf->GetDIEToType()[die.GetDIE()] = NULL;
|
||||||
|
|
||||||
// Now we get the full type to force our class type to complete itself
|
// Now we get the full type to force our class type to complete itself
|
||||||
// using the clang::ExternalASTSource protocol which will parse all
|
// using the clang::ExternalASTSource protocol which will parse all
|
||||||
|
@ -1275,7 +1273,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
class_type->GetFullCompilerType ();
|
class_type->GetFullCompilerType ();
|
||||||
|
|
||||||
// The type for this DIE should have been filled in the function call above
|
// The type for this DIE should have been filled in the function call above
|
||||||
type_ptr = dwarf->m_die_to_type[die.GetDIE()];
|
type_ptr = dwarf->GetDIEToType()[die.GetDIE()];
|
||||||
if (type_ptr && type_ptr != DIE_IS_BEING_PARSED)
|
if (type_ptr && type_ptr != DIE_IS_BEING_PARSED)
|
||||||
{
|
{
|
||||||
type_sp = type_ptr->shared_from_this();
|
type_sp = type_ptr->shared_from_this();
|
||||||
|
@ -1352,9 +1350,9 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
case DW_TAG_array_type:
|
case DW_TAG_array_type:
|
||||||
{
|
{
|
||||||
// Set a bit that lets us know that we are currently parsing this
|
// Set a bit that lets us know that we are currently parsing this
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
dwarf->GetDIEToType()[die.GetDIE()] = DIE_IS_BEING_PARSED;
|
||||||
|
|
||||||
lldb::user_id_t type_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue type_die_form;
|
||||||
int64_t first_index = 0;
|
int64_t first_index = 0;
|
||||||
uint32_t byte_stride = 0;
|
uint32_t byte_stride = 0;
|
||||||
uint32_t bit_stride = 0;
|
uint32_t bit_stride = 0;
|
||||||
|
@ -1379,7 +1377,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
type_name_const_str.SetCString(type_name_cstr);
|
type_name_const_str.SetCString(type_name_cstr);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_type: type_die_offset = form_value.Reference(); break;
|
case DW_AT_type: type_die_form = form_value; break;
|
||||||
case DW_AT_byte_size: break; // byte_size = form_value.Unsigned(); break;
|
case DW_AT_byte_size: break; // byte_size = form_value.Unsigned(); break;
|
||||||
case DW_AT_byte_stride: byte_stride = form_value.Unsigned(); break;
|
case DW_AT_byte_stride: byte_stride = form_value.Unsigned(); break;
|
||||||
case DW_AT_bit_stride: bit_stride = form_value.Unsigned(); break;
|
case DW_AT_bit_stride: bit_stride = form_value.Unsigned(); break;
|
||||||
|
@ -1403,7 +1401,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
|
|
||||||
DEBUG_PRINTF ("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(), DW_TAG_value_to_name(tag), type_name_cstr);
|
DEBUG_PRINTF ("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(), DW_TAG_value_to_name(tag), type_name_cstr);
|
||||||
|
|
||||||
Type *element_type = dwarf->ResolveTypeUID(type_die_offset);
|
Type *element_type = dwarf->ResolveTypeUID(DIERef(type_die_form).GetUID());
|
||||||
|
|
||||||
if (element_type)
|
if (element_type)
|
||||||
{
|
{
|
||||||
|
@ -1440,7 +1438,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
empty_name,
|
empty_name,
|
||||||
array_element_bit_stride / 8,
|
array_element_bit_stride / 8,
|
||||||
NULL,
|
NULL,
|
||||||
type_die_offset,
|
DIERef(type_die_form).GetUID(),
|
||||||
Type::eEncodingIsUID,
|
Type::eEncodingIsUID,
|
||||||
&decl,
|
&decl,
|
||||||
clang_type,
|
clang_type,
|
||||||
|
@ -1453,8 +1451,8 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
|
|
||||||
case DW_TAG_ptr_to_member_type:
|
case DW_TAG_ptr_to_member_type:
|
||||||
{
|
{
|
||||||
dw_offset_t type_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue type_die_form;
|
||||||
dw_offset_t containing_type_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue containing_type_die_form;
|
||||||
|
|
||||||
const size_t num_attributes = die.GetAttributes (attributes);
|
const size_t num_attributes = die.GetAttributes (attributes);
|
||||||
|
|
||||||
|
@ -1468,15 +1466,15 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
switch (attr)
|
switch (attr)
|
||||||
{
|
{
|
||||||
case DW_AT_type:
|
case DW_AT_type:
|
||||||
type_die_offset = form_value.Reference(); break;
|
type_die_form = form_value; break;
|
||||||
case DW_AT_containing_type:
|
case DW_AT_containing_type:
|
||||||
containing_type_die_offset = form_value.Reference(); break;
|
containing_type_die_form = form_value; break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Type *pointee_type = dwarf->ResolveTypeUID(type_die_offset);
|
Type *pointee_type = dwarf->ResolveTypeUID(DIERef(type_die_form).GetUID());
|
||||||
Type *class_type = dwarf->ResolveTypeUID(containing_type_die_offset);
|
Type *class_type = dwarf->ResolveTypeUID(DIERef(containing_type_die_form).GetUID());
|
||||||
|
|
||||||
CompilerType pointee_clang_type = pointee_type->GetForwardCompilerType ();
|
CompilerType pointee_clang_type = pointee_type->GetForwardCompilerType ();
|
||||||
CompilerType class_clang_type = class_type->GetLayoutCompilerType ();
|
CompilerType class_clang_type = class_type->GetLayoutCompilerType ();
|
||||||
|
@ -1532,7 +1530,7 @@ DWARFASTParserClang::ParseTypeFromDWARF (const SymbolContext& sc,
|
||||||
// We are ready to put this type into the uniqued list up at the module level
|
// We are ready to put this type into the uniqued list up at the module level
|
||||||
type_list->Insert (type_sp);
|
type_list->Insert (type_sp);
|
||||||
|
|
||||||
dwarf->m_die_to_type[die.GetDIE()] = type_sp.get();
|
dwarf->GetDIEToType()[die.GetDIE()] = type_sp.get();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (type_ptr != DIE_IS_BEING_PARSED)
|
else if (type_ptr != DIE_IS_BEING_PARSED)
|
||||||
|
@ -1654,8 +1652,7 @@ DWARFASTParserClang::ParseTemplateDIE (const DWARFDIE &die,
|
||||||
case DW_AT_type:
|
case DW_AT_type:
|
||||||
if (attributes.ExtractFormValueAtIndex(i, form_value))
|
if (attributes.ExtractFormValueAtIndex(i, form_value))
|
||||||
{
|
{
|
||||||
const dw_offset_t type_die_offset = form_value.Reference();
|
lldb_type = die.ResolveTypeUID(DIERef(form_value).GetUID());
|
||||||
lldb_type = die.ResolveTypeUID(type_die_offset);
|
|
||||||
if (lldb_type)
|
if (lldb_type)
|
||||||
clang_type = lldb_type->GetForwardCompilerType ();
|
clang_type = lldb_type->GetForwardCompilerType ();
|
||||||
}
|
}
|
||||||
|
@ -1855,8 +1852,8 @@ DWARFASTParserClang::CompleteTypeFromDWARF (const DWARFDIE &die,
|
||||||
const size_t num_matches = method_die_offsets.size();
|
const size_t num_matches = method_die_offsets.size();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = method_die_offsets[i];
|
const DIERef& die_ref = method_die_offsets[i];
|
||||||
DWARFDIE method_die = debug_info->GetDIE (die_offset);
|
DWARFDIE method_die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (method_die)
|
if (method_die)
|
||||||
method_die.ResolveType ();
|
method_die.ResolveType ();
|
||||||
|
@ -2310,7 +2307,7 @@ DWARFASTParserClang::ParseFunctionFromDWARF (const SymbolContext& sc,
|
||||||
|
|
||||||
SymbolFileDWARF *dwarf = die.GetDWARF();
|
SymbolFileDWARF *dwarf = die.GetDWARF();
|
||||||
// Supply the type _only_ if it has already been parsed
|
// Supply the type _only_ if it has already been parsed
|
||||||
Type *func_type = dwarf->m_die_to_type.lookup (die.GetDIE());
|
Type *func_type = dwarf->GetDIEToType().lookup (die.GetDIE());
|
||||||
|
|
||||||
assert(func_type == NULL || func_type != DIE_IS_BEING_PARSED);
|
assert(func_type == NULL || func_type != DIE_IS_BEING_PARSED);
|
||||||
|
|
||||||
|
@ -2386,7 +2383,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
|
|
||||||
|
|
||||||
bool is_artificial = false;
|
bool is_artificial = false;
|
||||||
lldb::user_id_t encoding_uid = LLDB_INVALID_UID;
|
DWARFFormValue encoding_form;
|
||||||
AccessType accessibility = eAccessNone;
|
AccessType accessibility = eAccessNone;
|
||||||
uint32_t member_byte_offset = UINT32_MAX;
|
uint32_t member_byte_offset = UINT32_MAX;
|
||||||
size_t byte_size = 0;
|
size_t byte_size = 0;
|
||||||
|
@ -2406,7 +2403,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
case DW_AT_decl_line: decl.SetLine(form_value.Unsigned()); break;
|
case DW_AT_decl_line: decl.SetLine(form_value.Unsigned()); break;
|
||||||
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
||||||
case DW_AT_name: name = form_value.AsCString(); break;
|
case DW_AT_name: name = form_value.AsCString(); break;
|
||||||
case DW_AT_type: encoding_uid = form_value.Reference(); break;
|
case DW_AT_type: encoding_form = form_value; break;
|
||||||
case DW_AT_bit_offset: bit_offset = form_value.Unsigned(); break;
|
case DW_AT_bit_offset: bit_offset = form_value.Unsigned(); break;
|
||||||
case DW_AT_bit_size: bit_size = form_value.Unsigned(); break;
|
case DW_AT_bit_size: bit_size = form_value.Unsigned(); break;
|
||||||
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
case DW_AT_byte_size: byte_size = form_value.Unsigned(); break;
|
||||||
|
@ -2545,7 +2542,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
// Handle static members
|
// Handle static members
|
||||||
if (is_external && member_byte_offset == UINT32_MAX)
|
if (is_external && member_byte_offset == UINT32_MAX)
|
||||||
{
|
{
|
||||||
Type *var_type = die.ResolveTypeUID(encoding_uid);
|
Type *var_type = die.ResolveTypeUID(DIERef(encoding_form).GetUID());
|
||||||
|
|
||||||
if (var_type)
|
if (var_type)
|
||||||
{
|
{
|
||||||
|
@ -2561,7 +2558,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
|
|
||||||
if (is_artificial == false)
|
if (is_artificial == false)
|
||||||
{
|
{
|
||||||
Type *member_type = die.ResolveTypeUID(encoding_uid);
|
Type *member_type = die.ResolveTypeUID(DIERef(encoding_form).GetUID());
|
||||||
|
|
||||||
clang::FieldDecl *field_decl = NULL;
|
clang::FieldDecl *field_decl = NULL;
|
||||||
if (tag == DW_TAG_member)
|
if (tag == DW_TAG_member)
|
||||||
|
@ -2712,7 +2709,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member '%s' refers to type 0x%8.8" PRIx64 " which extends beyond the bounds of 0x%8.8" PRIx64,
|
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member '%s' refers to type 0x%8.8" PRIx64 " which extends beyond the bounds of 0x%8.8" PRIx64,
|
||||||
die.GetID(),
|
die.GetID(),
|
||||||
name,
|
name,
|
||||||
encoding_uid,
|
encoding_form.Reference(),
|
||||||
parent_die.GetID());
|
parent_die.GetID());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2737,11 +2734,11 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member '%s' refers to type 0x%8.8" PRIx64 " which was unable to be parsed",
|
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member '%s' refers to type 0x%8.8" PRIx64 " which was unable to be parsed",
|
||||||
die.GetID(),
|
die.GetID(),
|
||||||
name,
|
name,
|
||||||
encoding_uid);
|
encoding_form.Reference());
|
||||||
else
|
else
|
||||||
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member refers to type 0x%8.8" PRIx64 " which was unable to be parsed",
|
module_sp->ReportError ("0x%8.8" PRIx64 ": DW_TAG_member refers to type 0x%8.8" PRIx64 " which was unable to be parsed",
|
||||||
die.GetID(),
|
die.GetID(),
|
||||||
encoding_uid);
|
encoding_form.Reference());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2792,7 +2789,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
{
|
{
|
||||||
Declaration decl;
|
Declaration decl;
|
||||||
DWARFExpression location(die.GetCU());
|
DWARFExpression location(die.GetCU());
|
||||||
lldb::user_id_t encoding_uid = LLDB_INVALID_UID;
|
DWARFFormValue encoding_form;
|
||||||
AccessType accessibility = default_accessibility;
|
AccessType accessibility = default_accessibility;
|
||||||
bool is_virtual = false;
|
bool is_virtual = false;
|
||||||
bool is_base_of_class = true;
|
bool is_base_of_class = true;
|
||||||
|
@ -2809,7 +2806,7 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
case DW_AT_decl_file: decl.SetFile(sc.comp_unit->GetSupportFiles().GetFileSpecAtIndex(form_value.Unsigned())); break;
|
case DW_AT_decl_file: decl.SetFile(sc.comp_unit->GetSupportFiles().GetFileSpecAtIndex(form_value.Unsigned())); break;
|
||||||
case DW_AT_decl_line: decl.SetLine(form_value.Unsigned()); break;
|
case DW_AT_decl_line: decl.SetLine(form_value.Unsigned()); break;
|
||||||
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
||||||
case DW_AT_type: encoding_uid = form_value.Reference(); break;
|
case DW_AT_type: encoding_form = form_value; break;
|
||||||
case DW_AT_data_member_location:
|
case DW_AT_data_member_location:
|
||||||
if (form_value.BlockData())
|
if (form_value.BlockData())
|
||||||
{
|
{
|
||||||
|
@ -2861,12 +2858,12 @@ DWARFASTParserClang::ParseChildMembers (const SymbolContext& sc,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Type *base_class_type = die.ResolveTypeUID(encoding_uid);
|
Type *base_class_type = die.ResolveTypeUID(DIERef(encoding_form).GetUID());
|
||||||
if (base_class_type == NULL)
|
if (base_class_type == NULL)
|
||||||
{
|
{
|
||||||
module_sp->ReportError("0x%8.8x: DW_TAG_inheritance failed to resolve the base class at 0x%8.8" PRIx64 " from enclosing type 0x%8.8x. \nPlease file a bug and attach the file at the start of this error message",
|
module_sp->ReportError("0x%8.8x: DW_TAG_inheritance failed to resolve the base class at 0x%8.8" PRIx64 " from enclosing type 0x%8.8x. \nPlease file a bug and attach the file at the start of this error message",
|
||||||
die.GetOffset(),
|
die.GetOffset(),
|
||||||
encoding_uid,
|
encoding_form.Reference(),
|
||||||
parent_die.GetOffset());
|
parent_die.GetOffset());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2942,7 +2939,7 @@ DWARFASTParserClang::ParseChildParameters (const SymbolContext& sc,
|
||||||
{
|
{
|
||||||
const char *name = NULL;
|
const char *name = NULL;
|
||||||
Declaration decl;
|
Declaration decl;
|
||||||
dw_offset_t param_type_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue param_type_die_form;
|
||||||
bool is_artificial = false;
|
bool is_artificial = false;
|
||||||
// one of None, Auto, Register, Extern, Static, PrivateExtern
|
// one of None, Auto, Register, Extern, Static, PrivateExtern
|
||||||
|
|
||||||
|
@ -2961,7 +2958,7 @@ DWARFASTParserClang::ParseChildParameters (const SymbolContext& sc,
|
||||||
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
case DW_AT_decl_column: decl.SetColumn(form_value.Unsigned()); break;
|
||||||
case DW_AT_name: name = form_value.AsCString();
|
case DW_AT_name: name = form_value.AsCString();
|
||||||
break;
|
break;
|
||||||
case DW_AT_type: param_type_die_offset = form_value.Reference(); break;
|
case DW_AT_type: param_type_die_form = form_value; break;
|
||||||
case DW_AT_artificial: is_artificial = form_value.Boolean(); break;
|
case DW_AT_artificial: is_artificial = form_value.Boolean(); break;
|
||||||
case DW_AT_location:
|
case DW_AT_location:
|
||||||
// if (form_value.BlockData())
|
// if (form_value.BlockData())
|
||||||
|
@ -3006,7 +3003,7 @@ DWARFASTParserClang::ParseChildParameters (const SymbolContext& sc,
|
||||||
// being in the formal parameter DIE...
|
// being in the formal parameter DIE...
|
||||||
if (name == NULL || ::strcmp(name, "this")==0)
|
if (name == NULL || ::strcmp(name, "this")==0)
|
||||||
{
|
{
|
||||||
Type *this_type = die.ResolveTypeUID (param_type_die_offset);
|
Type *this_type = die.ResolveTypeUID (DIERef(param_type_die_form).GetUID());
|
||||||
if (this_type)
|
if (this_type)
|
||||||
{
|
{
|
||||||
uint32_t encoding_mask = this_type->GetEncodingMask();
|
uint32_t encoding_mask = this_type->GetEncodingMask();
|
||||||
|
@ -3049,7 +3046,7 @@ DWARFASTParserClang::ParseChildParameters (const SymbolContext& sc,
|
||||||
|
|
||||||
if (!skip)
|
if (!skip)
|
||||||
{
|
{
|
||||||
Type *type = die.ResolveTypeUID(param_type_die_offset);
|
Type *type = die.ResolveTypeUID(DIERef(param_type_die_form).GetUID());
|
||||||
if (type)
|
if (type)
|
||||||
{
|
{
|
||||||
function_param_types.push_back (type->GetForwardCompilerType ());
|
function_param_types.push_back (type->GetForwardCompilerType ());
|
||||||
|
@ -3471,7 +3468,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
src_die.GetOffset(), dst_die.GetOffset());
|
src_die.GetOffset(), dst_die.GetOffset());
|
||||||
}
|
}
|
||||||
|
|
||||||
Type *src_child_type = dst_die.GetDWARF()->m_die_to_type[src_die.GetDIE()];
|
Type *src_child_type = dst_die.GetDWARF()->GetDIEToType()[src_die.GetDIE()];
|
||||||
if (src_child_type)
|
if (src_child_type)
|
||||||
{
|
{
|
||||||
if (log)
|
if (log)
|
||||||
|
@ -3479,7 +3476,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
static_cast<void*>(src_child_type),
|
static_cast<void*>(src_child_type),
|
||||||
src_child_type->GetID(),
|
src_child_type->GetID(),
|
||||||
src_die.GetOffset(), dst_die.GetOffset());
|
src_die.GetOffset(), dst_die.GetOffset());
|
||||||
dst_die.GetDWARF()->m_die_to_type[dst_die.GetDIE()] = src_child_type;
|
dst_die.GetDWARF()->GetDIEToType()[dst_die.GetDIE()] = src_child_type;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -3522,7 +3519,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
log->Printf ("warning: tried to unique decl context from 0x%8.8x for 0x%8.8x, but none was found", src_die.GetOffset(), dst_die.GetOffset());
|
log->Printf ("warning: tried to unique decl context from 0x%8.8x for 0x%8.8x, but none was found", src_die.GetOffset(), dst_die.GetOffset());
|
||||||
}
|
}
|
||||||
|
|
||||||
Type *src_child_type = dst_die.GetDWARF()->m_die_to_type[src_die.GetDIE()];
|
Type *src_child_type = dst_die.GetDWARF()->GetDIEToType()[src_die.GetDIE()];
|
||||||
if (src_child_type)
|
if (src_child_type)
|
||||||
{
|
{
|
||||||
if (log)
|
if (log)
|
||||||
|
@ -3531,7 +3528,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
src_child_type->GetID(),
|
src_child_type->GetID(),
|
||||||
src_die.GetOffset(),
|
src_die.GetOffset(),
|
||||||
dst_die.GetOffset());
|
dst_die.GetOffset());
|
||||||
dst_die.GetDWARF()->m_die_to_type[dst_die.GetDIE()] = src_child_type;
|
dst_die.GetDWARF()->GetDIEToType()[dst_die.GetDIE()] = src_child_type;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -3581,7 +3578,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
log->Printf ("warning: tried to unique decl context from 0x%8.8x for 0x%8.8x, but none was found", src_die.GetOffset(), dst_die.GetOffset());
|
log->Printf ("warning: tried to unique decl context from 0x%8.8x for 0x%8.8x, but none was found", src_die.GetOffset(), dst_die.GetOffset());
|
||||||
}
|
}
|
||||||
|
|
||||||
Type *src_child_type = dst_die.GetDWARF()->m_die_to_type[src_die.GetDIE()];
|
Type *src_child_type = dst_die.GetDWARF()->GetDIEToType()[src_die.GetDIE()];
|
||||||
if (src_child_type)
|
if (src_child_type)
|
||||||
{
|
{
|
||||||
if (log)
|
if (log)
|
||||||
|
@ -3589,7 +3586,7 @@ DWARFASTParserClang::CopyUniqueClassMethodTypes (const DWARFDIE &src_class_die,
|
||||||
static_cast<void*>(src_child_type),
|
static_cast<void*>(src_child_type),
|
||||||
src_child_type->GetID(),
|
src_child_type->GetID(),
|
||||||
src_die.GetOffset(), dst_die.GetOffset());
|
src_die.GetOffset(), dst_die.GetOffset());
|
||||||
dst_die.GetDWARF()->m_die_to_type[dst_die.GetDIE()] = src_child_type;
|
dst_die.GetDWARF()->GetDIEToType()[dst_die.GetDIE()] = src_child_type;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "LogChannelDWARF.h"
|
#include "LogChannelDWARF.h"
|
||||||
#include "NameToDIE.h"
|
#include "NameToDIE.h"
|
||||||
#include "SymbolFileDWARF.h"
|
#include "SymbolFileDWARF.h"
|
||||||
|
#include "SymbolFileDWARFDwo.h"
|
||||||
#include "SymbolFileDWARFDebugMap.h"
|
#include "SymbolFileDWARFDebugMap.h"
|
||||||
|
|
||||||
using namespace lldb;
|
using namespace lldb;
|
||||||
|
@ -54,10 +55,15 @@ DWARFCompileUnit::DWARFCompileUnit(SymbolFileDWARF* dwarf2Data) :
|
||||||
m_producer_version_update (0),
|
m_producer_version_update (0),
|
||||||
m_language_type (eLanguageTypeUnknown),
|
m_language_type (eLanguageTypeUnknown),
|
||||||
m_is_dwarf64 (false),
|
m_is_dwarf64 (false),
|
||||||
m_is_optimized (eLazyBoolCalculate)
|
m_is_optimized (eLazyBoolCalculate),
|
||||||
|
m_addr_base (0),
|
||||||
|
m_base_obj_offset (DW_INVALID_OFFSET)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DWARFCompileUnit::~DWARFCompileUnit()
|
||||||
|
{}
|
||||||
|
|
||||||
void
|
void
|
||||||
DWARFCompileUnit::Clear()
|
DWARFCompileUnit::Clear()
|
||||||
{
|
{
|
||||||
|
@ -74,6 +80,8 @@ DWARFCompileUnit::Clear()
|
||||||
m_language_type = eLanguageTypeUnknown;
|
m_language_type = eLanguageTypeUnknown;
|
||||||
m_is_dwarf64 = false;
|
m_is_dwarf64 = false;
|
||||||
m_is_optimized = eLazyBoolCalculate;
|
m_is_optimized = eLazyBoolCalculate;
|
||||||
|
m_addr_base = 0;
|
||||||
|
m_base_obj_offset = DW_INVALID_OFFSET;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
@ -131,6 +139,9 @@ DWARFCompileUnit::ClearDIEs(bool keep_compile_unit_die)
|
||||||
if (keep_compile_unit_die)
|
if (keep_compile_unit_die)
|
||||||
m_die_array.push_back(tmp_array.front());
|
m_die_array.push_back(tmp_array.front());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_dwo_symbol_file)
|
||||||
|
m_dwo_symbol_file->GetCompileUnit()->ClearDIEs(keep_compile_unit_die);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
|
@ -192,12 +203,12 @@ DWARFCompileUnit::ExtractDIEsIfNeeded (bool cu_die_only)
|
||||||
const bool null_die = die.IsNULL();
|
const bool null_die = die.IsNULL();
|
||||||
if (depth == 0)
|
if (depth == 0)
|
||||||
{
|
{
|
||||||
uint64_t base_addr = die.GetAttributeValueAsUnsigned(m_dwarf2Data, this, DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
|
||||||
if (base_addr == LLDB_INVALID_ADDRESS)
|
|
||||||
base_addr = die.GetAttributeValueAsUnsigned(m_dwarf2Data, this, DW_AT_entry_pc, 0);
|
|
||||||
SetBaseAddress (base_addr);
|
|
||||||
if (initial_die_array_size == 0)
|
if (initial_die_array_size == 0)
|
||||||
AddDIE (die);
|
AddCompileUnitDIE(die);
|
||||||
|
uint64_t base_addr = die.GetAttributeValueAsAddress(m_dwarf2Data, this, DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
||||||
|
if (base_addr == LLDB_INVALID_ADDRESS)
|
||||||
|
base_addr = die.GetAttributeValueAsAddress(m_dwarf2Data, this, DW_AT_entry_pc, 0);
|
||||||
|
SetBaseAddress (base_addr);
|
||||||
if (cu_die_only)
|
if (cu_die_only)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -287,9 +298,83 @@ DWARFCompileUnit::ExtractDIEsIfNeeded (bool cu_die_only)
|
||||||
verbose_log->PutCString (strm.GetString().c_str());
|
verbose_log->PutCString (strm.GetString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
return m_die_array.size();
|
if (!m_dwo_symbol_file)
|
||||||
|
return m_die_array.size();
|
||||||
|
|
||||||
|
DWARFCompileUnit* dwo_cu = m_dwo_symbol_file->GetCompileUnit();
|
||||||
|
size_t dwo_die_count = dwo_cu->ExtractDIEsIfNeeded(cu_die_only);
|
||||||
|
return m_die_array.size() + dwo_die_count - 1; // We have 2 CU die, but we waht to count it only as one
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
DWARFCompileUnit::AddCompileUnitDIE(DWARFDebugInfoEntry& die)
|
||||||
|
{
|
||||||
|
assert (m_die_array.empty() && "Compile unit DIE already added");
|
||||||
|
AddDIE(die);
|
||||||
|
|
||||||
|
DWARFDebugInfoEntry& cu_die = m_die_array.front();
|
||||||
|
|
||||||
|
const char* dwo_name = cu_die.GetAttributeValueAsString(m_dwarf2Data,
|
||||||
|
this,
|
||||||
|
DW_AT_GNU_dwo_name,
|
||||||
|
nullptr);
|
||||||
|
if (!dwo_name)
|
||||||
|
return;
|
||||||
|
|
||||||
|
FileSpec dwo_file(dwo_name, true);
|
||||||
|
if (dwo_file.IsRelative())
|
||||||
|
{
|
||||||
|
const char* comp_dir = cu_die.GetAttributeValueAsString(m_dwarf2Data,
|
||||||
|
this,
|
||||||
|
DW_AT_comp_dir,
|
||||||
|
nullptr);
|
||||||
|
if (!comp_dir)
|
||||||
|
return;
|
||||||
|
|
||||||
|
dwo_file.SetFile(comp_dir, true);
|
||||||
|
dwo_file.AppendPathComponent(dwo_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dwo_file.Exists())
|
||||||
|
return;
|
||||||
|
|
||||||
|
DataBufferSP dwo_file_data_sp;
|
||||||
|
lldb::offset_t dwo_file_data_offset = 0;
|
||||||
|
ObjectFileSP dwo_obj_file = ObjectFile::FindPlugin(m_dwarf2Data->GetObjectFile()->GetModule(),
|
||||||
|
&dwo_file,
|
||||||
|
0 /* file_offset */,
|
||||||
|
dwo_file.GetByteSize(),
|
||||||
|
dwo_file_data_sp,
|
||||||
|
dwo_file_data_offset);
|
||||||
|
if (dwo_obj_file == nullptr)
|
||||||
|
return;
|
||||||
|
|
||||||
|
std::unique_ptr<SymbolFileDWARFDwo> dwo_symbol_file(new SymbolFileDWARFDwo(dwo_obj_file, this));
|
||||||
|
|
||||||
|
DWARFCompileUnit* dwo_cu = dwo_symbol_file->GetCompileUnit();
|
||||||
|
if (!dwo_cu)
|
||||||
|
return; // Can't fetch the compile unit from the dwo file.
|
||||||
|
|
||||||
|
DWARFDIE dwo_cu_die = dwo_cu->GetCompileUnitDIEOnly();
|
||||||
|
if (!dwo_cu_die.IsValid())
|
||||||
|
return; // Can't fetch the compile unit DIE from the dwo file.
|
||||||
|
|
||||||
|
uint64_t main_dwo_id = cu_die.GetAttributeValueAsUnsigned(m_dwarf2Data,
|
||||||
|
this,
|
||||||
|
DW_AT_GNU_dwo_id,
|
||||||
|
0);
|
||||||
|
uint64_t sub_dwo_id = dwo_cu_die.GetAttributeValueAsUnsigned(DW_AT_GNU_dwo_id, 0);
|
||||||
|
if (main_dwo_id != sub_dwo_id)
|
||||||
|
return; // The 2 dwo ID isn't match. Don't use the dwo file as it belongs to a differectn compilation.
|
||||||
|
|
||||||
|
m_dwo_symbol_file = std::move(dwo_symbol_file);
|
||||||
|
|
||||||
|
dw_addr_t addr_base = cu_die.GetAttributeValueAsUnsigned(m_dwarf2Data,
|
||||||
|
this,
|
||||||
|
DW_AT_GNU_addr_base,
|
||||||
|
0);
|
||||||
|
dwo_cu->SetAddrBase(addr_base, m_offset);
|
||||||
|
}
|
||||||
|
|
||||||
dw_offset_t
|
dw_offset_t
|
||||||
DWARFCompileUnit::GetAbbrevOffset() const
|
DWARFCompileUnit::GetAbbrevOffset() const
|
||||||
|
@ -380,10 +465,11 @@ DWARFCompileUnit::SetDefaultAddressSize(uint8_t addr_size)
|
||||||
lldb::user_id_t
|
lldb::user_id_t
|
||||||
DWARFCompileUnit::GetID () const
|
DWARFCompileUnit::GetID () const
|
||||||
{
|
{
|
||||||
|
dw_offset_t local_id = m_base_obj_offset != DW_INVALID_OFFSET ? m_base_obj_offset : m_offset;
|
||||||
if (m_dwarf2Data)
|
if (m_dwarf2Data)
|
||||||
return m_dwarf2Data->MakeUserID(GetOffset());
|
return m_dwarf2Data->MakeUserID(local_id);
|
||||||
else
|
else
|
||||||
return GetOffset();
|
return local_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -509,6 +595,17 @@ DWARFCompileUnit::GetFunctionAranges ()
|
||||||
const DWARFDebugInfoEntry* die = DIEPtr();
|
const DWARFDebugInfoEntry* die = DIEPtr();
|
||||||
if (die)
|
if (die)
|
||||||
die->BuildFunctionAddressRangeTable (m_dwarf2Data, this, m_func_aranges_ap.get());
|
die->BuildFunctionAddressRangeTable (m_dwarf2Data, this, m_func_aranges_ap.get());
|
||||||
|
|
||||||
|
if (m_dwo_symbol_file)
|
||||||
|
{
|
||||||
|
DWARFCompileUnit* dwo_cu = m_dwo_symbol_file->GetCompileUnit();
|
||||||
|
const DWARFDebugInfoEntry* dwo_die = dwo_cu->DIEPtr();
|
||||||
|
if (dwo_die)
|
||||||
|
dwo_die->BuildFunctionAddressRangeTable (m_dwo_symbol_file.get(),
|
||||||
|
dwo_cu,
|
||||||
|
m_func_aranges_ap.get());
|
||||||
|
}
|
||||||
|
|
||||||
const bool minimize = false;
|
const bool minimize = false;
|
||||||
m_func_aranges_ap->Sort(minimize);
|
m_func_aranges_ap->Sort(minimize);
|
||||||
}
|
}
|
||||||
|
@ -550,6 +647,9 @@ DWARFCompileUnit::GetDIE (dw_offset_t die_offset)
|
||||||
{
|
{
|
||||||
if (die_offset != DW_INVALID_OFFSET)
|
if (die_offset != DW_INVALID_OFFSET)
|
||||||
{
|
{
|
||||||
|
if (m_dwo_symbol_file)
|
||||||
|
return m_dwo_symbol_file->GetCompileUnit()->GetDIE(die_offset);
|
||||||
|
|
||||||
if (ContainsDIEOffset(die_offset))
|
if (ContainsDIEOffset(die_offset))
|
||||||
{
|
{
|
||||||
ExtractDIEsIfNeeded (false);
|
ExtractDIEsIfNeeded (false);
|
||||||
|
@ -563,7 +663,9 @@ DWARFCompileUnit::GetDIE (dw_offset_t die_offset)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return m_dwarf2Data->DebugInfo()->GetDIE (die_offset);
|
// Don't specify the compile unit offset as we don't know it because the DIE belongs to
|
||||||
|
// a different compile unit in the same symbol file.
|
||||||
|
return m_dwarf2Data->DebugInfo()->GetDIE (DIERef(die_offset));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return DWARFDIE(); // Not found
|
return DWARFDIE(); // Not found
|
||||||
|
@ -609,8 +711,7 @@ DWARFCompileUnit::AppendDIEsWithTag (const dw_tag_t tag, DWARFDIECollection& die
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
DWARFCompileUnit::Index (const uint32_t cu_idx,
|
DWARFCompileUnit::Index (NameToDIE& func_basenames,
|
||||||
NameToDIE& func_basenames,
|
|
||||||
NameToDIE& func_fullnames,
|
NameToDIE& func_fullnames,
|
||||||
NameToDIE& func_methods,
|
NameToDIE& func_methods,
|
||||||
NameToDIE& func_selectors,
|
NameToDIE& func_selectors,
|
||||||
|
@ -619,9 +720,6 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
NameToDIE& types,
|
NameToDIE& types,
|
||||||
NameToDIE& namespaces)
|
NameToDIE& namespaces)
|
||||||
{
|
{
|
||||||
DWARFFormValue::FixedFormSizes fixed_form_sizes =
|
|
||||||
DWARFFormValue::GetFixedFormSizesForAddressSize (GetAddressByteSize(), m_is_dwarf64);
|
|
||||||
|
|
||||||
Log *log (LogChannelDWARF::GetLogIfAll (DWARF_LOG_LOOKUPS));
|
Log *log (LogChannelDWARF::GetLogIfAll (DWARF_LOG_LOOKUPS));
|
||||||
|
|
||||||
if (log)
|
if (log)
|
||||||
|
@ -632,9 +730,57 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
}
|
}
|
||||||
|
|
||||||
const LanguageType cu_language = GetLanguageType();
|
const LanguageType cu_language = GetLanguageType();
|
||||||
|
DWARFFormValue::FixedFormSizes fixed_form_sizes =
|
||||||
|
DWARFFormValue::GetFixedFormSizesForAddressSize (GetAddressByteSize(), m_is_dwarf64);
|
||||||
|
|
||||||
|
IndexPrivate(this,
|
||||||
|
cu_language,
|
||||||
|
fixed_form_sizes,
|
||||||
|
GetOffset(),
|
||||||
|
func_basenames,
|
||||||
|
func_fullnames,
|
||||||
|
func_methods,
|
||||||
|
func_selectors,
|
||||||
|
objc_class_selectors,
|
||||||
|
globals,
|
||||||
|
types,
|
||||||
|
namespaces);
|
||||||
|
|
||||||
|
SymbolFileDWARFDwo* dwo_symbol_file = GetDwoSymbolFile();
|
||||||
|
if (dwo_symbol_file)
|
||||||
|
{
|
||||||
|
IndexPrivate(dwo_symbol_file->GetCompileUnit(),
|
||||||
|
cu_language,
|
||||||
|
fixed_form_sizes,
|
||||||
|
GetOffset(),
|
||||||
|
func_basenames,
|
||||||
|
func_fullnames,
|
||||||
|
func_methods,
|
||||||
|
func_selectors,
|
||||||
|
objc_class_selectors,
|
||||||
|
globals,
|
||||||
|
types,
|
||||||
|
namespaces);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
DWARFCompileUnit::IndexPrivate (DWARFCompileUnit* dwarf_cu,
|
||||||
|
const LanguageType cu_language,
|
||||||
|
const DWARFFormValue::FixedFormSizes& fixed_form_sizes,
|
||||||
|
const dw_offset_t cu_offset,
|
||||||
|
NameToDIE& func_basenames,
|
||||||
|
NameToDIE& func_fullnames,
|
||||||
|
NameToDIE& func_methods,
|
||||||
|
NameToDIE& func_selectors,
|
||||||
|
NameToDIE& objc_class_selectors,
|
||||||
|
NameToDIE& globals,
|
||||||
|
NameToDIE& types,
|
||||||
|
NameToDIE& namespaces)
|
||||||
|
{
|
||||||
DWARFDebugInfoEntry::const_iterator pos;
|
DWARFDebugInfoEntry::const_iterator pos;
|
||||||
DWARFDebugInfoEntry::const_iterator begin = m_die_array.begin();
|
DWARFDebugInfoEntry::const_iterator begin = dwarf_cu->m_die_array.begin();
|
||||||
DWARFDebugInfoEntry::const_iterator end = m_die_array.end();
|
DWARFDebugInfoEntry::const_iterator end = dwarf_cu->m_die_array.end();
|
||||||
for (pos = begin; pos != end; ++pos)
|
for (pos = begin; pos != end; ++pos)
|
||||||
{
|
{
|
||||||
const DWARFDebugInfoEntry &die = *pos;
|
const DWARFDebugInfoEntry &die = *pos;
|
||||||
|
@ -672,8 +818,8 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
bool has_location = false;
|
bool has_location = false;
|
||||||
bool is_global_or_static_variable = false;
|
bool is_global_or_static_variable = false;
|
||||||
|
|
||||||
dw_offset_t specification_die_offset = DW_INVALID_OFFSET;
|
DWARFFormValue specification_die_form;
|
||||||
const size_t num_attributes = die.GetAttributes(this, fixed_form_sizes, attributes);
|
const size_t num_attributes = die.GetAttributes(dwarf_cu, fixed_form_sizes, attributes);
|
||||||
if (num_attributes > 0)
|
if (num_attributes > 0)
|
||||||
{
|
{
|
||||||
for (uint32_t i=0; i<num_attributes; ++i)
|
for (uint32_t i=0; i<num_attributes; ++i)
|
||||||
|
@ -763,7 +909,7 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
|
|
||||||
case DW_AT_specification:
|
case DW_AT_specification:
|
||||||
if (attributes.ExtractFormValueAtIndex(i, form_value))
|
if (attributes.ExtractFormValueAtIndex(i, form_value))
|
||||||
specification_die_offset = form_value.Reference();
|
specification_die_form = form_value;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -783,15 +929,15 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
ConstString objc_selector_name (objc_method.GetSelector());
|
ConstString objc_selector_name (objc_method.GetSelector());
|
||||||
ConstString objc_fullname_no_category_name (objc_method.GetFullNameWithoutCategory(true));
|
ConstString objc_fullname_no_category_name (objc_method.GetFullNameWithoutCategory(true));
|
||||||
ConstString objc_class_name_no_category (objc_method.GetClassName());
|
ConstString objc_class_name_no_category (objc_method.GetClassName());
|
||||||
func_fullnames.Insert (ConstString(name), die.GetOffset());
|
func_fullnames.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
if (objc_class_name_with_category)
|
if (objc_class_name_with_category)
|
||||||
objc_class_selectors.Insert(objc_class_name_with_category, die.GetOffset());
|
objc_class_selectors.Insert(objc_class_name_with_category, DIERef(cu_offset, die.GetOffset()));
|
||||||
if (objc_class_name_no_category && objc_class_name_no_category != objc_class_name_with_category)
|
if (objc_class_name_no_category && objc_class_name_no_category != objc_class_name_with_category)
|
||||||
objc_class_selectors.Insert(objc_class_name_no_category, die.GetOffset());
|
objc_class_selectors.Insert(objc_class_name_no_category, DIERef(cu_offset, die.GetOffset()));
|
||||||
if (objc_selector_name)
|
if (objc_selector_name)
|
||||||
func_selectors.Insert (objc_selector_name, die.GetOffset());
|
func_selectors.Insert (objc_selector_name, DIERef(cu_offset, die.GetOffset()));
|
||||||
if (objc_fullname_no_category_name)
|
if (objc_fullname_no_category_name)
|
||||||
func_fullnames.Insert (objc_fullname_no_category_name, die.GetOffset());
|
func_fullnames.Insert (objc_fullname_no_category_name, DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
// If we have a mangled name, then the DW_AT_name attribute
|
// If we have a mangled name, then the DW_AT_name attribute
|
||||||
// is usually the method name without the class or any parameters
|
// is usually the method name without the class or any parameters
|
||||||
|
@ -806,9 +952,9 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (specification_die_offset != DW_INVALID_OFFSET)
|
if (specification_die_form.IsValid())
|
||||||
{
|
{
|
||||||
DWARFDIE specification_die = m_dwarf2Data->DebugInfo()->GetDIE (specification_die_offset);
|
DWARFDIE specification_die = dwarf_cu->GetSymbolFileDWARF()->DebugInfo()->GetDIE (DIERef(specification_die_form));
|
||||||
if (specification_die.GetParent().IsStructOrClass())
|
if (specification_die.GetParent().IsStructOrClass())
|
||||||
is_method = true;
|
is_method = true;
|
||||||
}
|
}
|
||||||
|
@ -817,12 +963,12 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
|
|
||||||
|
|
||||||
if (is_method)
|
if (is_method)
|
||||||
func_methods.Insert (ConstString(name), die.GetOffset());
|
func_methods.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
else
|
else
|
||||||
func_basenames.Insert (ConstString(name), die.GetOffset());
|
func_basenames.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
|
|
||||||
if (!is_method && !mangled_cstr && !objc_method.IsValid(true))
|
if (!is_method && !mangled_cstr && !objc_method.IsValid(true))
|
||||||
func_fullnames.Insert (ConstString(name), die.GetOffset());
|
func_fullnames.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
if (mangled_cstr)
|
if (mangled_cstr)
|
||||||
{
|
{
|
||||||
|
@ -833,10 +979,10 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
if (name != mangled_cstr && ((mangled_cstr[0] == '_') || (name && ::strcmp(name, mangled_cstr) != 0)))
|
if (name != mangled_cstr && ((mangled_cstr[0] == '_') || (name && ::strcmp(name, mangled_cstr) != 0)))
|
||||||
{
|
{
|
||||||
Mangled mangled (ConstString(mangled_cstr), true);
|
Mangled mangled (ConstString(mangled_cstr), true);
|
||||||
func_fullnames.Insert (mangled.GetMangledName(), die.GetOffset());
|
func_fullnames.Insert (mangled.GetMangledName(), DIERef(cu_offset, die.GetOffset()));
|
||||||
ConstString demangled = mangled.GetDemangledName(cu_language);
|
ConstString demangled = mangled.GetDemangledName(cu_language);
|
||||||
if (demangled)
|
if (demangled)
|
||||||
func_fullnames.Insert (demangled, die.GetOffset());
|
func_fullnames.Insert (demangled, DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -846,7 +992,7 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
if (has_address)
|
if (has_address)
|
||||||
{
|
{
|
||||||
if (name)
|
if (name)
|
||||||
func_basenames.Insert (ConstString(name), die.GetOffset());
|
func_basenames.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
if (mangled_cstr)
|
if (mangled_cstr)
|
||||||
{
|
{
|
||||||
// Make sure our mangled name isn't the same string table entry
|
// Make sure our mangled name isn't the same string table entry
|
||||||
|
@ -856,14 +1002,14 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
if (name != mangled_cstr && ((mangled_cstr[0] == '_') || (::strcmp(name, mangled_cstr) != 0)))
|
if (name != mangled_cstr && ((mangled_cstr[0] == '_') || (::strcmp(name, mangled_cstr) != 0)))
|
||||||
{
|
{
|
||||||
Mangled mangled (ConstString(mangled_cstr), true);
|
Mangled mangled (ConstString(mangled_cstr), true);
|
||||||
func_fullnames.Insert (mangled.GetMangledName(), die.GetOffset());
|
func_fullnames.Insert (mangled.GetMangledName(), DIERef(cu_offset, die.GetOffset()));
|
||||||
ConstString demangled = mangled.GetDemangledName(cu_language);
|
ConstString demangled = mangled.GetDemangledName(cu_language);
|
||||||
if (demangled)
|
if (demangled)
|
||||||
func_fullnames.Insert (demangled, die.GetOffset());
|
func_fullnames.Insert (demangled, DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
func_fullnames.Insert (ConstString(name), die.GetOffset());
|
func_fullnames.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -879,19 +1025,19 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
case DW_TAG_unspecified_type:
|
case DW_TAG_unspecified_type:
|
||||||
if (name && is_declaration == false)
|
if (name && is_declaration == false)
|
||||||
{
|
{
|
||||||
types.Insert (ConstString(name), die.GetOffset());
|
types.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_TAG_namespace:
|
case DW_TAG_namespace:
|
||||||
if (name)
|
if (name)
|
||||||
namespaces.Insert (ConstString(name), die.GetOffset());
|
namespaces.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_TAG_variable:
|
case DW_TAG_variable:
|
||||||
if (name && has_location && is_global_or_static_variable)
|
if (name && has_location && is_global_or_static_variable)
|
||||||
{
|
{
|
||||||
globals.Insert (ConstString(name), die.GetOffset());
|
globals.Insert (ConstString(name), DIERef(cu_offset, die.GetOffset()));
|
||||||
// Be sure to include variables by their mangled and demangled
|
// Be sure to include variables by their mangled and demangled
|
||||||
// names if they have any since a variable can have a basename
|
// names if they have any since a variable can have a basename
|
||||||
// "i", a mangled named "_ZN12_GLOBAL__N_11iE" and a demangled
|
// "i", a mangled named "_ZN12_GLOBAL__N_11iE" and a demangled
|
||||||
|
@ -904,10 +1050,10 @@ DWARFCompileUnit::Index (const uint32_t cu_idx,
|
||||||
if (mangled_cstr && name != mangled_cstr && ((mangled_cstr[0] == '_') || (::strcmp(name, mangled_cstr) != 0)))
|
if (mangled_cstr && name != mangled_cstr && ((mangled_cstr[0] == '_') || (::strcmp(name, mangled_cstr) != 0)))
|
||||||
{
|
{
|
||||||
Mangled mangled (ConstString(mangled_cstr), true);
|
Mangled mangled (ConstString(mangled_cstr), true);
|
||||||
globals.Insert (mangled.GetMangledName(), die.GetOffset());
|
globals.Insert (mangled.GetMangledName(), DIERef(cu_offset, die.GetOffset()));
|
||||||
ConstString demangled = mangled.GetDemangledName(cu_language);
|
ConstString demangled = mangled.GetDemangledName(cu_language);
|
||||||
if (demangled)
|
if (demangled)
|
||||||
globals.Insert (demangled, die.GetOffset());
|
globals.Insert (demangled, DIERef(cu_offset, die.GetOffset()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1097,3 +1243,18 @@ DWARFCompileUnit::GetTypeSystem ()
|
||||||
else
|
else
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
DWARFCompileUnit::SetUserData(void *d)
|
||||||
|
{
|
||||||
|
m_user_data = d;
|
||||||
|
if (m_dwo_symbol_file)
|
||||||
|
m_dwo_symbol_file->GetCompileUnit()->SetUserData(d);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
DWARFCompileUnit::SetAddrBase(dw_addr_t addr_base, dw_offset_t base_obj_offset)
|
||||||
|
{
|
||||||
|
m_addr_base = addr_base;
|
||||||
|
m_base_obj_offset = base_obj_offset;
|
||||||
|
}
|
||||||
|
|
|
@ -13,9 +13,10 @@
|
||||||
#include "lldb/lldb-enumerations.h"
|
#include "lldb/lldb-enumerations.h"
|
||||||
#include "DWARFDebugInfoEntry.h"
|
#include "DWARFDebugInfoEntry.h"
|
||||||
#include "DWARFDIE.h"
|
#include "DWARFDIE.h"
|
||||||
#include "SymbolFileDWARF.h"
|
|
||||||
|
|
||||||
class NameToDIE;
|
class NameToDIE;
|
||||||
|
class SymbolFileDWARF;
|
||||||
|
class SymbolFileDWARFDwo;
|
||||||
|
|
||||||
class DWARFCompileUnit
|
class DWARFCompileUnit
|
||||||
{
|
{
|
||||||
|
@ -30,6 +31,7 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
DWARFCompileUnit(SymbolFileDWARF* dwarf2Data);
|
DWARFCompileUnit(SymbolFileDWARF* dwarf2Data);
|
||||||
|
~DWARFCompileUnit();
|
||||||
|
|
||||||
bool Extract(const lldb_private::DWARFDataExtractor &debug_info, lldb::offset_t *offset_ptr);
|
bool Extract(const lldb_private::DWARFDataExtractor &debug_info, lldb::offset_t *offset_ptr);
|
||||||
size_t ExtractDIEsIfNeeded (bool cu_die_only);
|
size_t ExtractDIEsIfNeeded (bool cu_die_only);
|
||||||
|
@ -51,11 +53,13 @@ public:
|
||||||
dw_offset_t GetAbbrevOffset() const;
|
dw_offset_t GetAbbrevOffset() const;
|
||||||
uint8_t GetAddressByteSize() const { return m_addr_size; }
|
uint8_t GetAddressByteSize() const { return m_addr_size; }
|
||||||
dw_addr_t GetBaseAddress() const { return m_base_addr; }
|
dw_addr_t GetBaseAddress() const { return m_base_addr; }
|
||||||
dw_addr_t GetAddrBase() const { return 0; } // TODO: Read out DW_AT_addr_base from the parent compile unit
|
dw_addr_t GetAddrBase() const { return m_addr_base; }
|
||||||
|
void SetAddrBase(dw_addr_t addr_base, dw_offset_t base_obj_offset);
|
||||||
void ClearDIEs(bool keep_compile_unit_die);
|
void ClearDIEs(bool keep_compile_unit_die);
|
||||||
void BuildAddressRangeTable (SymbolFileDWARF* dwarf2Data,
|
void BuildAddressRangeTable (SymbolFileDWARF* dwarf2Data,
|
||||||
DWARFDebugAranges* debug_aranges);
|
DWARFDebugAranges* debug_aranges);
|
||||||
|
|
||||||
|
|
||||||
lldb_private::TypeSystem *
|
lldb_private::TypeSystem *
|
||||||
GetTypeSystem();
|
GetTypeSystem();
|
||||||
|
|
||||||
|
@ -97,6 +101,9 @@ public:
|
||||||
m_die_array.push_back(die);
|
m_die_array.push_back(die);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
AddCompileUnitDIE (DWARFDebugInfoEntry& die);
|
||||||
|
|
||||||
bool
|
bool
|
||||||
HasDIEsParsed () const
|
HasDIEsParsed () const
|
||||||
{
|
{
|
||||||
|
@ -125,10 +132,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
SetUserData(void *d)
|
SetUserData(void *d);
|
||||||
{
|
|
||||||
m_user_data = d;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool
|
bool
|
||||||
Supports_DW_AT_APPLE_objc_complete_type ();
|
Supports_DW_AT_APPLE_objc_complete_type ();
|
||||||
|
@ -140,8 +144,7 @@ public:
|
||||||
Supports_unnamed_objc_bitfields ();
|
Supports_unnamed_objc_bitfields ();
|
||||||
|
|
||||||
void
|
void
|
||||||
Index (const uint32_t cu_idx,
|
Index (NameToDIE& func_basenames,
|
||||||
NameToDIE& func_basenames,
|
|
||||||
NameToDIE& func_fullnames,
|
NameToDIE& func_fullnames,
|
||||||
NameToDIE& func_methods,
|
NameToDIE& func_methods,
|
||||||
NameToDIE& func_selectors,
|
NameToDIE& func_selectors,
|
||||||
|
@ -183,8 +186,21 @@ public:
|
||||||
bool
|
bool
|
||||||
GetIsOptimized ();
|
GetIsOptimized ();
|
||||||
|
|
||||||
|
SymbolFileDWARFDwo*
|
||||||
|
GetDwoSymbolFile() const
|
||||||
|
{
|
||||||
|
return m_dwo_symbol_file.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
dw_offset_t
|
||||||
|
GetBaseObjOffset() const
|
||||||
|
{
|
||||||
|
return m_base_obj_offset;
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
SymbolFileDWARF* m_dwarf2Data;
|
SymbolFileDWARF* m_dwarf2Data;
|
||||||
|
std::unique_ptr<SymbolFileDWARFDwo> m_dwo_symbol_file;
|
||||||
const DWARFAbbreviationDeclarationSet *m_abbrevs;
|
const DWARFAbbreviationDeclarationSet *m_abbrevs;
|
||||||
void * m_user_data;
|
void * m_user_data;
|
||||||
DWARFDebugInfoEntry::collection m_die_array; // The compile unit debug information entry item
|
DWARFDebugInfoEntry::collection m_die_array; // The compile unit debug information entry item
|
||||||
|
@ -201,9 +217,27 @@ protected:
|
||||||
lldb::LanguageType m_language_type;
|
lldb::LanguageType m_language_type;
|
||||||
bool m_is_dwarf64;
|
bool m_is_dwarf64;
|
||||||
lldb_private::LazyBool m_is_optimized;
|
lldb_private::LazyBool m_is_optimized;
|
||||||
|
dw_addr_t m_addr_base; // Value of DW_AT_addr_base
|
||||||
|
dw_offset_t m_base_obj_offset; // If this is a dwo compile unit this is the offset of
|
||||||
|
// the base compile unit in the main object file
|
||||||
|
|
||||||
void
|
void
|
||||||
ParseProducerInfo ();
|
ParseProducerInfo ();
|
||||||
|
|
||||||
|
static void
|
||||||
|
IndexPrivate (DWARFCompileUnit* dwarf_cu,
|
||||||
|
const lldb::LanguageType cu_language,
|
||||||
|
const DWARFFormValue::FixedFormSizes& fixed_form_sizes,
|
||||||
|
const dw_offset_t cu_offset,
|
||||||
|
NameToDIE& func_basenames,
|
||||||
|
NameToDIE& func_fullnames,
|
||||||
|
NameToDIE& func_methods,
|
||||||
|
NameToDIE& func_selectors,
|
||||||
|
NameToDIE& objc_class_selectors,
|
||||||
|
NameToDIE& globals,
|
||||||
|
NameToDIE& types,
|
||||||
|
NameToDIE& namespaces);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
const DWARFDebugInfoEntry*
|
const DWARFDebugInfoEntry*
|
||||||
|
|
|
@ -25,6 +25,18 @@
|
||||||
#include "lldb/Core/Module.h"
|
#include "lldb/Core/Module.h"
|
||||||
#include "lldb/Symbol/ObjectFile.h"
|
#include "lldb/Symbol/ObjectFile.h"
|
||||||
|
|
||||||
|
DIERef
|
||||||
|
DWARFDIE::GetDIERef() const
|
||||||
|
{
|
||||||
|
if (!IsValid())
|
||||||
|
return DIERef();
|
||||||
|
|
||||||
|
dw_offset_t cu_offset = m_cu->GetOffset();
|
||||||
|
if (m_cu->GetBaseObjOffset() != DW_INVALID_OFFSET)
|
||||||
|
cu_offset = m_cu->GetBaseObjOffset();
|
||||||
|
return DIERef(cu_offset, m_die->GetOffset());
|
||||||
|
}
|
||||||
|
|
||||||
dw_tag_t
|
dw_tag_t
|
||||||
DWARFDIE::Tag() const
|
DWARFDIE::Tag() const
|
||||||
{
|
{
|
||||||
|
@ -122,6 +134,15 @@ DWARFDIE::GetAttributeValueAsReference (const dw_attr_t attr, uint64_t fail_valu
|
||||||
return fail_value;
|
return fail_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint64_t
|
||||||
|
DWARFDIE::GetAttributeValueAsAddress (const dw_attr_t attr, uint64_t fail_value) const
|
||||||
|
{
|
||||||
|
if (IsValid())
|
||||||
|
return m_die->GetAttributeValueAsAddress(GetDWARF(), GetCU(), attr, fail_value);
|
||||||
|
else
|
||||||
|
return fail_value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
DWARFDIE
|
DWARFDIE
|
||||||
DWARFDIE::LookupDeepestBlock (lldb::addr_t file_addr) const
|
DWARFDIE::LookupDeepestBlock (lldb::addr_t file_addr) const
|
||||||
|
@ -143,7 +164,7 @@ DWARFDIE::LookupDeepestBlock (lldb::addr_t file_addr) const
|
||||||
if (cu->ContainsDIEOffset(block_die->GetOffset()))
|
if (cu->ContainsDIEOffset(block_die->GetOffset()))
|
||||||
return DWARFDIE(cu, block_die);
|
return DWARFDIE(cu, block_die);
|
||||||
else
|
else
|
||||||
return DWARFDIE(dwarf->DebugInfo()->GetCompileUnitContainingDIE(block_die->GetOffset()), block_die);
|
return DWARFDIE(dwarf->DebugInfo()->GetCompileUnitContainingDIE(DIERef(cu->GetOffset(), block_die->GetOffset())), block_die);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -156,11 +177,19 @@ DWARFDIE::GetID () const
|
||||||
const dw_offset_t die_offset = GetOffset();
|
const dw_offset_t die_offset = GetOffset();
|
||||||
if (die_offset != DW_INVALID_OFFSET)
|
if (die_offset != DW_INVALID_OFFSET)
|
||||||
{
|
{
|
||||||
|
lldb::user_id_t id = 0;
|
||||||
SymbolFileDWARF *dwarf = GetDWARF();
|
SymbolFileDWARF *dwarf = GetDWARF();
|
||||||
if (dwarf)
|
if (dwarf)
|
||||||
return dwarf->MakeUserID(die_offset);
|
id = dwarf->MakeUserID(die_offset);
|
||||||
else
|
else
|
||||||
return die_offset;
|
id = die_offset;
|
||||||
|
|
||||||
|
if (m_cu)
|
||||||
|
{
|
||||||
|
assert ((id&0xffffffff00000000ull) == 0 || m_cu->GetOffset() == 0);
|
||||||
|
id |= ((lldb::user_id_t)m_cu->GetOffset()) << 32;
|
||||||
|
}
|
||||||
|
return id;
|
||||||
}
|
}
|
||||||
return LLDB_INVALID_UID;
|
return LLDB_INVALID_UID;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
#include "lldb/lldb-types.h"
|
#include "lldb/lldb-types.h"
|
||||||
#include "lldb/Core/dwarf.h"
|
#include "lldb/Core/dwarf.h"
|
||||||
|
|
||||||
|
struct DIERef;
|
||||||
class DWARFASTParser;
|
class DWARFASTParser;
|
||||||
class DWARFAttributes;
|
class DWARFAttributes;
|
||||||
class DWARFCompileUnit;
|
class DWARFCompileUnit;
|
||||||
|
@ -95,6 +96,9 @@ public:
|
||||||
return m_die;
|
return m_die;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DIERef
|
||||||
|
GetDIERef() const;
|
||||||
|
|
||||||
lldb_private::TypeSystem *
|
lldb_private::TypeSystem *
|
||||||
GetTypeSystem () const;
|
GetTypeSystem () const;
|
||||||
|
|
||||||
|
@ -232,6 +236,9 @@ public:
|
||||||
uint64_t
|
uint64_t
|
||||||
GetAttributeValueAsReference (const dw_attr_t attr, uint64_t fail_value) const;
|
GetAttributeValueAsReference (const dw_attr_t attr, uint64_t fail_value) const;
|
||||||
|
|
||||||
|
uint64_t
|
||||||
|
GetAttributeValueAsAddress (const dw_attr_t attr, uint64_t fail_value) const;
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
GetAttributes (DWARFAttributes &attributes, uint32_t depth = 0) const;
|
GetAttributes (DWARFAttributes &attributes, uint32_t depth = 0) const;
|
||||||
|
|
||||||
|
|
|
@ -103,48 +103,6 @@ DWARFDebugInfo::GetCompileUnitAranges ()
|
||||||
return *m_cu_aranges_ap.get();
|
return *m_cu_aranges_ap.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
// LookupAddress
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
DWARFDIE
|
|
||||||
DWARFDebugInfo::LookupAddress (const dw_addr_t address,
|
|
||||||
const dw_offset_t hint_die_offset)
|
|
||||||
{
|
|
||||||
DWARFDIE die;
|
|
||||||
DWARFCompileUnit *cu = nullptr;
|
|
||||||
if (hint_die_offset != DW_INVALID_OFFSET)
|
|
||||||
{
|
|
||||||
cu = GetCompileUnit(hint_die_offset);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DWARFDebugAranges &cu_aranges = GetCompileUnitAranges ();
|
|
||||||
const dw_offset_t cu_offset = cu_aranges.FindAddress (address);
|
|
||||||
cu = GetCompileUnit(cu_offset);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cu)
|
|
||||||
{
|
|
||||||
die = cu->LookupAddress(address);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// The hint_die_offset may have been a pointer to the actual item that
|
|
||||||
// we are looking for
|
|
||||||
die = GetDIE(hint_die_offset);
|
|
||||||
if (die)
|
|
||||||
{
|
|
||||||
DWARFDebugInfoEntry* function_die = nullptr;
|
|
||||||
|
|
||||||
if (die.GetDIE()->LookupAddress (address, die.GetDWARF(), die.GetCU(), &function_die, nullptr))
|
|
||||||
die.Set (die.GetCU(), function_die);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return die;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
DWARFDebugInfo::ParseCompileUnitHeadersIfNeeded()
|
DWARFDebugInfo::ParseCompileUnitHeadersIfNeeded()
|
||||||
{
|
{
|
||||||
|
@ -251,10 +209,18 @@ DWARFDebugInfo::GetCompileUnit(dw_offset_t cu_offset, uint32_t* idx_ptr)
|
||||||
}
|
}
|
||||||
|
|
||||||
DWARFCompileUnit *
|
DWARFCompileUnit *
|
||||||
DWARFDebugInfo::GetCompileUnitContainingDIE (dw_offset_t die_offset)
|
DWARFDebugInfo::GetCompileUnitContainingDIE (const DIERef& die_ref)
|
||||||
{
|
{
|
||||||
|
dw_offset_t search_offset = die_ref.die_offset;
|
||||||
|
bool is_cu_offset = false;
|
||||||
|
if (m_dwarf2Data->GetID() == 0 && die_ref.cu_offset != DW_INVALID_OFFSET)
|
||||||
|
{
|
||||||
|
is_cu_offset = true;
|
||||||
|
search_offset = die_ref.cu_offset;
|
||||||
|
}
|
||||||
|
|
||||||
DWARFCompileUnitSP cu_sp;
|
DWARFCompileUnitSP cu_sp;
|
||||||
if (die_offset != DW_INVALID_OFFSET)
|
if (search_offset != DW_INVALID_OFFSET)
|
||||||
{
|
{
|
||||||
ParseCompileUnitHeadersIfNeeded();
|
ParseCompileUnitHeadersIfNeeded();
|
||||||
|
|
||||||
|
@ -262,19 +228,25 @@ DWARFDebugInfo::GetCompileUnitContainingDIE (dw_offset_t die_offset)
|
||||||
const size_t num_cus = m_compile_units.size();
|
const size_t num_cus = m_compile_units.size();
|
||||||
if (num_cus == 1)
|
if (num_cus == 1)
|
||||||
{
|
{
|
||||||
if (m_compile_units[0]->ContainsDIEOffset(die_offset))
|
if ((is_cu_offset && m_compile_units[0]->GetOffset() == search_offset) ||
|
||||||
|
(!is_cu_offset && m_compile_units[0]->ContainsDIEOffset(search_offset)))
|
||||||
|
{
|
||||||
cu_sp = m_compile_units[0];
|
cu_sp = m_compile_units[0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (num_cus)
|
else if (num_cus)
|
||||||
{
|
{
|
||||||
CompileUnitColl::const_iterator end_pos = m_compile_units.end();
|
CompileUnitColl::const_iterator end_pos = m_compile_units.end();
|
||||||
CompileUnitColl::const_iterator begin_pos = m_compile_units.begin();
|
CompileUnitColl::const_iterator begin_pos = m_compile_units.begin();
|
||||||
CompileUnitColl::const_iterator pos = std::upper_bound(begin_pos, end_pos, die_offset, OffsetLessThanCompileUnitOffset);
|
CompileUnitColl::const_iterator pos = std::upper_bound(begin_pos, end_pos, search_offset, OffsetLessThanCompileUnitOffset);
|
||||||
if (pos != begin_pos)
|
if (pos != begin_pos)
|
||||||
{
|
{
|
||||||
--pos;
|
--pos;
|
||||||
if ((*pos)->ContainsDIEOffset(die_offset))
|
if ((is_cu_offset && (*pos)->GetOffset() == search_offset) ||
|
||||||
|
(!is_cu_offset && (*pos)->ContainsDIEOffset(search_offset)))
|
||||||
|
{
|
||||||
cu_sp = *pos;
|
cu_sp = *pos;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -287,11 +259,11 @@ DWARFDebugInfo::GetCompileUnitContainingDIE (dw_offset_t die_offset)
|
||||||
// Get the DIE (Debug Information Entry) with the specified offset.
|
// Get the DIE (Debug Information Entry) with the specified offset.
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
DWARFDIE
|
DWARFDIE
|
||||||
DWARFDebugInfo::GetDIE(dw_offset_t die_offset)
|
DWARFDebugInfo::GetDIE(const DIERef& die_ref)
|
||||||
{
|
{
|
||||||
DWARFCompileUnit *cu = GetCompileUnitContainingDIE(die_offset);
|
DWARFCompileUnit *cu = GetCompileUnitContainingDIE(die_ref);
|
||||||
if (cu)
|
if (cu)
|
||||||
return cu->GetDIE (die_offset);
|
return cu->GetDIE (die_ref.die_offset);
|
||||||
return DWARFDIE(); // Not found
|
return DWARFDIE(); // Not found
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -36,18 +36,13 @@ public:
|
||||||
DWARFDebugInfo();
|
DWARFDebugInfo();
|
||||||
void SetDwarfData(SymbolFileDWARF* dwarf2Data);
|
void SetDwarfData(SymbolFileDWARF* dwarf2Data);
|
||||||
|
|
||||||
DWARFDIE
|
|
||||||
LookupAddress(const dw_addr_t address,
|
|
||||||
const dw_offset_t cu_offset); // Can be valid (find in .debug_aranges), or DW_INVALID_OFFSET if we need to search manually
|
|
||||||
|
|
||||||
size_t GetNumCompileUnits();
|
size_t GetNumCompileUnits();
|
||||||
bool ContainsCompileUnit (const DWARFCompileUnit *cu) const;
|
bool ContainsCompileUnit (const DWARFCompileUnit *cu) const;
|
||||||
DWARFCompileUnit* GetCompileUnitAtIndex (uint32_t idx);
|
DWARFCompileUnit* GetCompileUnitAtIndex (uint32_t idx);
|
||||||
DWARFCompileUnit* GetCompileUnit (dw_offset_t cu_offset, uint32_t* idx_ptr = NULL);
|
DWARFCompileUnit* GetCompileUnit (dw_offset_t cu_offset, uint32_t* idx_ptr = NULL);
|
||||||
DWARFCompileUnit* GetCompileUnitContainingDIE (dw_offset_t die_offset);
|
DWARFCompileUnit* GetCompileUnitContainingDIE (const DIERef& die_ref);
|
||||||
|
|
||||||
DWARFDIE GetDIE (dw_offset_t die_offset);
|
DWARFDIE GetDIE (const DIERef& die_ref);
|
||||||
DWARFDIE GetDIEContainingOffset (dw_offset_t die_offset);
|
|
||||||
|
|
||||||
void Dump(lldb_private::Stream *s, const uint32_t die_offset, const uint32_t recurse_depth);
|
void Dump(lldb_private::Stream *s, const uint32_t die_offset, const uint32_t recurse_depth);
|
||||||
static void Parse(SymbolFileDWARF* parser, Callback callback, void* userData);
|
static void Parse(SymbolFileDWARF* parser, Callback callback, void* userData);
|
||||||
|
|
|
@ -19,7 +19,6 @@
|
||||||
#include "lldb/Symbol/ObjectFile.h"
|
#include "lldb/Symbol/ObjectFile.h"
|
||||||
|
|
||||||
#include "DWARFCompileUnit.h"
|
#include "DWARFCompileUnit.h"
|
||||||
#include "SymbolFileDWARF.h"
|
|
||||||
#include "DWARFDebugAbbrev.h"
|
#include "DWARFDebugAbbrev.h"
|
||||||
#include "DWARFDebugAranges.h"
|
#include "DWARFDebugAranges.h"
|
||||||
#include "DWARFDebugInfo.h"
|
#include "DWARFDebugInfo.h"
|
||||||
|
@ -29,6 +28,8 @@
|
||||||
#include "DWARFLocationDescription.h"
|
#include "DWARFLocationDescription.h"
|
||||||
#include "DWARFLocationList.h"
|
#include "DWARFLocationList.h"
|
||||||
#include "DWARFDebugRanges.h"
|
#include "DWARFDebugRanges.h"
|
||||||
|
#include "SymbolFileDWARF.h"
|
||||||
|
#include "SymbolFileDWARFDwo.h"
|
||||||
|
|
||||||
using namespace lldb_private;
|
using namespace lldb_private;
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
@ -245,7 +246,7 @@ DWARFDebugInfoEntry::Extract
|
||||||
if (form_value.ExtractValue(debug_info_data, &offset))
|
if (form_value.ExtractValue(debug_info_data, &offset))
|
||||||
{
|
{
|
||||||
if (attr == DW_AT_low_pc || attr == DW_AT_entry_pc)
|
if (attr == DW_AT_low_pc || attr == DW_AT_entry_pc)
|
||||||
((DWARFCompileUnit*)cu)->SetBaseAddress(form_value.Unsigned());
|
const_cast<DWARFCompileUnit*>(cu)->SetBaseAddress(form_value.Address());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -403,12 +404,27 @@ DWARFDebugInfoEntry::GetDIENamesAndRanges
|
||||||
DWARFExpression *frame_base
|
DWARFExpression *frame_base
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
if (dwarf2Data == NULL)
|
if (dwarf2Data == nullptr)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
SymbolFileDWARFDwo* dwo_symbol_file = cu->GetDwoSymbolFile();
|
||||||
|
if (dwo_symbol_file)
|
||||||
|
return GetDIENamesAndRanges(dwo_symbol_file,
|
||||||
|
dwo_symbol_file->GetCompileUnit(),
|
||||||
|
name,
|
||||||
|
mangled,
|
||||||
|
ranges,
|
||||||
|
decl_file,
|
||||||
|
decl_line,
|
||||||
|
decl_column,
|
||||||
|
call_file,
|
||||||
|
call_line,
|
||||||
|
call_column,
|
||||||
|
frame_base);
|
||||||
|
|
||||||
dw_addr_t lo_pc = LLDB_INVALID_ADDRESS;
|
dw_addr_t lo_pc = LLDB_INVALID_ADDRESS;
|
||||||
dw_addr_t hi_pc = LLDB_INVALID_ADDRESS;
|
dw_addr_t hi_pc = LLDB_INVALID_ADDRESS;
|
||||||
std::vector<dw_offset_t> die_offsets;
|
std::vector<DIERef> die_refs;
|
||||||
bool set_frame_base_loclist_addr = false;
|
bool set_frame_base_loclist_addr = false;
|
||||||
|
|
||||||
lldb::offset_t offset;
|
lldb::offset_t offset;
|
||||||
|
@ -438,7 +454,7 @@ DWARFDebugInfoEntry::GetDIENamesAndRanges
|
||||||
switch (attr)
|
switch (attr)
|
||||||
{
|
{
|
||||||
case DW_AT_low_pc:
|
case DW_AT_low_pc:
|
||||||
lo_pc = form_value.Unsigned();
|
lo_pc = form_value.Address();
|
||||||
|
|
||||||
if (do_offset)
|
if (do_offset)
|
||||||
hi_pc += lo_pc;
|
hi_pc += lo_pc;
|
||||||
|
@ -446,13 +462,18 @@ DWARFDebugInfoEntry::GetDIENamesAndRanges
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_entry_pc:
|
case DW_AT_entry_pc:
|
||||||
lo_pc = form_value.Unsigned();
|
lo_pc = form_value.Address();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_high_pc:
|
case DW_AT_high_pc:
|
||||||
hi_pc = form_value.Unsigned();
|
if (form_value.Form() == DW_FORM_addr ||
|
||||||
if (form_value.Form() != DW_FORM_addr)
|
form_value.Form() == DW_FORM_GNU_addr_index)
|
||||||
{
|
{
|
||||||
|
hi_pc = form_value.Address();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hi_pc = form_value.Unsigned();
|
||||||
if (lo_pc == LLDB_INVALID_ADDRESS)
|
if (lo_pc == LLDB_INVALID_ADDRESS)
|
||||||
do_offset = hi_pc != LLDB_INVALID_ADDRESS;
|
do_offset = hi_pc != LLDB_INVALID_ADDRESS;
|
||||||
else
|
else
|
||||||
|
@ -483,11 +504,11 @@ DWARFDebugInfoEntry::GetDIENamesAndRanges
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_abstract_origin:
|
case DW_AT_abstract_origin:
|
||||||
die_offsets.push_back(form_value.Reference());
|
die_refs.emplace_back(form_value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_specification:
|
case DW_AT_specification:
|
||||||
die_offsets.push_back(form_value.Reference());
|
die_refs.emplace_back(form_value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DW_AT_decl_file:
|
case DW_AT_decl_file:
|
||||||
|
@ -579,14 +600,11 @@ DWARFDebugInfoEntry::GetDIENamesAndRanges
|
||||||
|
|
||||||
if (ranges.IsEmpty() || name == NULL || mangled == NULL)
|
if (ranges.IsEmpty() || name == NULL || mangled == NULL)
|
||||||
{
|
{
|
||||||
std::vector<dw_offset_t>::const_iterator pos;
|
for (const DIERef& die_ref : die_refs)
|
||||||
std::vector<dw_offset_t>::const_iterator end = die_offsets.end();
|
|
||||||
for (pos = die_offsets.begin(); pos != end; ++pos)
|
|
||||||
{
|
{
|
||||||
dw_offset_t die_offset = *pos;
|
if (die_ref.die_offset != DW_INVALID_OFFSET)
|
||||||
if (die_offset != DW_INVALID_OFFSET)
|
|
||||||
{
|
{
|
||||||
DWARFDIE die = dwarf2Data->DebugInfo()->GetDIE(die_offset);
|
DWARFDIE die = dwarf2Data->DebugInfo()->GetDIE(die_ref);
|
||||||
if (die)
|
if (die)
|
||||||
die.GetDIE()->GetDIENamesAndRanges(die.GetDWARF(), die.GetCU(), name, mangled, ranges, decl_file, decl_line, decl_column, call_file, call_line, call_column);
|
die.GetDIE()->GetDIENamesAndRanges(die.GetDWARF(), die.GetCU(), name, mangled, ranges, decl_file, decl_line, decl_column, call_file, call_line, call_column);
|
||||||
}
|
}
|
||||||
|
@ -867,6 +885,16 @@ DWARFDebugInfoEntry::GetAttributes (const DWARFCompileUnit* cu,
|
||||||
lldb::offset_t offset = 0;
|
lldb::offset_t offset = 0;
|
||||||
if (cu)
|
if (cu)
|
||||||
{
|
{
|
||||||
|
if (m_tag != DW_TAG_compile_unit)
|
||||||
|
{
|
||||||
|
SymbolFileDWARFDwo* dwo_symbol_file = cu->GetDwoSymbolFile();
|
||||||
|
if (dwo_symbol_file)
|
||||||
|
return GetAttributes(dwo_symbol_file->GetCompileUnit(),
|
||||||
|
fixed_form_sizes,
|
||||||
|
attributes,
|
||||||
|
curr_depth);
|
||||||
|
}
|
||||||
|
|
||||||
dwarf2Data = cu->GetSymbolFileDWARF();
|
dwarf2Data = cu->GetSymbolFileDWARF();
|
||||||
abbrevDecl = GetAbbreviationDeclarationPtr(dwarf2Data, cu, offset);
|
abbrevDecl = GetAbbreviationDeclarationPtr(dwarf2Data, cu, offset);
|
||||||
}
|
}
|
||||||
|
@ -951,9 +979,19 @@ DWARFDebugInfoEntry::GetAttributeValue
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
DWARFFormValue& form_value,
|
DWARFFormValue& form_value,
|
||||||
dw_offset_t* end_attr_offset_ptr
|
dw_offset_t* end_attr_offset_ptr,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
|
SymbolFileDWARFDwo* dwo_symbol_file = cu->GetDwoSymbolFile();
|
||||||
|
if (dwo_symbol_file && m_tag != DW_TAG_compile_unit)
|
||||||
|
return GetAttributeValue(dwo_symbol_file,
|
||||||
|
dwo_symbol_file->GetCompileUnit(),
|
||||||
|
attr,
|
||||||
|
form_value,
|
||||||
|
end_attr_offset_ptr,
|
||||||
|
check_specification_or_abstract_origin);
|
||||||
|
|
||||||
lldb::offset_t offset;
|
lldb::offset_t offset;
|
||||||
const DWARFAbbreviationDeclaration* abbrevDecl = GetAbbreviationDeclarationPtr(dwarf2Data, cu, offset);
|
const DWARFAbbreviationDeclaration* abbrevDecl = GetAbbreviationDeclarationPtr(dwarf2Data, cu, offset);
|
||||||
|
|
||||||
|
@ -981,7 +1019,58 @@ DWARFDebugInfoEntry::GetAttributeValue
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
if (check_specification_or_abstract_origin)
|
||||||
|
{
|
||||||
|
if (GetAttributeValue(dwarf2Data, cu, DW_AT_specification, form_value))
|
||||||
|
{
|
||||||
|
DWARFDIE die = const_cast<DWARFCompileUnit*>(cu)->GetDIE(form_value.Reference());
|
||||||
|
if (die)
|
||||||
|
{
|
||||||
|
dw_offset_t die_offset = die.GetDIE()->GetAttributeValue(die.GetDWARF(),
|
||||||
|
die.GetCU(),
|
||||||
|
attr,
|
||||||
|
form_value,
|
||||||
|
end_attr_offset_ptr,
|
||||||
|
false);
|
||||||
|
if (die_offset)
|
||||||
|
return die_offset;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (GetAttributeValue(dwarf2Data, cu, DW_AT_abstract_origin, form_value))
|
||||||
|
{
|
||||||
|
DWARFDIE die = const_cast<DWARFCompileUnit*>(cu)->GetDIE(form_value.Reference());
|
||||||
|
if (die)
|
||||||
|
{
|
||||||
|
dw_offset_t die_offset = die.GetDIE()->GetAttributeValue(die.GetDWARF(),
|
||||||
|
die.GetCU(),
|
||||||
|
attr,
|
||||||
|
form_value,
|
||||||
|
end_attr_offset_ptr,
|
||||||
|
false);
|
||||||
|
if (die_offset)
|
||||||
|
return die_offset;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!dwo_symbol_file)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
DWARFCompileUnit* dwo_cu = dwo_symbol_file->GetCompileUnit();
|
||||||
|
if (!dwo_cu)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
DWARFDIE dwo_cu_die = dwo_cu->GetCompileUnitDIEOnly();
|
||||||
|
if (!dwo_cu_die.IsValid())
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return dwo_cu_die.GetDIE()->GetAttributeValue(dwo_symbol_file,
|
||||||
|
dwo_cu,
|
||||||
|
attr,
|
||||||
|
form_value,
|
||||||
|
end_attr_offset_ptr,
|
||||||
|
check_specification_or_abstract_origin);
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
|
@ -998,10 +1087,11 @@ DWARFDebugInfoEntry::GetAttributeValueAsString
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
const char* fail_value) const
|
const char* fail_value,
|
||||||
|
bool check_specification_or_abstract_origin) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
DWARFFormValue form_value;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, attr, form_value))
|
if (GetAttributeValue(dwarf2Data, cu, attr, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
return form_value.AsCString();
|
return form_value.AsCString();
|
||||||
return fail_value;
|
return fail_value;
|
||||||
}
|
}
|
||||||
|
@ -1017,11 +1107,12 @@ DWARFDebugInfoEntry::GetAttributeValueAsUnsigned
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
uint64_t fail_value
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
DWARFFormValue form_value;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, attr, form_value))
|
if (GetAttributeValue(dwarf2Data, cu, attr, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
return form_value.Unsigned();
|
return form_value.Unsigned();
|
||||||
return fail_value;
|
return fail_value;
|
||||||
}
|
}
|
||||||
|
@ -1037,11 +1128,12 @@ DWARFDebugInfoEntry::GetAttributeValueAsSigned
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
int64_t fail_value
|
int64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
DWARFFormValue form_value;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, attr, form_value))
|
if (GetAttributeValue(dwarf2Data, cu, attr, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
return form_value.Signed();
|
return form_value.Signed();
|
||||||
return fail_value;
|
return fail_value;
|
||||||
}
|
}
|
||||||
|
@ -1058,15 +1150,32 @@ DWARFDebugInfoEntry::GetAttributeValueAsReference
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
uint64_t fail_value
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
DWARFFormValue form_value;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, attr, form_value))
|
if (GetAttributeValue(dwarf2Data, cu, attr, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
return form_value.Reference();
|
return form_value.Reference();
|
||||||
return fail_value;
|
return fail_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint64_t
|
||||||
|
DWARFDebugInfoEntry::GetAttributeValueAsAddress
|
||||||
|
(
|
||||||
|
SymbolFileDWARF* dwarf2Data,
|
||||||
|
const DWARFCompileUnit* cu,
|
||||||
|
const dw_attr_t attr,
|
||||||
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
|
) const
|
||||||
|
{
|
||||||
|
DWARFFormValue form_value;
|
||||||
|
if (GetAttributeValue(dwarf2Data, cu, attr, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
|
return form_value.Address();
|
||||||
|
return fail_value;
|
||||||
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
// GetAttributeHighPC
|
// GetAttributeHighPC
|
||||||
//
|
//
|
||||||
|
@ -1081,11 +1190,12 @@ DWARFDebugInfoEntry::GetAttributeHighPC
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
dw_addr_t lo_pc,
|
dw_addr_t lo_pc,
|
||||||
uint64_t fail_value
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
DWARFFormValue form_value;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_high_pc, form_value))
|
if (GetAttributeValue(dwarf2Data, cu, DW_AT_high_pc, form_value, nullptr, check_specification_or_abstract_origin))
|
||||||
{
|
{
|
||||||
dw_form_t form = form_value.Form();
|
dw_form_t form = form_value.Form();
|
||||||
if (form == DW_FORM_addr || form == DW_FORM_GNU_addr_index)
|
if (form == DW_FORM_addr || form == DW_FORM_GNU_addr_index)
|
||||||
|
@ -1112,13 +1222,14 @@ DWARFDebugInfoEntry::GetAttributeAddressRange
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
dw_addr_t& lo_pc,
|
dw_addr_t& lo_pc,
|
||||||
dw_addr_t& hi_pc,
|
dw_addr_t& hi_pc,
|
||||||
uint64_t fail_value
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
lo_pc = GetAttributeValueAsUnsigned(dwarf2Data, cu, DW_AT_low_pc, fail_value);
|
lo_pc = GetAttributeValueAsAddress(dwarf2Data, cu, DW_AT_low_pc, fail_value, check_specification_or_abstract_origin);
|
||||||
if (lo_pc != fail_value)
|
if (lo_pc != fail_value)
|
||||||
{
|
{
|
||||||
hi_pc = GetAttributeHighPC(dwarf2Data, cu, lo_pc, fail_value);
|
hi_pc = GetAttributeHighPC(dwarf2Data, cu, lo_pc, fail_value, check_specification_or_abstract_origin);
|
||||||
if (hi_pc != fail_value)
|
if (hi_pc != fail_value)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1131,11 +1242,16 @@ size_t
|
||||||
DWARFDebugInfoEntry::GetAttributeAddressRanges (SymbolFileDWARF* dwarf2Data,
|
DWARFDebugInfoEntry::GetAttributeAddressRanges (SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
DWARFRangeList &ranges,
|
DWARFRangeList &ranges,
|
||||||
bool check_hi_lo_pc) const
|
bool check_hi_lo_pc,
|
||||||
|
bool check_specification_or_abstract_origin) const
|
||||||
{
|
{
|
||||||
ranges.Clear();
|
ranges.Clear();
|
||||||
|
|
||||||
dw_offset_t debug_ranges_offset = GetAttributeValueAsUnsigned(dwarf2Data, cu, DW_AT_ranges, DW_INVALID_OFFSET);
|
dw_offset_t debug_ranges_offset = GetAttributeValueAsUnsigned(dwarf2Data,
|
||||||
|
cu,
|
||||||
|
DW_AT_ranges,
|
||||||
|
DW_INVALID_OFFSET,
|
||||||
|
check_specification_or_abstract_origin);
|
||||||
if (debug_ranges_offset != DW_INVALID_OFFSET)
|
if (debug_ranges_offset != DW_INVALID_OFFSET)
|
||||||
{
|
{
|
||||||
DWARFDebugRanges* debug_ranges = dwarf2Data->DebugRanges();
|
DWARFDebugRanges* debug_ranges = dwarf2Data->DebugRanges();
|
||||||
|
@ -1147,7 +1263,7 @@ DWARFDebugInfoEntry::GetAttributeAddressRanges (SymbolFileDWARF* dwarf2Data,
|
||||||
{
|
{
|
||||||
dw_addr_t lo_pc = LLDB_INVALID_ADDRESS;
|
dw_addr_t lo_pc = LLDB_INVALID_ADDRESS;
|
||||||
dw_addr_t hi_pc = LLDB_INVALID_ADDRESS;
|
dw_addr_t hi_pc = LLDB_INVALID_ADDRESS;
|
||||||
if (GetAttributeAddressRange (dwarf2Data, cu, lo_pc, hi_pc, LLDB_INVALID_ADDRESS))
|
if (GetAttributeAddressRange (dwarf2Data, cu, lo_pc, hi_pc, LLDB_INVALID_ADDRESS, check_specification_or_abstract_origin))
|
||||||
{
|
{
|
||||||
if (lo_pc < hi_pc)
|
if (lo_pc < hi_pc)
|
||||||
ranges.Append(DWARFRangeList::Entry(lo_pc, hi_pc - lo_pc));
|
ranges.Append(DWARFRangeList::Entry(lo_pc, hi_pc - lo_pc));
|
||||||
|
@ -1156,56 +1272,6 @@ DWARFDebugInfoEntry::GetAttributeAddressRanges (SymbolFileDWARF* dwarf2Data,
|
||||||
return ranges.GetSize();
|
return ranges.GetSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
// GetAttributeValueAsLocation
|
|
||||||
//
|
|
||||||
// Get the value of an attribute as reference and fix up and compile
|
|
||||||
// unit relative offsets as needed.
|
|
||||||
//----------------------------------------------------------------------
|
|
||||||
dw_offset_t
|
|
||||||
DWARFDebugInfoEntry::GetAttributeValueAsLocation
|
|
||||||
(
|
|
||||||
SymbolFileDWARF* dwarf2Data,
|
|
||||||
const DWARFCompileUnit* cu,
|
|
||||||
const dw_attr_t attr,
|
|
||||||
DWARFDataExtractor& location_data,
|
|
||||||
uint32_t &block_size
|
|
||||||
) const
|
|
||||||
{
|
|
||||||
block_size = 0;
|
|
||||||
DWARFFormValue form_value;
|
|
||||||
|
|
||||||
// Empty out data in case we don't find anything
|
|
||||||
location_data.Clear();
|
|
||||||
dw_offset_t end_addr_offset = DW_INVALID_OFFSET;
|
|
||||||
const dw_offset_t attr_offset = GetAttributeValue(dwarf2Data, cu, attr, form_value, &end_addr_offset);
|
|
||||||
if (attr_offset)
|
|
||||||
{
|
|
||||||
const uint8_t* blockData = form_value.BlockData();
|
|
||||||
if (blockData)
|
|
||||||
{
|
|
||||||
// We have an inlined location list in the .debug_info section
|
|
||||||
const DWARFDataExtractor& debug_info = dwarf2Data->get_debug_info_data();
|
|
||||||
dw_offset_t block_offset = blockData - debug_info.GetDataStart();
|
|
||||||
block_size = (end_addr_offset - attr_offset) - form_value.Unsigned();
|
|
||||||
location_data.SetData(debug_info, block_offset, block_size);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// We have a location list offset as the value that is
|
|
||||||
// the offset into the .debug_loc section that describes
|
|
||||||
// the value over it's lifetime
|
|
||||||
lldb::offset_t debug_loc_offset = form_value.Unsigned();
|
|
||||||
if (dwarf2Data)
|
|
||||||
{
|
|
||||||
assert(dwarf2Data->get_debug_loc_data().GetAddressByteSize() == cu->GetAddressByteSize());
|
|
||||||
return DWARFLocationList::Extract(dwarf2Data->get_debug_loc_data(), &debug_loc_offset, location_data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return attr_offset;
|
|
||||||
}
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
// GetName
|
// GetName
|
||||||
//
|
//
|
||||||
|
@ -1219,25 +1285,9 @@ DWARFDebugInfoEntry::GetName
|
||||||
const DWARFCompileUnit* cu
|
const DWARFCompileUnit* cu
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
return GetAttributeValueAsString(dwarf2Data, cu, DW_AT_name, nullptr, true);
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_name, form_value))
|
|
||||||
return form_value.AsCString();
|
|
||||||
else if (GetAttributeValue(dwarf2Data, cu, DW_AT_specification, form_value))
|
|
||||||
{
|
|
||||||
DWARFDIE die = const_cast<DWARFCompileUnit*>(cu)->GetDIE(form_value.Reference());
|
|
||||||
if (die)
|
|
||||||
return die.GetName();
|
|
||||||
}
|
|
||||||
else if (GetAttributeValue(dwarf2Data, cu, DW_AT_abstract_origin, form_value))
|
|
||||||
{
|
|
||||||
DWARFDIE die = const_cast<DWARFCompileUnit*>(cu)->GetDIE(form_value.Reference());
|
|
||||||
if (die)
|
|
||||||
return die.GetName();
|
|
||||||
}
|
|
||||||
return nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//----------------------------------------------------------------------
|
//----------------------------------------------------------------------
|
||||||
// GetMangledName
|
// GetMangledName
|
||||||
//
|
//
|
||||||
|
@ -1253,19 +1303,19 @@ DWARFDebugInfoEntry::GetMangledName
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
const char* name = nullptr;
|
const char* name = nullptr;
|
||||||
DWARFFormValue form_value;
|
|
||||||
|
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_MIPS_linkage_name, form_value))
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_MIPS_linkage_name, nullptr, true);
|
||||||
name = form_value.AsCString();
|
if (name)
|
||||||
|
return name;
|
||||||
|
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_linkage_name, form_value))
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_linkage_name, nullptr, true);
|
||||||
name = form_value.AsCString();
|
if (name)
|
||||||
|
return name;
|
||||||
|
|
||||||
if (substitute_name_allowed && name == nullptr)
|
if (!substitute_name_allowed)
|
||||||
{
|
return nullptr;
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_name, form_value))
|
|
||||||
name = form_value.AsCString();
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_name, nullptr, true);
|
||||||
}
|
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1283,24 +1333,19 @@ DWARFDebugInfoEntry::GetPubname
|
||||||
const DWARFCompileUnit* cu
|
const DWARFCompileUnit* cu
|
||||||
) const
|
) const
|
||||||
{
|
{
|
||||||
const char* name = NULL;
|
const char* name = nullptr;
|
||||||
if (!dwarf2Data)
|
if (!dwarf2Data)
|
||||||
return name;
|
return name;
|
||||||
|
|
||||||
DWARFFormValue form_value;
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_MIPS_linkage_name, nullptr, true);
|
||||||
|
if (name)
|
||||||
|
return name;
|
||||||
|
|
||||||
if (GetAttributeValue(dwarf2Data, cu, DW_AT_MIPS_linkage_name, form_value))
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_linkage_name, nullptr, true);
|
||||||
name = form_value.AsCString();
|
if (name)
|
||||||
else if (GetAttributeValue(dwarf2Data, cu, DW_AT_linkage_name, form_value))
|
return name;
|
||||||
name = form_value.AsCString();
|
|
||||||
else if (GetAttributeValue(dwarf2Data, cu, DW_AT_name, form_value))
|
name = GetAttributeValueAsString(dwarf2Data, cu, DW_AT_name, nullptr, true);
|
||||||
name = form_value.AsCString();
|
|
||||||
else if (GetAttributeValue(dwarf2Data, cu, DW_AT_specification, form_value))
|
|
||||||
{
|
|
||||||
DWARFDIE die = const_cast<DWARFCompileUnit*>(cu)->GetDIE(form_value.Reference());
|
|
||||||
if (die)
|
|
||||||
name = die.GetPubname();
|
|
||||||
}
|
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1340,15 +1385,11 @@ DWARFDebugInfoEntry::GetName
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
DWARFFormValue form_value;
|
const char* name = die.GetAttributeValueAsString(dwarf2Data, cu, DW_AT_name, nullptr, true);
|
||||||
if (die.GetAttributeValue(dwarf2Data, cu, DW_AT_name, form_value))
|
if (name)
|
||||||
{
|
{
|
||||||
const char* name = form_value.AsCString();
|
s.PutCString(name);
|
||||||
if (name)
|
return true;
|
||||||
{
|
|
||||||
s.PutCString(name);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1390,8 +1431,6 @@ DWARFDebugInfoEntry::AppendTypeName
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
const char* name = die.GetPubname(dwarf2Data, cu);
|
const char* name = die.GetPubname(dwarf2Data, cu);
|
||||||
// if (die.GetAttributeValue(dwarf2Data, cu, DW_AT_name, form_value))
|
|
||||||
// name = form_value.AsCString(&dwarf2Data->get_debug_str_data());
|
|
||||||
if (name)
|
if (name)
|
||||||
s.PutCString(name);
|
s.PutCString(name);
|
||||||
else
|
else
|
||||||
|
@ -1810,7 +1849,7 @@ DWARFDebugInfoEntry::LookupAddress
|
||||||
|
|
||||||
if (match_addr_range)
|
if (match_addr_range)
|
||||||
{
|
{
|
||||||
dw_addr_t lo_pc = GetAttributeValueAsUnsigned(dwarf2Data, cu, DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
dw_addr_t lo_pc = GetAttributeValueAsAddress(dwarf2Data, cu, DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
||||||
if (lo_pc != LLDB_INVALID_ADDRESS)
|
if (lo_pc != LLDB_INVALID_ADDRESS)
|
||||||
{
|
{
|
||||||
dw_addr_t hi_pc = GetAttributeHighPC(dwarf2Data, cu, lo_pc, LLDB_INVALID_ADDRESS);
|
dw_addr_t hi_pc = GetAttributeHighPC(dwarf2Data, cu, lo_pc, LLDB_INVALID_ADDRESS);
|
||||||
|
|
|
@ -115,62 +115,62 @@ public:
|
||||||
DWARFAttributes& attrs,
|
DWARFAttributes& attrs,
|
||||||
uint32_t curr_depth = 0) const; // "curr_depth" for internal use only, don't set this yourself!!!
|
uint32_t curr_depth = 0) const; // "curr_depth" for internal use only, don't set this yourself!!!
|
||||||
|
|
||||||
dw_offset_t GetAttributeValue(
|
|
||||||
SymbolFileDWARF* dwarf2Data,
|
|
||||||
const DWARFCompileUnit* cu,
|
|
||||||
const dw_attr_t attr,
|
|
||||||
DWARFFormValue& formValue,
|
|
||||||
dw_offset_t* end_attr_offset_ptr = NULL) const;
|
|
||||||
|
|
||||||
const char* GetAttributeValueAsString(
|
const char* GetAttributeValueAsString(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
const char* fail_value) const;
|
const char* fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
uint64_t GetAttributeValueAsUnsigned(
|
uint64_t GetAttributeValueAsUnsigned(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
uint64_t fail_value) const;
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
uint64_t GetAttributeValueAsReference(
|
uint64_t GetAttributeValueAsReference(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
uint64_t fail_value) const;
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
int64_t GetAttributeValueAsSigned(
|
int64_t GetAttributeValueAsSigned(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
const dw_attr_t attr,
|
const dw_attr_t attr,
|
||||||
int64_t fail_value) const;
|
int64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
|
uint64_t GetAttributeValueAsAddress(
|
||||||
|
SymbolFileDWARF* dwarf2Data,
|
||||||
|
const DWARFCompileUnit* cu,
|
||||||
|
const dw_attr_t attr,
|
||||||
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
dw_addr_t GetAttributeHighPC(
|
dw_addr_t GetAttributeHighPC(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
dw_addr_t lo_pc,
|
dw_addr_t lo_pc,
|
||||||
uint64_t fail_value) const;
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
bool GetAttributeAddressRange(
|
bool GetAttributeAddressRange(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
dw_addr_t& lo_pc,
|
dw_addr_t& lo_pc,
|
||||||
dw_addr_t& hi_pc,
|
dw_addr_t& hi_pc,
|
||||||
uint64_t fail_value) const;
|
uint64_t fail_value,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
size_t GetAttributeAddressRanges (
|
size_t GetAttributeAddressRanges (
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
const DWARFCompileUnit* cu,
|
const DWARFCompileUnit* cu,
|
||||||
DWARFRangeList &ranges,
|
DWARFRangeList &ranges,
|
||||||
bool check_hi_lo_pc) const;
|
bool check_hi_lo_pc,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
dw_offset_t GetAttributeValueAsLocation(
|
|
||||||
SymbolFileDWARF* dwarf2Data,
|
|
||||||
const DWARFCompileUnit* cu,
|
|
||||||
const dw_attr_t attr,
|
|
||||||
lldb_private::DWARFDataExtractor& data,
|
|
||||||
uint32_t &block_size) const;
|
|
||||||
|
|
||||||
const char* GetName(
|
const char* GetName(
|
||||||
SymbolFileDWARF* dwarf2Data,
|
SymbolFileDWARF* dwarf2Data,
|
||||||
|
@ -382,6 +382,13 @@ public:
|
||||||
DWARFDebugInfoEntry::collection &die_collection);
|
DWARFDebugInfoEntry::collection &die_collection);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
dw_offset_t GetAttributeValue(SymbolFileDWARF* dwarf2Data,
|
||||||
|
const DWARFCompileUnit* cu,
|
||||||
|
const dw_attr_t attr,
|
||||||
|
DWARFFormValue& formValue,
|
||||||
|
dw_offset_t* end_attr_offset_ptr = nullptr,
|
||||||
|
bool check_specification_or_abstract_origin = false) const;
|
||||||
|
|
||||||
dw_offset_t m_offset; // Offset within the .debug_info of the start of this entry
|
dw_offset_t m_offset; // Offset within the .debug_info of the start of this entry
|
||||||
uint32_t m_parent_idx; // How many to subtract from "this" to get the parent. If zero this die has no parent
|
uint32_t m_parent_idx; // How many to subtract from "this" to get the parent. If zero this die has no parent
|
||||||
uint32_t m_sibling_idx:31, // How many to add to "this" to get the sibling.
|
uint32_t m_sibling_idx:31, // How many to add to "this" to get the sibling.
|
||||||
|
@ -389,7 +396,6 @@ protected:
|
||||||
uint32_t m_abbr_idx:DIE_ABBR_IDX_BITSIZE,
|
uint32_t m_abbr_idx:DIE_ABBR_IDX_BITSIZE,
|
||||||
m_has_children:1, // Set to 1 if this DIE has children
|
m_has_children:1, // Set to 1 if this DIE has children
|
||||||
m_tag:16; // A copy of the DW_TAG value so we don't have to go through the compile unit abbrev table
|
m_tag:16; // A copy of the DW_TAG value so we don't have to go through the compile unit abbrev table
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SymbolFileDWARF_DWARFDebugInfoEntry_h_
|
#endif // SymbolFileDWARF_DWARFDebugInfoEntry_h_
|
||||||
|
|
|
@ -93,6 +93,7 @@ public:
|
||||||
void SetSigned(int64_t sval) { m_value.value.sval = sval; }
|
void SetSigned(int64_t sval) { m_value.value.sval = sval; }
|
||||||
const char* AsCString() const;
|
const char* AsCString() const;
|
||||||
dw_addr_t Address() const;
|
dw_addr_t Address() const;
|
||||||
|
bool IsValid() const { return m_form != 0; }
|
||||||
bool SkipValue(const lldb_private::DWARFDataExtractor& debug_info_data, lldb::offset_t *offset_ptr) const;
|
bool SkipValue(const lldb_private::DWARFDataExtractor& debug_info_data, lldb::offset_t *offset_ptr) const;
|
||||||
static bool SkipValue(const dw_form_t form, const lldb_private::DWARFDataExtractor& debug_info_data, lldb::offset_t *offset_ptr, const DWARFCompileUnit* cu);
|
static bool SkipValue(const dw_form_t form, const lldb_private::DWARFDataExtractor& debug_info_data, lldb::offset_t *offset_ptr, const DWARFCompileUnit* cu);
|
||||||
static bool IsBlockForm(const dw_form_t form);
|
static bool IsBlockForm(const dw_form_t form);
|
||||||
|
|
|
@ -14,7 +14,7 @@ DWARFMappedHash::ExtractDIEArray (const DIEInfoArray &die_info_array, DIEArray &
|
||||||
{
|
{
|
||||||
const size_t count = die_info_array.size();
|
const size_t count = die_info_array.size();
|
||||||
for (size_t i=0; i<count; ++i)
|
for (size_t i=0; i<count; ++i)
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -39,7 +39,7 @@ DWARFMappedHash::ExtractDIEArray (const DIEInfoArray &die_info_array,
|
||||||
tag_matches = tag == DW_TAG_structure_type || tag == DW_TAG_class_type;
|
tag_matches = tag == DW_TAG_structure_type || tag == DW_TAG_class_type;
|
||||||
}
|
}
|
||||||
if (tag_matches)
|
if (tag_matches)
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ DWARFMappedHash::ExtractDIEArray (const DIEInfoArray &die_info_array,
|
||||||
tag_matches = tag == DW_TAG_structure_type || tag == DW_TAG_class_type;
|
tag_matches = tag == DW_TAG_structure_type || tag == DW_TAG_class_type;
|
||||||
}
|
}
|
||||||
if (tag_matches)
|
if (tag_matches)
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -92,19 +92,19 @@ DWARFMappedHash::ExtractClassOrStructDIEArray (const DIEInfoArray &die_info_arra
|
||||||
// We found the one true definition for this class, so
|
// We found the one true definition for this class, so
|
||||||
// only return that
|
// only return that
|
||||||
die_offsets.clear();
|
die_offsets.clear();
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Put the one true definition as the first entry so it
|
// Put the one true definition as the first entry so it
|
||||||
// matches first
|
// matches first
|
||||||
die_offsets.insert (die_offsets.begin(), die_info_array[i].offset);
|
die_offsets.emplace(die_offsets.begin(), die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -120,7 +120,7 @@ DWARFMappedHash::ExtractTypesFromDIEArray (const DIEInfoArray &die_info_array,
|
||||||
for (size_t i=0; i<count; ++i)
|
for (size_t i=0; i<count; ++i)
|
||||||
{
|
{
|
||||||
if ((die_info_array[i].type_flags & type_flag_mask) == type_flag_value)
|
if ((die_info_array[i].type_flags & type_flag_mask) == type_flag_value)
|
||||||
die_offsets.push_back (die_info_array[i].offset);
|
die_offsets.emplace_back(die_info_array[i].cu_offset, die_info_array[i].offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,6 +141,7 @@ DWARFMappedHash::GetAtomTypeName (uint16_t atom)
|
||||||
}
|
}
|
||||||
|
|
||||||
DWARFMappedHash::DIEInfo::DIEInfo () :
|
DWARFMappedHash::DIEInfo::DIEInfo () :
|
||||||
|
cu_offset (DW_INVALID_OFFSET),
|
||||||
offset (DW_INVALID_OFFSET),
|
offset (DW_INVALID_OFFSET),
|
||||||
tag (0),
|
tag (0),
|
||||||
type_flags (0),
|
type_flags (0),
|
||||||
|
@ -148,7 +149,12 @@ DWARFMappedHash::DIEInfo::DIEInfo () :
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
DWARFMappedHash::DIEInfo::DIEInfo (dw_offset_t o, dw_tag_t t, uint32_t f, uint32_t h) :
|
DWARFMappedHash::DIEInfo::DIEInfo (dw_offset_t c,
|
||||||
|
dw_offset_t o,
|
||||||
|
dw_tag_t t,
|
||||||
|
uint32_t f,
|
||||||
|
uint32_t h) :
|
||||||
|
cu_offset (c),
|
||||||
offset (o),
|
offset (o),
|
||||||
tag (t),
|
tag (t),
|
||||||
type_flags (f),
|
type_flags (f),
|
||||||
|
|
|
@ -52,13 +52,14 @@ public:
|
||||||
|
|
||||||
struct DIEInfo
|
struct DIEInfo
|
||||||
{
|
{
|
||||||
|
dw_offset_t cu_offset;
|
||||||
dw_offset_t offset; // The DIE offset
|
dw_offset_t offset; // The DIE offset
|
||||||
dw_tag_t tag;
|
dw_tag_t tag;
|
||||||
uint32_t type_flags; // Any flags for this DIEInfo
|
uint32_t type_flags; // Any flags for this DIEInfo
|
||||||
uint32_t qualified_name_hash; // A 32 bit hash of the fully qualified name
|
uint32_t qualified_name_hash; // A 32 bit hash of the fully qualified name
|
||||||
|
|
||||||
DIEInfo ();
|
DIEInfo ();
|
||||||
DIEInfo (dw_offset_t o, dw_tag_t t, uint32_t f, uint32_t h);
|
DIEInfo (dw_offset_t c, dw_offset_t o, dw_tag_t t, uint32_t f, uint32_t h);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Atom
|
struct Atom
|
||||||
|
@ -178,7 +179,7 @@ public:
|
||||||
Result
|
Result
|
||||||
GetHashDataForName (const char *name,
|
GetHashDataForName (const char *name,
|
||||||
lldb::offset_t* hash_data_offset_ptr,
|
lldb::offset_t* hash_data_offset_ptr,
|
||||||
Pair &pair) const;
|
Pair &pair) const override;
|
||||||
|
|
||||||
const lldb_private::DWARFDataExtractor &m_data;
|
const lldb_private::DWARFDataExtractor &m_data;
|
||||||
const lldb_private::DWARFDataExtractor &m_string_table;
|
const lldb_private::DWARFDataExtractor &m_string_table;
|
||||||
|
@ -200,8 +201,6 @@ protected:
|
||||||
const uint32_t qualified_name_hash,
|
const uint32_t qualified_name_hash,
|
||||||
DIEArray &die_offsets);
|
DIEArray &die_offsets);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
ExtractClassOrStructDIEArray (const DIEInfoArray &die_info_array,
|
ExtractClassOrStructDIEArray (const DIEInfoArray &die_info_array,
|
||||||
bool return_implementation_only_if_available,
|
bool return_implementation_only_if_available,
|
||||||
|
@ -217,5 +216,4 @@ protected:
|
||||||
GetAtomTypeName (uint16_t atom);
|
GetAtomTypeName (uint16_t atom);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif // SymbolFileDWARF_HashedNameToDIE_h_
|
#endif // SymbolFileDWARF_HashedNameToDIE_h_
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "DWARFDebugInfo.h"
|
#include "DWARFDebugInfo.h"
|
||||||
#include "DWARFDebugInfoEntry.h"
|
#include "DWARFDebugInfoEntry.h"
|
||||||
#include "SymbolFileDWARF.h"
|
#include "SymbolFileDWARF.h"
|
||||||
|
|
||||||
using namespace lldb;
|
using namespace lldb;
|
||||||
using namespace lldb_private;
|
using namespace lldb_private;
|
||||||
|
|
||||||
|
@ -29,9 +30,9 @@ NameToDIE::Finalize()
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
NameToDIE::Insert (const ConstString& name, uint32_t die_offset)
|
NameToDIE::Insert (const ConstString& name, const DIERef& die_ref)
|
||||||
{
|
{
|
||||||
m_map.Append(name.GetCString(), die_offset);
|
m_map.Append(name.GetCString(), die_ref);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
|
@ -47,17 +48,15 @@ NameToDIE::Find (const RegularExpression& regex, DIEArray &info_array) const
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
NameToDIE::FindAllEntriesForCompileUnit (uint32_t cu_offset,
|
NameToDIE::FindAllEntriesForCompileUnit (dw_offset_t cu_offset, DIEArray &info_array) const
|
||||||
uint32_t cu_end_offset,
|
|
||||||
DIEArray &info_array) const
|
|
||||||
{
|
{
|
||||||
const size_t initial_size = info_array.size();
|
const size_t initial_size = info_array.size();
|
||||||
const uint32_t size = m_map.GetSize();
|
const uint32_t size = m_map.GetSize();
|
||||||
for (uint32_t i=0; i<size; ++i)
|
for (uint32_t i=0; i<size; ++i)
|
||||||
{
|
{
|
||||||
const uint32_t die_offset = m_map.GetValueAtIndexUnchecked(i);
|
const DIERef& die_ref = m_map.GetValueAtIndexUnchecked(i);
|
||||||
if (cu_offset < die_offset && die_offset < cu_end_offset)
|
if (cu_offset == die_ref.cu_offset)
|
||||||
info_array.push_back (die_offset);
|
info_array.push_back (die_ref);
|
||||||
}
|
}
|
||||||
return info_array.size() - initial_size;
|
return info_array.size() - initial_size;
|
||||||
}
|
}
|
||||||
|
@ -69,18 +68,18 @@ NameToDIE::Dump (Stream *s)
|
||||||
for (uint32_t i=0; i<size; ++i)
|
for (uint32_t i=0; i<size; ++i)
|
||||||
{
|
{
|
||||||
const char *cstr = m_map.GetCStringAtIndex(i);
|
const char *cstr = m_map.GetCStringAtIndex(i);
|
||||||
s->Printf("%p: {0x%8.8x} \"%s\"\n", (const void *)cstr, m_map.GetValueAtIndexUnchecked(i), cstr);
|
const DIERef& die_ref = m_map.GetValueAtIndexUnchecked(i);
|
||||||
|
s->Printf("%p: {0x%8.8x/0x%8.8x} \"%s\"\n", cstr, die_ref.cu_offset, die_ref.die_offset, cstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
NameToDIE::ForEach (std::function <bool(const char *name, uint32_t die_offset)> const &callback) const
|
NameToDIE::ForEach (std::function <bool(const char *name, const DIERef& die_ref)> const &callback) const
|
||||||
{
|
{
|
||||||
const uint32_t size = m_map.GetSize();
|
const uint32_t size = m_map.GetSize();
|
||||||
for (uint32_t i=0; i<size; ++i)
|
for (uint32_t i=0; i<size; ++i)
|
||||||
{
|
{
|
||||||
if (!callback(m_map.GetCStringAtIndexUnchecked(i),
|
if (!callback(m_map.GetCStringAtIndexUnchecked(i), m_map.GetValueAtIndexUnchecked (i)))
|
||||||
m_map.GetValueAtIndexUnchecked (i)))
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,16 +10,15 @@
|
||||||
#ifndef SymbolFileDWARF_NameToDIE_h_
|
#ifndef SymbolFileDWARF_NameToDIE_h_
|
||||||
#define SymbolFileDWARF_NameToDIE_h_
|
#define SymbolFileDWARF_NameToDIE_h_
|
||||||
|
|
||||||
#include "lldb/Core/UniqueCStringMap.h"
|
|
||||||
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
|
||||||
|
#include "lldb/Core/dwarf.h"
|
||||||
|
#include "lldb/Core/UniqueCStringMap.h"
|
||||||
#include "lldb/lldb-defines.h"
|
#include "lldb/lldb-defines.h"
|
||||||
|
#include "DIERef.h"
|
||||||
|
|
||||||
class SymbolFileDWARF;
|
class SymbolFileDWARF;
|
||||||
|
|
||||||
typedef std::vector<uint32_t> DIEArray;
|
|
||||||
|
|
||||||
class NameToDIE
|
class NameToDIE
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -36,30 +35,25 @@ public:
|
||||||
Dump (lldb_private::Stream *s);
|
Dump (lldb_private::Stream *s);
|
||||||
|
|
||||||
void
|
void
|
||||||
Insert (const lldb_private::ConstString& name, uint32_t die_offset);
|
Insert (const lldb_private::ConstString& name, const DIERef& die_ref);
|
||||||
|
|
||||||
void
|
void
|
||||||
Finalize();
|
Finalize();
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
Find (const lldb_private::ConstString &name,
|
Find (const lldb_private::ConstString &name, DIEArray &info_array) const;
|
||||||
DIEArray &info_array) const;
|
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
Find (const lldb_private::RegularExpression& regex,
|
Find (const lldb_private::RegularExpression& regex, DIEArray &info_array) const;
|
||||||
DIEArray &info_array) const;
|
|
||||||
|
|
||||||
size_t
|
size_t
|
||||||
FindAllEntriesForCompileUnit (uint32_t cu_offset,
|
FindAllEntriesForCompileUnit (dw_offset_t cu_offset, DIEArray &info_array) const;
|
||||||
uint32_t cu_end_offset,
|
|
||||||
DIEArray &info_array) const;
|
|
||||||
|
|
||||||
void
|
void
|
||||||
ForEach (std::function <bool(const char *name, uint32_t die_offset)> const &callback) const;
|
ForEach (std::function <bool(const char *name, const DIERef& die_ref)> const &callback) const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
lldb_private::UniqueCStringMap<uint32_t> m_map;
|
lldb_private::UniqueCStringMap<DIERef> m_map;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SymbolFileDWARF_NameToDIE_h_
|
#endif // SymbolFileDWARF_NameToDIE_h_
|
||||||
|
|
|
@ -72,6 +72,7 @@
|
||||||
#include "DWARFFormValue.h"
|
#include "DWARFFormValue.h"
|
||||||
#include "DWARFLocationList.h"
|
#include "DWARFLocationList.h"
|
||||||
#include "LogChannelDWARF.h"
|
#include "LogChannelDWARF.h"
|
||||||
|
#include "SymbolFileDWARFDwo.h"
|
||||||
#include "SymbolFileDWARFDebugMap.h"
|
#include "SymbolFileDWARFDebugMap.h"
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
|
@ -917,7 +918,11 @@ SymbolFileDWARF::ParseCompileUnit (DWARFCompileUnit* dwarf_cu, uint32_t cu_idx)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (GetDebugMapSymfile ())
|
if (dwarf_cu->GetSymbolFileDWARF() != this)
|
||||||
|
{
|
||||||
|
return dwarf_cu->GetSymbolFileDWARF()->ParseCompileUnit(dwarf_cu, cu_idx);
|
||||||
|
}
|
||||||
|
else if (GetDebugMapSymfile ())
|
||||||
{
|
{
|
||||||
// Let the debug map create the compile unit
|
// Let the debug map create the compile unit
|
||||||
cu_sp = m_debug_map_symfile->GetCompileUnit(this);
|
cu_sp = m_debug_map_symfile->GetCompileUnit(this);
|
||||||
|
@ -1386,7 +1391,7 @@ SymbolFileDWARF::GetDeclContextForUID (lldb::user_id_t type_uid)
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
if (debug_info)
|
if (debug_info)
|
||||||
{
|
{
|
||||||
DWARFDIE die = debug_info->GetDIE(type_uid);
|
DWARFDIE die = debug_info->GetDIE(DIERef(type_uid));
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
DWARFASTParser *dwarf_ast = die.GetDWARFParser();
|
DWARFASTParser *dwarf_ast = die.GetDWARFParser();
|
||||||
|
@ -1406,7 +1411,7 @@ SymbolFileDWARF::GetDeclContextContainingUID (lldb::user_id_t type_uid)
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
if (debug_info)
|
if (debug_info)
|
||||||
{
|
{
|
||||||
DWARFDIE die = debug_info->GetDIE(type_uid);
|
DWARFDIE die = debug_info->GetDIE(DIERef(type_uid));
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
DWARFASTParser *dwarf_ast = die.GetDWARFParser();
|
DWARFASTParser *dwarf_ast = die.GetDWARFParser();
|
||||||
|
@ -1427,7 +1432,7 @@ SymbolFileDWARF::ResolveTypeUID (lldb::user_id_t type_uid)
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
if (debug_info)
|
if (debug_info)
|
||||||
{
|
{
|
||||||
DWARFDIE type_die = debug_info->GetDIE (type_uid);
|
DWARFDIE type_die = debug_info->GetDIE (DIERef(type_uid));
|
||||||
if (type_die)
|
if (type_die)
|
||||||
{
|
{
|
||||||
const bool assert_not_being_parsed = true;
|
const bool assert_not_being_parsed = true;
|
||||||
|
@ -1493,7 +1498,7 @@ bool
|
||||||
SymbolFileDWARF::HasForwardDeclForClangType (const CompilerType &clang_type)
|
SymbolFileDWARF::HasForwardDeclForClangType (const CompilerType &clang_type)
|
||||||
{
|
{
|
||||||
CompilerType clang_type_no_qualifiers = ClangASTContext::RemoveFastQualifiers(clang_type);
|
CompilerType clang_type_no_qualifiers = ClangASTContext::RemoveFastQualifiers(clang_type);
|
||||||
return m_forward_decl_clang_type_to_die.lookup (clang_type_no_qualifiers.GetOpaqueQualType()) != nullptr;
|
return GetForwardDeclClangTypeToDie().count (clang_type_no_qualifiers.GetOpaqueQualType());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1502,8 +1507,8 @@ SymbolFileDWARF::CompleteType (CompilerType &clang_type)
|
||||||
{
|
{
|
||||||
// We have a struct/union/class/enum that needs to be fully resolved.
|
// We have a struct/union/class/enum that needs to be fully resolved.
|
||||||
CompilerType clang_type_no_qualifiers = ClangASTContext::RemoveFastQualifiers(clang_type);
|
CompilerType clang_type_no_qualifiers = ClangASTContext::RemoveFastQualifiers(clang_type);
|
||||||
const DWARFDebugInfoEntry* die = m_forward_decl_clang_type_to_die.lookup (clang_type_no_qualifiers.GetOpaqueQualType());
|
auto die_it = GetForwardDeclClangTypeToDie().find (clang_type_no_qualifiers.GetOpaqueQualType());
|
||||||
if (die == NULL)
|
if (die_it == GetForwardDeclClangTypeToDie().end())
|
||||||
{
|
{
|
||||||
// We have already resolved this type...
|
// We have already resolved this type...
|
||||||
return true;
|
return true;
|
||||||
|
@ -1512,11 +1517,12 @@ SymbolFileDWARF::CompleteType (CompilerType &clang_type)
|
||||||
// map in case anyone child members or other types require this type to get resolved.
|
// map in case anyone child members or other types require this type to get resolved.
|
||||||
// The type will get resolved when all of the calls to SymbolFileDWARF::ResolveClangOpaqueTypeDefinition
|
// The type will get resolved when all of the calls to SymbolFileDWARF::ResolveClangOpaqueTypeDefinition
|
||||||
// are done.
|
// are done.
|
||||||
m_forward_decl_clang_type_to_die.erase (clang_type_no_qualifiers.GetOpaqueQualType());
|
GetForwardDeclClangTypeToDie().erase (clang_type_no_qualifiers.GetOpaqueQualType());
|
||||||
|
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
DWARFDIE dwarf_die (debug_info->GetCompileUnitContainingDIE (die->GetOffset()), die);
|
|
||||||
Type *type = m_die_to_type.lookup (die);
|
DWARFDIE dwarf_die = debug_info->GetDIE(die_it->getSecond());
|
||||||
|
Type *type = GetDIEToType().lookup (dwarf_die.GetDIE());
|
||||||
|
|
||||||
Log *log (LogChannelDWARF::GetLogIfAny(DWARF_LOG_DEBUG_INFO|DWARF_LOG_TYPE_COMPLETION));
|
Log *log (LogChannelDWARF::GetLogIfAny(DWARF_LOG_DEBUG_INFO|DWARF_LOG_TYPE_COMPLETION));
|
||||||
if (log)
|
if (log)
|
||||||
|
@ -1537,7 +1543,7 @@ SymbolFileDWARF::ResolveType (const DWARFDIE &die, bool assert_not_being_parsed)
|
||||||
{
|
{
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
Type *type = m_die_to_type.lookup (die.GetDIE());
|
Type *type = GetDIEToType().lookup (die.GetDIE());
|
||||||
|
|
||||||
if (type == NULL)
|
if (type == NULL)
|
||||||
type = GetTypeForDIE (die).get();
|
type = GetTypeForDIE (die).get();
|
||||||
|
@ -1623,7 +1629,6 @@ SymbolFileDWARF::UpdateExternalModuleListIfNeeded()
|
||||||
m_fetched_external_modules = true;
|
m_fetched_external_modules = true;
|
||||||
|
|
||||||
DWARFDebugInfo * debug_info = DebugInfo();
|
DWARFDebugInfo * debug_info = DebugInfo();
|
||||||
debug_info->GetNumCompileUnits();
|
|
||||||
|
|
||||||
const uint32_t num_compile_units = GetNumCompileUnits();
|
const uint32_t num_compile_units = GetNumCompileUnits();
|
||||||
for (uint32_t cu_idx = 0; cu_idx < num_compile_units; ++cu_idx)
|
for (uint32_t cu_idx = 0; cu_idx < num_compile_units; ++cu_idx)
|
||||||
|
@ -2000,8 +2005,7 @@ SymbolFileDWARF::Index ()
|
||||||
|
|
||||||
bool clear_dies = dwarf_cu->ExtractDIEsIfNeeded (false) > 1;
|
bool clear_dies = dwarf_cu->ExtractDIEsIfNeeded (false) > 1;
|
||||||
|
|
||||||
dwarf_cu->Index (cu_idx,
|
dwarf_cu->Index (m_function_basename_index,
|
||||||
m_function_basename_index,
|
|
||||||
m_function_fullname_index,
|
m_function_fullname_index,
|
||||||
m_function_method_index,
|
m_function_method_index,
|
||||||
m_function_selector_index,
|
m_function_selector_index,
|
||||||
|
@ -2127,8 +2131,8 @@ SymbolFileDWARF::FindGlobalVariables (const ConstString &name, const CompilerDec
|
||||||
bool done = false;
|
bool done = false;
|
||||||
for (size_t i=0; i<num_die_matches && !done; ++i)
|
for (size_t i=0; i<num_die_matches && !done; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = debug_info->GetDIE (die_offset);
|
DWARFDIE die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
|
@ -2169,7 +2173,7 @@ SymbolFileDWARF::FindGlobalVariables (const ConstString &name, const CompilerDec
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')\n",
|
||||||
die_offset, name.GetCString());
|
die_ref.die_offset, name.GetCString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2244,8 +2248,8 @@ SymbolFileDWARF::FindGlobalVariables(const RegularExpression& regex, bool append
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = debug_info->GetDIE (die_offset);
|
DWARFDIE die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
|
@ -2261,7 +2265,7 @@ SymbolFileDWARF::FindGlobalVariables(const RegularExpression& regex, bool append
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for regex '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for regex '%s')\n",
|
||||||
die_offset, regex.GetText());
|
die_ref.die_offset, regex.GetText());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2273,11 +2277,11 @@ SymbolFileDWARF::FindGlobalVariables(const RegularExpression& regex, bool append
|
||||||
|
|
||||||
|
|
||||||
bool
|
bool
|
||||||
SymbolFileDWARF::ResolveFunction (dw_offset_t die_offset,
|
SymbolFileDWARF::ResolveFunction (const DIERef& die_ref,
|
||||||
bool include_inlines,
|
bool include_inlines,
|
||||||
SymbolContextList& sc_list)
|
SymbolContextList& sc_list)
|
||||||
{
|
{
|
||||||
DWARFDIE die = DebugInfo()->GetDIE (die_offset);
|
DWARFDIE die = DebugInfo()->GetDIE (die_ref);
|
||||||
return ResolveFunction (die, include_inlines, sc_list);
|
return ResolveFunction (die, include_inlines, sc_list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2397,10 +2401,7 @@ SymbolFileDWARF::ParseFunctions (const DIEArray &die_offsets,
|
||||||
if (num_matches)
|
if (num_matches)
|
||||||
{
|
{
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
ResolveFunction (die_offsets[i], include_inlines, sc_list);
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
|
||||||
ResolveFunction (die_offset, include_inlines, sc_list);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2493,8 +2494,8 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
num_matches = m_apple_names_ap->FindByName (name_cstr, die_offsets);
|
num_matches = m_apple_names_ap->FindByName (name_cstr, die_offsets);
|
||||||
for (uint32_t i = 0; i < num_matches; i++)
|
for (uint32_t i = 0; i < num_matches; i++)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = info->GetDIE (die_offset);
|
DWARFDIE die = info->GetDIE (die_ref);
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
if (!DIEInDeclContext(parent_decl_ctx, die))
|
if (!DIEInDeclContext(parent_decl_ctx, die))
|
||||||
|
@ -2509,7 +2510,7 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
||||||
die_offset, name_cstr);
|
die_ref.die_offset, name_cstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2525,8 +2526,8 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
|
|
||||||
for (uint32_t i = 0; i < num_matches; i++)
|
for (uint32_t i = 0; i < num_matches; i++)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = info->GetDIE (die_offset);
|
DWARFDIE die = info->GetDIE (die_ref);
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
const char *die_name = die.GetName();
|
const char *die_name = die.GetName();
|
||||||
|
@ -2542,7 +2543,7 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportError ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
GetObjectFile()->GetModule()->ReportError ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
||||||
die_offset, name_cstr);
|
die_ref.die_offset, name_cstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
die_offsets.clear();
|
die_offsets.clear();
|
||||||
|
@ -2559,8 +2560,8 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
|
|
||||||
for (uint32_t i = 0; i < num_matches; i++)
|
for (uint32_t i = 0; i < num_matches; i++)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = info->GetDIE (die_offset);
|
DWARFDIE die = info->GetDIE (die_ref);
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
if (!DIEInDeclContext(parent_decl_ctx, die))
|
if (!DIEInDeclContext(parent_decl_ctx, die))
|
||||||
|
@ -2609,7 +2610,7 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportWarning ("function at die offset 0x%8.8x had no function type",
|
GetObjectFile()->GetModule()->ReportWarning ("function at die offset 0x%8.8x had no function type",
|
||||||
die_offset);
|
die_ref.die_offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2621,7 +2622,7 @@ SymbolFileDWARF::FindFunctions (const ConstString &name,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x for '%s')",
|
||||||
die_offset, name_cstr);
|
die_ref.die_offset, name_cstr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
die_offsets.clear();
|
die_offsets.clear();
|
||||||
|
@ -2856,8 +2857,8 @@ SymbolFileDWARF::FindTypes (const SymbolContext& sc,
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_die_matches; ++i)
|
for (size_t i=0; i<num_die_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = debug_info->GetDIE (die_offset);
|
DWARFDIE die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
|
@ -2878,7 +2879,7 @@ SymbolFileDWARF::FindTypes (const SymbolContext& sc,
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
||||||
die_offset, name.GetCString());
|
die_ref.die_offset, name.GetCString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2960,8 +2961,8 @@ SymbolFileDWARF::FindNamespace (const SymbolContext& sc,
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = debug_info->GetDIE (die_offset);
|
DWARFDIE die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
|
@ -2981,7 +2982,7 @@ SymbolFileDWARF::FindNamespace (const SymbolContext& sc,
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_namespaces accelerator table had bad die 0x%8.8x for '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_namespaces accelerator table had bad die 0x%8.8x for '%s')\n",
|
||||||
die_offset, name.GetCString());
|
die_ref.die_offset, name.GetCString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3001,42 +3002,13 @@ SymbolFileDWARF::FindNamespace (const SymbolContext& sc,
|
||||||
return namespace_decl_ctx;
|
return namespace_decl_ctx;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t
|
|
||||||
SymbolFileDWARF::FindTypes(std::vector<dw_offset_t> die_offsets, uint32_t max_matches, TypeList& types)
|
|
||||||
{
|
|
||||||
// Remember how many sc_list are in the list before we search in case
|
|
||||||
// we are appending the results to a variable list.
|
|
||||||
uint32_t original_size = types.GetSize();
|
|
||||||
|
|
||||||
const uint32_t num_die_offsets = die_offsets.size();
|
|
||||||
// Parse all of the types we found from the pubtypes matches
|
|
||||||
uint32_t i;
|
|
||||||
uint32_t num_matches = 0;
|
|
||||||
for (i = 0; i < num_die_offsets; ++i)
|
|
||||||
{
|
|
||||||
Type *matching_type = ResolveTypeUID (die_offsets[i]);
|
|
||||||
if (matching_type)
|
|
||||||
{
|
|
||||||
// We found a type pointer, now find the shared pointer form our type list
|
|
||||||
types.InsertUnique (matching_type->shared_from_this());
|
|
||||||
++num_matches;
|
|
||||||
if (num_matches >= max_matches)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return the number of variable that were appended to the list
|
|
||||||
return types.GetSize() - original_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
TypeSP
|
TypeSP
|
||||||
SymbolFileDWARF::GetTypeForDIE (const DWARFDIE &die)
|
SymbolFileDWARF::GetTypeForDIE (const DWARFDIE &die)
|
||||||
{
|
{
|
||||||
TypeSP type_sp;
|
TypeSP type_sp;
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
Type *type_ptr = m_die_to_type.lookup (die.GetDIE());
|
Type *type_ptr = GetDIEToType().lookup (die.GetDIE());
|
||||||
if (type_ptr == NULL)
|
if (type_ptr == NULL)
|
||||||
{
|
{
|
||||||
CompileUnit* lldb_cu = GetCompUnitForDWARFCompUnit(die.GetCU());
|
CompileUnit* lldb_cu = GetCompUnitForDWARFCompUnit(die.GetCU());
|
||||||
|
@ -3195,8 +3167,8 @@ SymbolFileDWARF::FindCompleteObjCDefinitionTypeForDIE (const DWARFDIE &die,
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE type_die = debug_info->GetDIE (die_offset);
|
DWARFDIE type_die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (type_die)
|
if (type_die)
|
||||||
{
|
{
|
||||||
|
@ -3233,7 +3205,7 @@ SymbolFileDWARF::FindCompleteObjCDefinitionTypeForDIE (const DWARFDIE &die,
|
||||||
type_cu->GetID());
|
type_cu->GetID());
|
||||||
|
|
||||||
if (die)
|
if (die)
|
||||||
m_die_to_type[die.GetDIE()] = resolved_type;
|
GetDIEToType()[die.GetDIE()] = resolved_type;
|
||||||
type_sp = resolved_type->shared_from_this();
|
type_sp = resolved_type->shared_from_this();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -3245,7 +3217,7 @@ SymbolFileDWARF::FindCompleteObjCDefinitionTypeForDIE (const DWARFDIE &die,
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
||||||
die_offset, type_name.GetCString());
|
die_ref.die_offset, type_name.GetCString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3419,8 +3391,8 @@ SymbolFileDWARF::FindDefinitionTypeForDWARFDeclContext (const DWARFDeclContext &
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE type_die = debug_info->GetDIE (die_offset);
|
DWARFDIE type_die = debug_info->GetDIE (die_ref);
|
||||||
|
|
||||||
if (type_die)
|
if (type_die)
|
||||||
{
|
{
|
||||||
|
@ -3503,7 +3475,7 @@ SymbolFileDWARF::FindDefinitionTypeForDWARFDeclContext (const DWARFDeclContext &
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_types accelerator table had bad die 0x%8.8x for '%s')\n",
|
||||||
die_offset, type_name.GetCString());
|
die_ref.die_offset, type_name.GetCString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3646,9 +3618,9 @@ SymbolFileDWARF::ParseVariablesForContext (const SymbolContext& sc)
|
||||||
|
|
||||||
if (sc.function)
|
if (sc.function)
|
||||||
{
|
{
|
||||||
DWARFDIE function_die = info->GetDIE(sc.function->GetID());
|
DWARFDIE function_die = info->GetDIE(DIERef(sc.function->GetID()));
|
||||||
|
|
||||||
const dw_addr_t func_lo_pc = function_die.GetAttributeValueAsUnsigned (DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
const dw_addr_t func_lo_pc = function_die.GetAttributeValueAsAddress (DW_AT_low_pc, LLDB_INVALID_ADDRESS);
|
||||||
if (func_lo_pc != LLDB_INVALID_ADDRESS)
|
if (func_lo_pc != LLDB_INVALID_ADDRESS)
|
||||||
{
|
{
|
||||||
const size_t num_variables = ParseVariables(sc, function_die.GetFirstChild(), func_lo_pc, true, true);
|
const size_t num_variables = ParseVariables(sc, function_die.GetFirstChild(), func_lo_pc, true, true);
|
||||||
|
@ -3695,7 +3667,6 @@ SymbolFileDWARF::ParseVariablesForContext (const SymbolContext& sc)
|
||||||
Index ();
|
Index ();
|
||||||
|
|
||||||
m_global_index.FindAllEntriesForCompileUnit (dwarf_cu->GetOffset(),
|
m_global_index.FindAllEntriesForCompileUnit (dwarf_cu->GetOffset(),
|
||||||
dwarf_cu->GetNextCompileUnitOffset(),
|
|
||||||
die_offsets);
|
die_offsets);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3705,8 +3676,8 @@ SymbolFileDWARF::ParseVariablesForContext (const SymbolContext& sc)
|
||||||
DWARFDebugInfo* debug_info = DebugInfo();
|
DWARFDebugInfo* debug_info = DebugInfo();
|
||||||
for (size_t i=0; i<num_matches; ++i)
|
for (size_t i=0; i<num_matches; ++i)
|
||||||
{
|
{
|
||||||
const dw_offset_t die_offset = die_offsets[i];
|
const DIERef& die_ref = die_offsets[i];
|
||||||
DWARFDIE die = debug_info->GetDIE (die_offset);
|
DWARFDIE die = debug_info->GetDIE (die_ref);
|
||||||
if (die)
|
if (die)
|
||||||
{
|
{
|
||||||
VariableSP var_sp (ParseVariableDIE(sc, die, LLDB_INVALID_ADDRESS));
|
VariableSP var_sp (ParseVariableDIE(sc, die, LLDB_INVALID_ADDRESS));
|
||||||
|
@ -3720,7 +3691,7 @@ SymbolFileDWARF::ParseVariablesForContext (const SymbolContext& sc)
|
||||||
{
|
{
|
||||||
if (m_using_apple_tables)
|
if (m_using_apple_tables)
|
||||||
{
|
{
|
||||||
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x)\n", die_offset);
|
GetObjectFile()->GetModule()->ReportErrorIfModifyDetected ("the DWARF debug information has been modified (.apple_names accelerator table had bad die 0x%8.8x)\n", die_ref.die_offset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3741,11 +3712,14 @@ SymbolFileDWARF::ParseVariableDIE
|
||||||
const lldb::addr_t func_low_pc
|
const lldb::addr_t func_low_pc
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (die.GetDWARF() != this)
|
||||||
|
return die.GetDWARF()->ParseVariableDIE(sc, die, func_low_pc);
|
||||||
|
|
||||||
VariableSP var_sp;
|
VariableSP var_sp;
|
||||||
if (!die)
|
if (!die)
|
||||||
return var_sp;
|
return var_sp;
|
||||||
|
|
||||||
var_sp = m_die_to_variable_sp[die.GetDIE()];
|
var_sp = GetDIEToVariable()[die.GetDIE()];
|
||||||
if (var_sp)
|
if (var_sp)
|
||||||
return var_sp; // Already been parsed!
|
return var_sp; // Already been parsed!
|
||||||
|
|
||||||
|
@ -3764,7 +3738,7 @@ SymbolFileDWARF::ParseVariableDIE
|
||||||
const char *mangled = NULL;
|
const char *mangled = NULL;
|
||||||
Declaration decl;
|
Declaration decl;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
lldb::user_id_t type_uid = LLDB_INVALID_UID;
|
DWARFFormValue type_die_form;
|
||||||
DWARFExpression location(die.GetCU());
|
DWARFExpression location(die.GetCU());
|
||||||
bool is_external = false;
|
bool is_external = false;
|
||||||
bool is_artificial = false;
|
bool is_artificial = false;
|
||||||
|
@ -3788,7 +3762,7 @@ SymbolFileDWARF::ParseVariableDIE
|
||||||
case DW_AT_name: name = form_value.AsCString(); break;
|
case DW_AT_name: name = form_value.AsCString(); break;
|
||||||
case DW_AT_linkage_name:
|
case DW_AT_linkage_name:
|
||||||
case DW_AT_MIPS_linkage_name: mangled = form_value.AsCString(); break;
|
case DW_AT_MIPS_linkage_name: mangled = form_value.AsCString(); break;
|
||||||
case DW_AT_type: type_uid = form_value.Reference(); break;
|
case DW_AT_type: type_die_form = form_value; break;
|
||||||
case DW_AT_external: is_external = form_value.Boolean(); break;
|
case DW_AT_external: is_external = form_value.Boolean(); break;
|
||||||
case DW_AT_const_value:
|
case DW_AT_const_value:
|
||||||
// If we have already found a DW_AT_location attribute, ignore this attribute.
|
// If we have already found a DW_AT_location attribute, ignore this attribute.
|
||||||
|
@ -4063,7 +4037,7 @@ SymbolFileDWARF::ParseVariableDIE
|
||||||
|
|
||||||
if (symbol_context_scope)
|
if (symbol_context_scope)
|
||||||
{
|
{
|
||||||
SymbolFileTypeSP type_sp(new SymbolFileType(*this, type_uid));
|
SymbolFileTypeSP type_sp(new SymbolFileType(*this, DIERef(type_die_form).GetUID()));
|
||||||
|
|
||||||
if (const_value.Form() && type_sp && type_sp->GetType())
|
if (const_value.Form() && type_sp && type_sp->GetType())
|
||||||
location.CopyOpcodeData(const_value.Unsigned(), type_sp->GetType()->GetByteSize(), die.GetCU()->GetAddressByteSize());
|
location.CopyOpcodeData(const_value.Unsigned(), type_sp->GetType()->GetByteSize(), die.GetCU()->GetAddressByteSize());
|
||||||
|
@ -4094,20 +4068,20 @@ SymbolFileDWARF::ParseVariableDIE
|
||||||
// was missing vital information to be able to be displayed in the debugger
|
// was missing vital information to be able to be displayed in the debugger
|
||||||
// (missing location due to optimization, etc)) so we don't re-parse
|
// (missing location due to optimization, etc)) so we don't re-parse
|
||||||
// this DIE over and over later...
|
// this DIE over and over later...
|
||||||
m_die_to_variable_sp[die.GetDIE()] = var_sp;
|
GetDIEToVariable()[die.GetDIE()] = var_sp;
|
||||||
}
|
}
|
||||||
return var_sp;
|
return var_sp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
DWARFDIE
|
DWARFDIE
|
||||||
SymbolFileDWARF::FindBlockContainingSpecification (dw_offset_t func_die_offset,
|
SymbolFileDWARF::FindBlockContainingSpecification (const DIERef& func_die_ref,
|
||||||
dw_offset_t spec_block_die_offset)
|
dw_offset_t spec_block_die_offset)
|
||||||
{
|
{
|
||||||
// Give the concrete function die specified by "func_die_offset", find the
|
// Give the concrete function die specified by "func_die_offset", find the
|
||||||
// concrete block whose DW_AT_specification or DW_AT_abstract_origin points
|
// concrete block whose DW_AT_specification or DW_AT_abstract_origin points
|
||||||
// to "spec_block_die_offset"
|
// to "spec_block_die_offset"
|
||||||
return FindBlockContainingSpecification (DebugInfo()->GetDIE (func_die_offset), spec_block_die_offset);
|
return FindBlockContainingSpecification (DebugInfo()->GetDIE (func_die_ref), spec_block_die_offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -4166,7 +4140,7 @@ SymbolFileDWARF::ParseVariables (const SymbolContext& sc,
|
||||||
dw_tag_t tag = die.Tag();
|
dw_tag_t tag = die.Tag();
|
||||||
|
|
||||||
// Check to see if we have already parsed this variable or constant?
|
// Check to see if we have already parsed this variable or constant?
|
||||||
VariableSP var_sp = m_die_to_variable_sp[die.GetDIE()];
|
VariableSP var_sp = GetDIEToVariable()[die.GetDIE()];
|
||||||
if (var_sp)
|
if (var_sp)
|
||||||
{
|
{
|
||||||
if (cc_variable_list)
|
if (cc_variable_list)
|
||||||
|
@ -4219,7 +4193,7 @@ SymbolFileDWARF::ParseVariables (const SymbolContext& sc,
|
||||||
// a concrete block counterpart in the current function. We need
|
// a concrete block counterpart in the current function. We need
|
||||||
// to find the concrete block so we can correctly add the
|
// to find the concrete block so we can correctly add the
|
||||||
// variable to it
|
// variable to it
|
||||||
const DWARFDIE concrete_block_die = FindBlockContainingSpecification (sc.function->GetID(),
|
const DWARFDIE concrete_block_die = FindBlockContainingSpecification (DIERef(sc.function->GetID()),
|
||||||
sc_parent_die.GetOffset());
|
sc_parent_die.GetOffset());
|
||||||
if (concrete_block_die)
|
if (concrete_block_die)
|
||||||
block = sc.function->GetBlock(true).FindBlockByID(concrete_block_die.GetID());
|
block = sc.function->GetBlock(true).FindBlockByID(concrete_block_die.GetID());
|
||||||
|
@ -4324,5 +4298,3 @@ SymbolFileDWARF::GetDebugMapSymfile ()
|
||||||
}
|
}
|
||||||
return m_debug_map_symfile;
|
return m_debug_map_symfile;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -65,6 +65,7 @@ class SymbolFileDWARF : public lldb_private::SymbolFile, public lldb_private::Us
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
friend class SymbolFileDWARFDebugMap;
|
friend class SymbolFileDWARFDebugMap;
|
||||||
|
friend class SymbolFileDWARFDwo;
|
||||||
friend class DebugMapModule;
|
friend class DebugMapModule;
|
||||||
friend class DWARFCompileUnit;
|
friend class DWARFCompileUnit;
|
||||||
friend class DWARFASTParserClang;
|
friend class DWARFASTParserClang;
|
||||||
|
@ -265,7 +266,7 @@ public:
|
||||||
const DWARFDebugRanges*
|
const DWARFDebugRanges*
|
||||||
DebugRanges() const;
|
DebugRanges() const;
|
||||||
|
|
||||||
const lldb_private::DWARFDataExtractor&
|
virtual const lldb_private::DWARFDataExtractor&
|
||||||
GetCachedSectionData (uint32_t got_flag,
|
GetCachedSectionData (uint32_t got_flag,
|
||||||
lldb::SectionType sect_type,
|
lldb::SectionType sect_type,
|
||||||
lldb_private::DWARFDataExtractor &data);
|
lldb_private::DWARFDataExtractor &data);
|
||||||
|
@ -311,7 +312,14 @@ public:
|
||||||
static DWARFDIE
|
static DWARFDIE
|
||||||
GetParentSymbolContextDIE(const DWARFDIE &die);
|
GetParentSymbolContextDIE(const DWARFDIE &die);
|
||||||
|
|
||||||
|
virtual lldb::CompUnitSP
|
||||||
|
ParseCompileUnit (DWARFCompileUnit* dwarf_cu, uint32_t cu_idx);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb_private::Type *> DIEToTypePtr;
|
||||||
|
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb::VariableSP> DIEToVariableSP;
|
||||||
|
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb::clang_type_t> DIEToClangType;
|
||||||
|
typedef llvm::DenseMap<lldb::clang_type_t, DIERef> ClangTypeToDIE;
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
|
@ -343,11 +351,7 @@ protected:
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN (SymbolFileDWARF);
|
DISALLOW_COPY_AND_ASSIGN (SymbolFileDWARF);
|
||||||
|
|
||||||
lldb::CompUnitSP
|
virtual DWARFCompileUnit*
|
||||||
ParseCompileUnit (DWARFCompileUnit* dwarf_cu,
|
|
||||||
uint32_t cu_idx);
|
|
||||||
|
|
||||||
DWARFCompileUnit*
|
|
||||||
GetDWARFCompileUnit (lldb_private::CompileUnit *comp_unit);
|
GetDWARFCompileUnit (lldb_private::CompileUnit *comp_unit);
|
||||||
|
|
||||||
DWARFCompileUnit*
|
DWARFCompileUnit*
|
||||||
|
@ -401,7 +405,7 @@ protected:
|
||||||
|
|
||||||
// Given a die_offset, figure out the symbol context representing that die.
|
// Given a die_offset, figure out the symbol context representing that die.
|
||||||
bool
|
bool
|
||||||
ResolveFunction (dw_offset_t offset,
|
ResolveFunction (const DIERef& die_ref,
|
||||||
bool include_inlines,
|
bool include_inlines,
|
||||||
lldb_private::SymbolContextList& sc_list);
|
lldb_private::SymbolContextList& sc_list);
|
||||||
|
|
||||||
|
@ -451,11 +455,6 @@ protected:
|
||||||
lldb::TypeSP
|
lldb::TypeSP
|
||||||
GetTypeForDIE (const DWARFDIE &die);
|
GetTypeForDIE (const DWARFDIE &die);
|
||||||
|
|
||||||
uint32_t
|
|
||||||
FindTypes (std::vector<dw_offset_t> die_offsets,
|
|
||||||
uint32_t max_matches,
|
|
||||||
lldb_private::TypeList& types);
|
|
||||||
|
|
||||||
void
|
void
|
||||||
Index();
|
Index();
|
||||||
|
|
||||||
|
@ -472,12 +471,10 @@ protected:
|
||||||
GetDebugMapSymfile ();
|
GetDebugMapSymfile ();
|
||||||
|
|
||||||
DWARFDIE
|
DWARFDIE
|
||||||
FindBlockContainingSpecification (dw_offset_t func_die_offset,
|
FindBlockContainingSpecification (const DIERef& func_die_ref, dw_offset_t spec_block_die_offset);
|
||||||
dw_offset_t spec_block_die_offset);
|
|
||||||
|
|
||||||
DWARFDIE
|
DWARFDIE
|
||||||
FindBlockContainingSpecification (const DWARFDIE &die,
|
FindBlockContainingSpecification (const DWARFDIE &die, dw_offset_t spec_block_die_offset);
|
||||||
dw_offset_t spec_block_die_offset);
|
|
||||||
|
|
||||||
UniqueDWARFASTTypeMap &
|
UniqueDWARFASTTypeMap &
|
||||||
GetUniqueDWARFASTTypeMap ();
|
GetUniqueDWARFASTTypeMap ();
|
||||||
|
@ -486,7 +483,7 @@ protected:
|
||||||
UserIDMatches (lldb::user_id_t uid) const
|
UserIDMatches (lldb::user_id_t uid) const
|
||||||
{
|
{
|
||||||
const lldb::user_id_t high_uid = uid & 0xffffffff00000000ull;
|
const lldb::user_id_t high_uid = uid & 0xffffffff00000000ull;
|
||||||
if (high_uid)
|
if (high_uid != 0 && GetID() != 0)
|
||||||
return high_uid == GetID();
|
return high_uid == GetID();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -526,6 +523,18 @@ protected:
|
||||||
void
|
void
|
||||||
UpdateExternalModuleListIfNeeded();
|
UpdateExternalModuleListIfNeeded();
|
||||||
|
|
||||||
|
virtual DIEToTypePtr&
|
||||||
|
GetDIEToType() { return m_die_to_type; }
|
||||||
|
|
||||||
|
virtual DIEToVariableSP&
|
||||||
|
GetDIEToVariable() { return m_die_to_variable_sp; }
|
||||||
|
|
||||||
|
virtual DIEToClangType&
|
||||||
|
GetForwardDeclDieToClangType() { return m_forward_decl_die_to_clang_type; }
|
||||||
|
|
||||||
|
virtual ClangTypeToDIE&
|
||||||
|
GetForwardDeclClangTypeToDie() { return m_forward_decl_clang_type_to_die; }
|
||||||
|
|
||||||
lldb::ModuleWP m_debug_map_module_wp;
|
lldb::ModuleWP m_debug_map_module_wp;
|
||||||
SymbolFileDWARFDebugMap * m_debug_map_symfile;
|
SymbolFileDWARFDebugMap * m_debug_map_symfile;
|
||||||
lldb_private::Flags m_flags;
|
lldb_private::Flags m_flags;
|
||||||
|
@ -571,10 +580,6 @@ protected:
|
||||||
|
|
||||||
std::unique_ptr<DWARFDebugRanges> m_ranges;
|
std::unique_ptr<DWARFDebugRanges> m_ranges;
|
||||||
UniqueDWARFASTTypeMap m_unique_ast_type_map;
|
UniqueDWARFASTTypeMap m_unique_ast_type_map;
|
||||||
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb_private::Type *> DIEToTypePtr;
|
|
||||||
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb::VariableSP> DIEToVariableSP;
|
|
||||||
typedef llvm::DenseMap<const DWARFDebugInfoEntry *, lldb::clang_type_t> DIEToClangType;
|
|
||||||
typedef llvm::DenseMap<lldb::clang_type_t, const DWARFDebugInfoEntry *> ClangTypeToDIE;
|
|
||||||
DIEToTypePtr m_die_to_type;
|
DIEToTypePtr m_die_to_type;
|
||||||
DIEToVariableSP m_die_to_variable_sp;
|
DIEToVariableSP m_die_to_variable_sp;
|
||||||
DIEToClangType m_forward_decl_die_to_clang_type;
|
DIEToClangType m_forward_decl_die_to_clang_type;
|
||||||
|
|
|
@ -0,0 +1,104 @@
|
||||||
|
//===-- SymbolFileDWARFDwo.cpp ----------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#include "SymbolFileDWARFDwo.h"
|
||||||
|
|
||||||
|
#include "lldb/Core/Section.h"
|
||||||
|
#include "lldb/Symbol/ObjectFile.h"
|
||||||
|
|
||||||
|
#include "DWARFCompileUnit.h"
|
||||||
|
#include "DWARFDebugInfo.h"
|
||||||
|
|
||||||
|
using namespace lldb;
|
||||||
|
using namespace lldb_private;
|
||||||
|
|
||||||
|
SymbolFileDWARFDwo::SymbolFileDWARFDwo(ObjectFileSP objfile, DWARFCompileUnit* dwarf_cu) :
|
||||||
|
SymbolFileDWARF(objfile.get()),
|
||||||
|
m_obj_file_sp(objfile),
|
||||||
|
m_base_dwarf_cu(dwarf_cu)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
const lldb_private::DWARFDataExtractor&
|
||||||
|
SymbolFileDWARFDwo::GetCachedSectionData(uint32_t got_flag,
|
||||||
|
lldb::SectionType sect_type,
|
||||||
|
lldb_private::DWARFDataExtractor &data)
|
||||||
|
{
|
||||||
|
if (!m_flags.IsClear (got_flag))
|
||||||
|
return data;
|
||||||
|
|
||||||
|
const SectionList* section_list = m_obj_file->GetSectionList(false /* update_module_section_list */);
|
||||||
|
if (section_list)
|
||||||
|
{
|
||||||
|
SectionSP section_sp (section_list->FindSectionByType(sect_type, true));
|
||||||
|
if (section_sp)
|
||||||
|
{
|
||||||
|
// See if we memory mapped the DWARF segment?
|
||||||
|
if (m_dwarf_data.GetByteSize())
|
||||||
|
{
|
||||||
|
data.SetData(m_dwarf_data, section_sp->GetOffset(), section_sp->GetFileSize());
|
||||||
|
m_flags.Set (got_flag);
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_obj_file->ReadSectionData(section_sp.get(), data) != 0)
|
||||||
|
{
|
||||||
|
m_flags.Set (got_flag);
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
data.Clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SymbolFileDWARF::GetCachedSectionData(got_flag, sect_type, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
lldb::CompUnitSP
|
||||||
|
SymbolFileDWARFDwo::ParseCompileUnit(DWARFCompileUnit* dwarf_cu, uint32_t cu_idx)
|
||||||
|
{
|
||||||
|
assert(GetCompileUnit() == dwarf_cu && "SymbolFileDWARFDwo::ParseCompileUnit called with incompatible compile unit");
|
||||||
|
return m_base_dwarf_cu->GetSymbolFileDWARF()->ParseCompileUnit(m_base_dwarf_cu, UINT32_MAX);
|
||||||
|
}
|
||||||
|
|
||||||
|
DWARFCompileUnit*
|
||||||
|
SymbolFileDWARFDwo::GetCompileUnit()
|
||||||
|
{
|
||||||
|
assert(GetNumCompileUnits() == 1 && "Only dwo files with 1 compile unit is supported");
|
||||||
|
return DebugInfo()->GetCompileUnitAtIndex(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
DWARFCompileUnit*
|
||||||
|
SymbolFileDWARFDwo::GetDWARFCompileUnit(lldb_private::CompileUnit *comp_unit)
|
||||||
|
{
|
||||||
|
return GetCompileUnit();
|
||||||
|
}
|
||||||
|
|
||||||
|
SymbolFileDWARF::DIEToTypePtr&
|
||||||
|
SymbolFileDWARFDwo::GetDIEToType()
|
||||||
|
{
|
||||||
|
return m_base_dwarf_cu->GetSymbolFileDWARF()->GetDIEToType();
|
||||||
|
}
|
||||||
|
|
||||||
|
SymbolFileDWARF::DIEToVariableSP&
|
||||||
|
SymbolFileDWARFDwo::GetDIEToVariable()
|
||||||
|
{
|
||||||
|
return m_base_dwarf_cu->GetSymbolFileDWARF()->GetDIEToVariable();
|
||||||
|
}
|
||||||
|
|
||||||
|
SymbolFileDWARF::DIEToClangType&
|
||||||
|
SymbolFileDWARFDwo::GetForwardDeclDieToClangType()
|
||||||
|
{
|
||||||
|
return m_base_dwarf_cu->GetSymbolFileDWARF()->GetForwardDeclDieToClangType();
|
||||||
|
}
|
||||||
|
|
||||||
|
SymbolFileDWARF::ClangTypeToDIE&
|
||||||
|
SymbolFileDWARFDwo::GetForwardDeclClangTypeToDie()
|
||||||
|
{
|
||||||
|
return m_base_dwarf_cu->GetSymbolFileDWARF()->GetForwardDeclClangTypeToDie();
|
||||||
|
}
|
|
@ -0,0 +1,58 @@
|
||||||
|
//===-- SymbolFileDWARFDwo.h ------------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef SymbolFileDWARFDwo_SymbolFileDWARFDwo_h_
|
||||||
|
#define SymbolFileDWARFDwo_SymbolFileDWARFDwo_h_
|
||||||
|
|
||||||
|
// C Includes
|
||||||
|
// C++ Includes
|
||||||
|
// Other libraries and framework includes
|
||||||
|
// Project includes
|
||||||
|
#include "SymbolFileDWARF.h"
|
||||||
|
|
||||||
|
class SymbolFileDWARFDwo : public SymbolFileDWARF
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
SymbolFileDWARFDwo(lldb::ObjectFileSP objfile, DWARFCompileUnit* dwarf_cu);
|
||||||
|
|
||||||
|
virtual
|
||||||
|
~SymbolFileDWARFDwo() = default;
|
||||||
|
|
||||||
|
const lldb_private::DWARFDataExtractor&
|
||||||
|
GetCachedSectionData(uint32_t got_flag,
|
||||||
|
lldb::SectionType sect_type,
|
||||||
|
lldb_private::DWARFDataExtractor &data) override;
|
||||||
|
|
||||||
|
lldb::CompUnitSP
|
||||||
|
ParseCompileUnit(DWARFCompileUnit* dwarf_cu, uint32_t cu_idx) override;
|
||||||
|
|
||||||
|
DWARFCompileUnit*
|
||||||
|
GetCompileUnit();
|
||||||
|
|
||||||
|
DWARFCompileUnit*
|
||||||
|
GetDWARFCompileUnit(lldb_private::CompileUnit *comp_unit) override;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
DIEToTypePtr&
|
||||||
|
GetDIEToType() override;
|
||||||
|
|
||||||
|
DIEToVariableSP&
|
||||||
|
GetDIEToVariable() override;
|
||||||
|
|
||||||
|
DIEToClangType&
|
||||||
|
GetForwardDeclDieToClangType() override;
|
||||||
|
|
||||||
|
ClangTypeToDIE&
|
||||||
|
GetForwardDeclClangTypeToDie() override;
|
||||||
|
|
||||||
|
lldb::ObjectFileSP m_obj_file_sp;
|
||||||
|
DWARFCompileUnit* m_base_dwarf_cu;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // SymbolFileDWARFDwo_SymbolFileDWARFDwo_h_
|
|
@ -602,15 +602,23 @@ ObjectFile::ClearSymtab ()
|
||||||
}
|
}
|
||||||
|
|
||||||
SectionList *
|
SectionList *
|
||||||
ObjectFile::GetSectionList()
|
ObjectFile::GetSectionList(bool update_module_section_list)
|
||||||
{
|
{
|
||||||
if (m_sections_ap.get() == nullptr)
|
if (m_sections_ap.get() == nullptr)
|
||||||
{
|
{
|
||||||
ModuleSP module_sp(GetModule());
|
if (update_module_section_list)
|
||||||
if (module_sp)
|
|
||||||
{
|
{
|
||||||
lldb_private::Mutex::Locker locker(module_sp->GetMutex());
|
ModuleSP module_sp(GetModule());
|
||||||
CreateSections(*module_sp->GetUnifiedSectionList());
|
if (module_sp)
|
||||||
|
{
|
||||||
|
lldb_private::Mutex::Locker locker(module_sp->GetMutex());
|
||||||
|
CreateSections(*module_sp->GetUnifiedSectionList());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SectionList unified_section_list;
|
||||||
|
CreateSections(unified_section_list);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return m_sections_ap.get();
|
return m_sections_ap.get();
|
||||||
|
|
Loading…
Reference in New Issue