[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <53D49CC5.80107@intel.com>
Date: Sun, 27 Jul 2014 09:31:33 +0300
From: Adrian Hunter <adrian.hunter@...el.com>
To: Arnaldo Carvalho de Melo <acme@...nel.org>
CC: Peter Zijlstra <peterz@...radead.org>,
linux-kernel@...r.kernel.org, David Ahern <dsahern@...il.com>,
Frederic Weisbecker <fweisbec@...il.com>,
Jiri Olsa <jolsa@...hat.com>,
Namhyung Kim <namhyung@...il.com>,
Paul Mackerras <paulus@...ba.org>,
Stephane Eranian <eranian@...gle.com>
Subject: Re: [PATCH 28/52] perf script: Allow callchains if any event samples
them
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@...el.com>
>> ---
>> 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@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists