DWARFIndex: s/ReportInvalidDIEOffset/ReportInvalidDIERef

In a dwo/debug_types world, the die offset is not enough to uniquely
idendify a debug info entry. Pass the the entire DIERef object instead.

This is technically NFC, because only AppleIndex implemented this
method (and there, the die offset *is* enough for unique
identification). However, this makes the code simpler, and simplifies
some of the follow-up patches.

llvm-svn: 363373
This commit is contained in:
Pavel Labath 2019-06-14 12:01:18 +00:00
parent 30557ace0f
commit 78b2cf71f5
7 changed files with 17 additions and 27 deletions

View File

@ -155,12 +155,12 @@ void AppleDWARFIndex::GetFunctions(const RegularExpression &regex,
DWARFMappedHash::ExtractDIEArray(hash_data, offsets);
}
void AppleDWARFIndex::ReportInvalidDIEOffset(dw_offset_t offset,
void AppleDWARFIndex::ReportInvalidDIERef(const DIERef &ref,
llvm::StringRef name) {
m_module.ReportErrorIfModifyDetected(
"the DWARF debug information has been modified (accelerator table had "
"bad die 0x%8.8x for '%s')\n",
offset, name.str().c_str());
ref.die_offset, name.str().c_str());
}
void AppleDWARFIndex::Dump(Stream &s) {

View File

@ -48,8 +48,7 @@ public:
std::vector<DWARFDIE> &dies) override;
void GetFunctions(const RegularExpression &regex, DIEArray &offsets) override;
void ReportInvalidDIEOffset(dw_offset_t offset,
llvm::StringRef name) override;
void ReportInvalidDIERef(const DIERef &ref, llvm::StringRef name) override;
void Dump(Stream &s) override;
private:

View File

@ -24,7 +24,7 @@ void DWARFIndex::ProcessFunctionDIE(llvm::StringRef name, DIERef ref,
std::vector<DWARFDIE> &dies) {
DWARFDIE die = info.GetDIE(ref);
if (!die) {
ReportInvalidDIEOffset(ref.die_offset, name);
ReportInvalidDIERef(ref, name);
return;
}

View File

@ -47,8 +47,7 @@ public:
virtual void GetFunctions(const RegularExpression &regex,
DIEArray &offsets) = 0;
virtual void ReportInvalidDIEOffset(dw_offset_t offset,
llvm::StringRef name) = 0;
virtual void ReportInvalidDIERef(const DIERef &ref, llvm::StringRef name) = 0;
virtual void Dump(Stream &s) = 0;
protected:

View File

@ -41,8 +41,7 @@ public:
void GetFunctions(const RegularExpression &regex,
DIEArray &offsets) override;
void ReportInvalidDIEOffset(dw_offset_t offset,
llvm::StringRef name) override {}
void ReportInvalidDIERef(const DIERef &ref, llvm::StringRef name) override {}
void Dump(Stream &s) override;
private:

View File

@ -39,8 +39,7 @@ public:
std::vector<DWARFDIE> &dies) override;
void GetFunctions(const RegularExpression &regex, DIEArray &offsets) override;
void ReportInvalidDIEOffset(dw_offset_t offset,
llvm::StringRef name) override {}
void ReportInvalidDIERef(const DIERef &ref, llvm::StringRef name) override {}
void Dump(Stream &s) override;
private:

View File

@ -2064,8 +2064,7 @@ uint32_t SymbolFileDWARF::FindGlobalVariables(
} break;
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, name.GetStringRef());
}
}
}
@ -2128,7 +2127,7 @@ uint32_t SymbolFileDWARF::FindGlobalVariables(const RegularExpression &regex,
if (variables.GetSize() - original_size >= max_matches)
break;
} else
m_index->ReportInvalidDIEOffset(die_ref.die_offset, regex.GetText());
m_index->ReportInvalidDIERef(die_ref, regex.GetText());
}
}
@ -2312,7 +2311,7 @@ uint32_t SymbolFileDWARF::FindFunctions(const RegularExpression &regex,
for (DIERef ref : offsets) {
DWARFDIE die = info->GetDIE(ref);
if (!die) {
m_index->ReportInvalidDIEOffset(ref.die_offset, regex.GetText());
m_index->ReportInvalidDIERef(ref, regex.GetText());
continue;
}
if (resolved_dies.insert(die.GetDIE()).second)
@ -2415,8 +2414,7 @@ uint32_t SymbolFileDWARF::FindTypes(
break;
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, name.GetStringRef());
}
}
const uint32_t num_matches = types.GetSize() - initial_types_size;
@ -2494,8 +2492,7 @@ size_t SymbolFileDWARF::FindTypes(const std::vector<CompilerContext> &context,
++num_matches;
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, name.GetStringRef());
}
}
return num_matches;
@ -2540,8 +2537,7 @@ SymbolFileDWARF::FindNamespace(ConstString name,
break;
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, name.GetStringRef());
}
}
}
@ -2751,8 +2747,7 @@ TypeSP SymbolFileDWARF::FindCompleteObjCDefinitionTypeForDIE(
}
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
type_name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, type_name.GetStringRef());
}
}
}
@ -2959,8 +2954,7 @@ TypeSP SymbolFileDWARF::FindDefinitionTypeForDWARFDeclContext(
}
}
} else {
m_index->ReportInvalidDIEOffset(die_ref.die_offset,
type_name.GetStringRef());
m_index->ReportInvalidDIERef(die_ref, type_name.GetStringRef());
}
}
}
@ -3127,7 +3121,7 @@ size_t SymbolFileDWARF::ParseVariablesForContext(const SymbolContext &sc) {
++vars_added;
}
} else
m_index->ReportInvalidDIEOffset(die_ref.die_offset, "");
m_index->ReportInvalidDIERef(die_ref, "");
}
}
}