summaryrefslogtreecommitdiff
path: root/Libraries
diff options
context:
space:
mode:
authorItamar <itamar8910@gmail.com>2020-05-08 15:38:54 +0300
committerAndreas Kling <kling@serenityos.org>2020-05-09 23:41:08 +0200
commitb28ca9fad11dfe0759c6ebd2517817a22fbeedc6 (patch)
treec0c37ba0bca0298b60ace4654277806c61dabf68 /Libraries
parent2acce56ac15c2229d59c3d2b1128b6c147430a15 (diff)
downloadserenity-b28ca9fad11dfe0759c6ebd2517817a22fbeedc6.zip
LibDebug: Add support for creating VariableInfo for paramters
Diffstat (limited to 'Libraries')
-rw-r--r--Libraries/LibDebug/DebugInfo.cpp24
-rw-r--r--Libraries/LibDebug/DebugInfo.h2
-rw-r--r--Libraries/LibDebug/Dwarf/DwarfTypes.h1
3 files changed, 21 insertions, 6 deletions
diff --git a/Libraries/LibDebug/DebugInfo.cpp b/Libraries/LibDebug/DebugInfo.cpp
index caeaa6e3af..d5486f868e 100644
--- a/Libraries/LibDebug/DebugInfo.cpp
+++ b/Libraries/LibDebug/DebugInfo.cpp
@@ -74,7 +74,8 @@ void DebugInfo::parse_scopes_impl(const Dwarf::DIE& die)
scope.address_high = scope.address_low + child.get_attribute(Dwarf::Attribute::HighPc).value().data.as_u32;
child.for_each_child([&](const Dwarf::DIE& variable_entry) {
- if (variable_entry.tag() != Dwarf::EntryTag::Variable)
+ if (!(variable_entry.tag() == Dwarf::EntryTag::Variable
+ || variable_entry.tag() == Dwarf::EntryTag::FormalParameter))
return;
scope.dies_of_variables.append(variable_entry);
});
@@ -148,15 +149,26 @@ NonnullOwnPtrVector<DebugInfo::VariableInfo> DebugInfo::get_variables_in_current
continue;
for (const auto& die_entry : scope.dies_of_variables) {
- variables.append(create_variable_info(die_entry, regs));
+ auto variable_info = create_variable_info(die_entry, regs);
+ if (!variable_info)
+ continue;
+ variables.append(variable_info.release_nonnull());
}
}
return variables;
}
-NonnullOwnPtr<DebugInfo::VariableInfo> DebugInfo::create_variable_info(const Dwarf::DIE& variable_die, const PtraceRegisters& regs) const
+OwnPtr<DebugInfo::VariableInfo> DebugInfo::create_variable_info(const Dwarf::DIE& variable_die, const PtraceRegisters& regs) const
{
- ASSERT(variable_die.tag() == Dwarf::EntryTag::Variable || variable_die.tag() == Dwarf::EntryTag::Member);
+ ASSERT(variable_die.tag() == Dwarf::EntryTag::Variable
+ || variable_die.tag() == Dwarf::EntryTag::Member
+ || variable_die.tag() == Dwarf::EntryTag::FormalParameter);
+
+ if (variable_die.tag() == Dwarf::EntryTag::FormalParameter
+ && !variable_die.get_attribute(Dwarf::Attribute::Name).has_value()) {
+ // We don't want to display info for unused paramters
+ return {};
+ }
NonnullOwnPtr<VariableInfo> variable_info = make<VariableInfo>();
@@ -201,13 +213,15 @@ NonnullOwnPtr<DebugInfo::VariableInfo> DebugInfo::create_variable_info(const Dwa
if (member.is_null())
return;
auto member_variable = create_variable_info(member, regs);
+
+ ASSERT(member_variable);
ASSERT(member_variable->location_type == DebugInfo::VariableInfo::LocationType::Address);
ASSERT(variable_info->location_type == DebugInfo::VariableInfo::LocationType::Address);
member_variable->location_data.address += variable_info->location_data.address;
member_variable->parent = variable_info.ptr();
- variable_info->members.append(move(member_variable));
+ variable_info->members.append(member_variable.release_nonnull());
});
return variable_info;
diff --git a/Libraries/LibDebug/DebugInfo.h b/Libraries/LibDebug/DebugInfo.h
index 334e5e2a32..de73a8aa38 100644
--- a/Libraries/LibDebug/DebugInfo.h
+++ b/Libraries/LibDebug/DebugInfo.h
@@ -99,7 +99,7 @@ private:
void prepare_variable_scopes();
void prepare_lines();
void parse_scopes_impl(const Dwarf::DIE& die);
- NonnullOwnPtr<VariableInfo> create_variable_info(const Dwarf::DIE& variable_die, const PtraceRegisters&) const;
+ OwnPtr<VariableInfo> create_variable_info(const Dwarf::DIE& variable_die, const PtraceRegisters&) const;
NonnullRefPtr<const ELF::Loader> m_elf;
NonnullRefPtr<Dwarf::DwarfInfo> m_dwarf_info;
diff --git a/Libraries/LibDebug/Dwarf/DwarfTypes.h b/Libraries/LibDebug/Dwarf/DwarfTypes.h
index cd8efb04d8..a4f1d271a9 100644
--- a/Libraries/LibDebug/Dwarf/DwarfTypes.h
+++ b/Libraries/LibDebug/Dwarf/DwarfTypes.h
@@ -38,6 +38,7 @@ struct [[gnu::packed]] CompilationUnitHeader
enum class EntryTag : u32 {
None = 0,
+ FormalParameter = 0x5,
LexicalBlock = 0xb,
Member = 0xd,
SubProgram = 0x2e,