aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/util/dwarf-aux.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/tools/perf/util/dwarf-aux.c b/tools/perf/util/dwarf-aux.c
index d0f4048b634f..ee51e9b4dc09 100644
--- a/tools/perf/util/dwarf-aux.c
+++ b/tools/perf/util/dwarf-aux.c
@@ -307,6 +307,17 @@ static int die_get_call_fileno(Dwarf_Die *in_die)
307 return -ENOENT; 307 return -ENOENT;
308} 308}
309 309
310/* Get the declared file index number in CU DIE */
311static int die_get_decl_fileno(Dwarf_Die *pdie)
312{
313 Dwarf_Sword idx;
314
315 if (die_get_attr_sdata(pdie, DW_AT_decl_file, &idx) == 0)
316 return (int)idx;
317 else
318 return -ENOENT;
319}
320
310/** 321/**
311 * die_get_call_file - Get callsite file name of inlined function instance 322 * die_get_call_file - Get callsite file name of inlined function instance
312 * @in_die: a DIE of an inlined function instance 323 * @in_die: a DIE of an inlined function instance
@@ -467,6 +478,7 @@ static int __die_walk_instances_cb(Dwarf_Die *inst, void *data)
467 Dwarf_Die origin_mem; 478 Dwarf_Die origin_mem;
468 Dwarf_Attribute *attr; 479 Dwarf_Attribute *attr;
469 Dwarf_Die *origin; 480 Dwarf_Die *origin;
481 int tmp;
470 482
471 attr = dwarf_attr(inst, DW_AT_abstract_origin, &attr_mem); 483 attr = dwarf_attr(inst, DW_AT_abstract_origin, &attr_mem);
472 if (attr == NULL) 484 if (attr == NULL)
@@ -476,6 +488,16 @@ static int __die_walk_instances_cb(Dwarf_Die *inst, void *data)
476 if (origin == NULL || origin->addr != iwp->addr) 488 if (origin == NULL || origin->addr != iwp->addr)
477 return DIE_FIND_CB_CONTINUE; 489 return DIE_FIND_CB_CONTINUE;
478 490
491 /* Ignore redundant instances */
492 if (dwarf_tag(inst) == DW_TAG_inlined_subroutine) {
493 dwarf_decl_line(origin, &tmp);
494 if (die_get_call_lineno(inst) == tmp) {
495 tmp = die_get_decl_fileno(origin);
496 if (die_get_call_fileno(inst) == tmp)
497 return DIE_FIND_CB_CONTINUE;
498 }
499 }
500
479 iwp->retval = iwp->callback(inst, iwp->data); 501 iwp->retval = iwp->callback(inst, iwp->data);
480 502
481 return (iwp->retval) ? DIE_FIND_CB_END : DIE_FIND_CB_CONTINUE; 503 return (iwp->retval) ? DIE_FIND_CB_END : DIE_FIND_CB_CONTINUE;