Re: [PATCH 28/52] perf script: Allow callchains if any event samples them

From: Adrian Hunter
Date: Sun Jul 27 2014 - 02:31:54 EST


On 25/07/2014 4:27 p.m., Arnaldo Carvalho de Melo wrote:
Em Tue, Jul 22, 2014 at 04:17:37PM +0300, Adrian Hunter escreveu:
perf script was not displaying callchains if any selected
event did not have PERF_SAMPLE_CALLCHAIN. Change this to
disable callchains only if all selected events do not have
PERF_SAMPLE_CALLCHAIN.

I wonder if some other tool gets this wrong as well, report maybe?

perf report was ok


Perhaps we need to have this check in some perf_evlist method?

Possibly


Wonder how report/top, i.e. the hists browser will react with some
events having callchains while some don't, specially with this new
children stuff, Namhyung, can you please check that?

Adrian, can you, in a case like that, provide a command line that
creates such combo? I.e. how to create a perf.data file with multiple
events with some having callchains while some don't.

For now, it looks like this is something that only Intel PT will do.
Intel PT decoding can create "instructions" samples that look like they
came from the "instructions" hardware event, and then Intel PT will
optionally synthesize call chains on them as well.


As a rule, it is better to ease reproducing behaviour you mention when
fixing stuff, so that quickly others can try and go on trying to fix it.

Thanks,

- Arnaldo

Signed-off-by: Adrian Hunter <adrian.hunter@xxxxxxxxx>
---
tools/perf/builtin-script.c | 17 +++++++++++++----
1 file changed, 13 insertions(+), 4 deletions(-)

diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c
index 582da97..c1a56f2 100644
--- a/tools/perf/builtin-script.c
+++ b/tools/perf/builtin-script.c
@@ -184,10 +184,6 @@ static int perf_evsel__check_attr(struct perf_evsel *evsel,
if (perf_evsel__check_stype(evsel, PERF_SAMPLE_IP, "IP",
PERF_OUTPUT_IP))
return -EINVAL;
-
- if (!no_callchain &&
- !(attr->sample_type & PERF_SAMPLE_CALLCHAIN))
- symbol_conf.use_callchain = false;
}

if (PRINT_FIELD(ADDR) &&
@@ -290,6 +286,19 @@ static int perf_session__check_output_opt(struct perf_session *session)
set_print_ip_opts(&evsel->attr);
}

+ if (!no_callchain) {
+ bool use_callchain = false;
+
+ evlist__for_each(session->evlist, evsel) {
+ if (evsel->attr.sample_type & PERF_SAMPLE_CALLCHAIN) {
+ use_callchain = true;
+ break;
+ }
+ }
+ if (!use_callchain)
+ symbol_conf.use_callchain = false;
+ }
+
/*
* set default for tracepoints to print symbols only
* if callchains are present
--
1.8.3.2
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/