Commit 06b234ec authored by Adrian Hunter's avatar Adrian Hunter Committed by Arnaldo Carvalho de Melo

perf script: Don't assume evsel position of tracking events

The tracking event does not have to be the first event so replace
perf_evlist__first() with perf_evlist__id2evsel() which uses the event
ID to find the correct evsel.
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Acked-by: default avatarPeter Zijlstra (Intel) <peterz@infradead.org>
Tested-by: default avatarJiri Olsa <jolsa@redhat.com>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Mathieu Poirier <mathieu.poirier@linaro.org>
Cc: Pawel Moll <pawel.moll@arm.com>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/r/1437471846-26995-5-git-send-email-adrian.hunter@intel.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent b757bb09
...@@ -661,7 +661,7 @@ static int process_comm_event(struct perf_tool *tool, ...@@ -661,7 +661,7 @@ static int process_comm_event(struct perf_tool *tool,
struct thread *thread; struct thread *thread;
struct perf_script *script = container_of(tool, struct perf_script, tool); struct perf_script *script = container_of(tool, struct perf_script, tool);
struct perf_session *session = script->session; struct perf_session *session = script->session;
struct perf_evsel *evsel = perf_evlist__first(session->evlist); struct perf_evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id);
int ret = -1; int ret = -1;
thread = machine__findnew_thread(machine, event->comm.pid, event->comm.tid); thread = machine__findnew_thread(machine, event->comm.pid, event->comm.tid);
...@@ -695,7 +695,7 @@ static int process_fork_event(struct perf_tool *tool, ...@@ -695,7 +695,7 @@ static int process_fork_event(struct perf_tool *tool,
struct thread *thread; struct thread *thread;
struct perf_script *script = container_of(tool, struct perf_script, tool); struct perf_script *script = container_of(tool, struct perf_script, tool);
struct perf_session *session = script->session; struct perf_session *session = script->session;
struct perf_evsel *evsel = perf_evlist__first(session->evlist); struct perf_evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id);
if (perf_event__process_fork(tool, event, sample, machine) < 0) if (perf_event__process_fork(tool, event, sample, machine) < 0)
return -1; return -1;
...@@ -727,7 +727,7 @@ static int process_exit_event(struct perf_tool *tool, ...@@ -727,7 +727,7 @@ static int process_exit_event(struct perf_tool *tool,
struct thread *thread; struct thread *thread;
struct perf_script *script = container_of(tool, struct perf_script, tool); struct perf_script *script = container_of(tool, struct perf_script, tool);
struct perf_session *session = script->session; struct perf_session *session = script->session;
struct perf_evsel *evsel = perf_evlist__first(session->evlist); struct perf_evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id);
thread = machine__findnew_thread(machine, event->fork.pid, event->fork.tid); thread = machine__findnew_thread(machine, event->fork.pid, event->fork.tid);
if (thread == NULL) { if (thread == NULL) {
...@@ -759,7 +759,7 @@ static int process_mmap_event(struct perf_tool *tool, ...@@ -759,7 +759,7 @@ static int process_mmap_event(struct perf_tool *tool,
struct thread *thread; struct thread *thread;
struct perf_script *script = container_of(tool, struct perf_script, tool); struct perf_script *script = container_of(tool, struct perf_script, tool);
struct perf_session *session = script->session; struct perf_session *session = script->session;
struct perf_evsel *evsel = perf_evlist__first(session->evlist); struct perf_evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id);
if (perf_event__process_mmap(tool, event, sample, machine) < 0) if (perf_event__process_mmap(tool, event, sample, machine) < 0)
return -1; return -1;
...@@ -790,7 +790,7 @@ static int process_mmap2_event(struct perf_tool *tool, ...@@ -790,7 +790,7 @@ static int process_mmap2_event(struct perf_tool *tool,
struct thread *thread; struct thread *thread;
struct perf_script *script = container_of(tool, struct perf_script, tool); struct perf_script *script = container_of(tool, struct perf_script, tool);
struct perf_session *session = script->session; struct perf_session *session = script->session;
struct perf_evsel *evsel = perf_evlist__first(session->evlist); struct perf_evsel *evsel = perf_evlist__id2evsel(session->evlist, sample->id);
if (perf_event__process_mmap2(tool, event, sample, machine) < 0) if (perf_event__process_mmap2(tool, event, sample, machine) < 0)
return -1; return -1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment