提交 570735b3 编写于 作者: A Adrian Hunter 提交者: Ingo Molnar

perf jit: Let jit_process() return errors

In preparation for moving clockid validation into jit_process().

Previously a return value of zero meant the processing had been done and
non-zero meant either the processing was not done (i.e. not the jitdump
file mmap event) or an error occurred.

Change it so that zero means the processing was not done, one means the
processing was done and successful, and negative values are an error.
Signed-off-by: NAdrian Hunter <adrian.hunter@intel.com>
Signed-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1457005856-6143-5-git-send-email-adrian.hunter@intel.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
上级 5fb0ac16
...@@ -253,12 +253,16 @@ static int perf_event__jit_repipe_mmap(struct perf_tool *tool, ...@@ -253,12 +253,16 @@ static int perf_event__jit_repipe_mmap(struct perf_tool *tool,
{ {
struct perf_inject *inject = container_of(tool, struct perf_inject, tool); struct perf_inject *inject = container_of(tool, struct perf_inject, tool);
u64 n = 0; u64 n = 0;
int ret;
/* /*
* if jit marker, then inject jit mmaps and generate ELF images * if jit marker, then inject jit mmaps and generate ELF images
*/ */
if (!jit_process(inject->session, &inject->output, machine, ret = jit_process(inject->session, &inject->output, machine,
event->mmap.filename, sample->pid, &n)) { event->mmap.filename, sample->pid, &n);
if (ret < 0)
return ret;
if (ret) {
inject->bytes_written += n; inject->bytes_written += n;
return 0; return 0;
} }
...@@ -287,12 +291,16 @@ static int perf_event__jit_repipe_mmap2(struct perf_tool *tool, ...@@ -287,12 +291,16 @@ static int perf_event__jit_repipe_mmap2(struct perf_tool *tool,
{ {
struct perf_inject *inject = container_of(tool, struct perf_inject, tool); struct perf_inject *inject = container_of(tool, struct perf_inject, tool);
u64 n = 0; u64 n = 0;
int ret;
/* /*
* if jit marker, then inject jit mmaps and generate ELF images * if jit marker, then inject jit mmaps and generate ELF images
*/ */
if (!jit_process(inject->session, &inject->output, machine, ret = jit_process(inject->session, &inject->output, machine,
event->mmap2.filename, sample->pid, &n)) { event->mmap2.filename, sample->pid, &n);
if (ret < 0)
return ret;
if (ret) {
inject->bytes_written += n; inject->bytes_written += n;
return 0; return 0;
} }
......
...@@ -647,7 +647,7 @@ jit_process(struct perf_session *session, ...@@ -647,7 +647,7 @@ jit_process(struct perf_session *session,
* first, detect marker mmap (i.e., the jitdump mmap) * first, detect marker mmap (i.e., the jitdump mmap)
*/ */
if (jit_detect(filename, pid)) if (jit_detect(filename, pid))
return -1; return 0;
memset(&jd, 0, sizeof(jd)); memset(&jd, 0, sizeof(jd));
...@@ -665,8 +665,10 @@ jit_process(struct perf_session *session, ...@@ -665,8 +665,10 @@ jit_process(struct perf_session *session,
*nbytes = 0; *nbytes = 0;
ret = jit_inject(&jd, filename); ret = jit_inject(&jd, filename);
if (!ret) if (!ret) {
*nbytes = jd.bytes_written; *nbytes = jd.bytes_written;
ret = 1;
}
return ret; return ret;
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册