perf probe: Improve an error message of perf probe --vars mode
Fix an error message when failed to find given address in --vars
mode.
Without this fix, perf probe -V doesn't show the final "Error"
message if it fails to find given source line. Moreover, it
tells it fails to find "variables" instead of the source line.
-----
# perf probe -V foo@bar
Failed to find variables at foo@bar (0)
-----
The result also shows mysterious error code. Actually the error
returns 0 or -ENOENT means that it just fails to find the address
of given source line. (0 means there is no matching address,
and -ENOENT means there is an entry(DIE) but it has no instance,
e.g. an empty inlined function)
This fixes it to show what happened and the final error message
as below.
-----
# perf probe -V foo@bar
Failed to find the address of foo@bar
Error: Failed to show vars.
-----
Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/20140606071359.6788.84716.stgit@kbuild-fedora.novalocal
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
committed by
Arnaldo Carvalho de Melo
parent
b4bf1130cd
commit
69e96eaa4f
@@ -721,9 +721,14 @@ static int show_available_vars_at(struct debuginfo *dinfo,
|
|||||||
ret = debuginfo__find_available_vars_at(dinfo, pev, &vls,
|
ret = debuginfo__find_available_vars_at(dinfo, pev, &vls,
|
||||||
max_vls, externs);
|
max_vls, externs);
|
||||||
if (ret <= 0) {
|
if (ret <= 0) {
|
||||||
pr_err("Failed to find variables at %s (%d)\n", buf, ret);
|
if (ret == 0 || ret == -ENOENT) {
|
||||||
|
pr_err("Failed to find the address of %s\n", buf);
|
||||||
|
ret = -ENOENT;
|
||||||
|
} else
|
||||||
|
pr_warning("Debuginfo analysis failed.\n");
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Some variables are found */
|
/* Some variables are found */
|
||||||
fprintf(stdout, "Available variables at %s\n", buf);
|
fprintf(stdout, "Available variables at %s\n", buf);
|
||||||
for (i = 0; i < ret; i++) {
|
for (i = 0; i < ret; i++) {
|
||||||
|
|||||||
@@ -1280,7 +1280,11 @@ out:
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find available variables at given probe point */
|
/*
|
||||||
|
* Find available variables at given probe point
|
||||||
|
* Return the number of found probe points. Return 0 if there is no
|
||||||
|
* matched probe point. Return <0 if an error occurs.
|
||||||
|
*/
|
||||||
int debuginfo__find_available_vars_at(struct debuginfo *dbg,
|
int debuginfo__find_available_vars_at(struct debuginfo *dbg,
|
||||||
struct perf_probe_event *pev,
|
struct perf_probe_event *pev,
|
||||||
struct variable_list **vls,
|
struct variable_list **vls,
|
||||||
|
|||||||
Reference in New Issue
Block a user