summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--dwflpp.cxx10
-rw-r--r--tapsets.cxx14
2 files changed, 14 insertions, 10 deletions
diff --git a/dwflpp.cxx b/dwflpp.cxx
index c781ef7a..6a697de7 100644
--- a/dwflpp.cxx
+++ b/dwflpp.cxx
@@ -629,9 +629,6 @@ dwflpp::iterate_over_functions (int (* callback)(Dwarf_Die * func, base_query *
}
else if (name_has_wildcard (function))
{
- // track addresses we've already seen
- set<Dwarf_Addr> alias_dupes;
-
for (it = v->begin(); it != v->end(); it++)
{
if (pending_interrupts) return DWARF_CB_ABORT;
@@ -643,13 +640,6 @@ dwflpp::iterate_over_functions (int (* callback)(Dwarf_Die * func, base_query *
clog << "function cache " << key << " match " << func_name << " vs "
<< function << endl;
- // make sure that this function address hasn't
- // already been matched under an aliased name
- Dwarf_Addr addr;
- if (dwarf_entrypc(&die, &addr) == 0 &&
- !alias_dupes.insert(addr).second)
- continue;
-
rc = (*callback)(& die, q);
if (rc != DWARF_CB_OK) break;
}
diff --git a/tapsets.cxx b/tapsets.cxx
index 8d0e0ab2..9884860a 100644
--- a/tapsets.cxx
+++ b/tapsets.cxx
@@ -548,6 +548,9 @@ struct dwarf_query : public base_query
Dwarf_Die *scope_die,
Dwarf_Addr addr);
+ // Track addresses we've already seen in a given module
+ set<Dwarf_Addr> alias_dupes;
+
// Extracted parameters.
string function_val;
@@ -854,6 +857,9 @@ dwarf_query::handle_query_module()
// prebuild the symbol table to resolve aliases
dw.mod_info->get_symtab(this);
+ // reset the dupe-checking for each new module
+ alias_dupes.clear();
+
if (dw.mod_info->dwarf_status == info_present)
query_module_dwarf();
@@ -1272,6 +1278,14 @@ query_dwarf_func (Dwarf_Die * func, base_query * bq)
{
q->dw.focus_on_function (func);
+ // make sure that this function address hasn't
+ // already been matched under an aliased name
+ Dwarf_Addr addr;
+ if (!q->dw.func_is_inline() &&
+ dwarf_entrypc(func, &addr) == 0 &&
+ !q->alias_dupes.insert(addr).second)
+ return DWARF_CB_OK;
+
if (q->dw.func_is_inline ()
&& (! q->has_call) && (! q->has_return)
&& (q->has_statement_str || q->has_function_str))