perf script: Fix export of callchains with recursion in db-export
authorChris Phlipot <cphlipot0@gmail.com>
Wed, 11 May 2016 03:26:49 +0000 (20:26 -0700)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 11 May 2016 15:24:58 +0000 (12:24 -0300)
When an IP with an unresolved symbol occurs in the callchain more than
once (ie. recursion), then duplicate symbols can be created because
the callchain nodes are never updated after they are first created.

To fix this issue we call dso__find_symbol whenever we encounter a NULL
symbol, in case we already added a symbol at that IP since we started
traversing the callchain.

This change prevents duplicate symbols from being exported when duplicate
IPs are present in the callchain.

Signed-off-by: Chris Phlipot <cphlipot0@gmail.com>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1462937209-6032-5-git-send-email-cphlipot0@gmail.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/db-export.c

index 8ca4186bf31bf8877e867cd9bd2e636bff32952c..8d96c80cc67e629f0ef576ae24c1266e468df91f 100644 (file)
@@ -326,6 +326,10 @@ static struct call_path *call_path_from_sample(struct db_export *dbe,
                al.machine = machine;
                al.addr = node->ip;
 
+               if (al.map && !al.sym)
+                       al.sym = dso__find_symbol(al.map->dso, MAP__FUNCTION,
+                                                 al.addr);
+
                db_ids_from_al(dbe, &al, &dso_db_id, &sym_db_id, &offset);
 
                /* add node to the call path tree if it doesn't exist */