aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util
diff options
context:
space:
mode:
authorDon Zickus <dzickus@redhat.com>2013-11-13 13:32:06 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2013-11-14 14:00:01 -0500
commit9d4ecc8893832337daf241236841db966fa53489 (patch)
treea585ae8a20208b8f1afe85d584cac2bfd42323a9 /tools/perf/util
parentea432a8bb940e6bea2aaeca3c0ff3d931ad81f2e (diff)
perf tools: Synthesize anon MMAP records again
When introducing the PERF_RECORD_MMAP2 in: 5c5e854bc760 perf tools: Add attr->mmap2 support A check for the number of entries parsed by sscanf was introduced that assumed all of the 8 fields needed to be correctly parsed so that particular /proc/pid/maps line would be considered synthesizable. That broke anon records synthesizing, as it doesn't have the 'execname' field. Fix it by keeping the sscanf return check, changing it to not require that the 'execname' variable be parsed, so that the preexisting logic can kick in and set it to '//anon'. This should get things like JIT profiling working again. Signed-off-by: Don Zickus <dzickus@redhat.com> Cc: Bill Gray <bgray@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Joe Mario <jmario@redhat.com> Cc: Richard Fowles <rfowles@redhat.com> Cc: Stephane Eranian <eranian@google.com> Cc: stable@vger.kernel.org Link: http://lkml.kernel.org/n/tip-bo4akalno7579shpz29u867j@git.kernel.org [ commit log message is mine, dzickus reported the problem with a patch ] Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util')
-rw-r--r--tools/perf/util/event.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/tools/perf/util/event.c b/tools/perf/util/event.c
index 6e3a846aed0e..bb788c109fe6 100644
--- a/tools/perf/util/event.c
+++ b/tools/perf/util/event.c
@@ -209,8 +209,10 @@ static int perf_event__synthesize_mmap_events(struct perf_tool *tool,
209 &event->mmap.start, &event->mmap.len, prot, 209 &event->mmap.start, &event->mmap.len, prot,
210 &event->mmap.pgoff, 210 &event->mmap.pgoff,
211 execname); 211 execname);
212 212 /*
213 if (n != 5) 213 * Anon maps don't have the execname.
214 */
215 if (n < 4)
214 continue; 216 continue;
215 /* 217 /*
216 * Just like the kernel, see __perf_event_mmap in kernel/perf_event.c 218 * Just like the kernel, see __perf_event_mmap in kernel/perf_event.c