forked from Minki/linux
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:
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,
|
||||
max_vls, externs);
|
||||
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;
|
||||
}
|
||||
|
||||
/* Some variables are found */
|
||||
fprintf(stdout, "Available variables at %s\n", buf);
|
||||
for (i = 0; i < ret; i++) {
|
||||
|
@ -1280,7 +1280,11 @@ out:
|
||||
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,
|
||||
struct perf_probe_event *pev,
|
||||
struct variable_list **vls,
|
||||
|
Loading…
Reference in New Issue
Block a user