Commit 18f49494 authored by Adrian Hunter's avatar Adrian Hunter Committed by Arnaldo Carvalho de Melo

perf auxtrace: Add Z itrace option for timeless decoding

Issues correlating timestamps can be avoided with timeless decoding. Add
an option for that, so that timeless decoding can be used even when
timestamps are present.
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Reviewed-by: default avatarAndi Kleen <ak@linux.intel.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Link: https://lore.kernel.org/r/20210430070309.17624-2-adrian.hunter@intel.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 88b06399
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
L synthesize last branch entries on existing event records L synthesize last branch entries on existing event records
s skip initial number of events s skip initial number of events
q quicker (less detailed) decoding q quicker (less detailed) decoding
Z prefer to ignore timestamps (so-called "timeless" decoding)
The default is all events i.e. the same as --itrace=ibxwpe, The default is all events i.e. the same as --itrace=ibxwpe,
except for perf script where it is --itrace=ce except for perf script where it is --itrace=ce
......
...@@ -1569,6 +1569,9 @@ int itrace_parse_synth_opts(const struct option *opt, const char *str, ...@@ -1569,6 +1569,9 @@ int itrace_parse_synth_opts(const struct option *opt, const char *str,
case 'q': case 'q':
synth_opts->quick += 1; synth_opts->quick += 1;
break; break;
case 'Z':
synth_opts->timeless_decoding = true;
break;
case ' ': case ' ':
case ',': case ',':
break; break;
......
...@@ -89,6 +89,7 @@ enum itrace_period_type { ...@@ -89,6 +89,7 @@ enum itrace_period_type {
* @tlb: whether to synthesize TLB events * @tlb: whether to synthesize TLB events
* @remote_access: whether to synthesize remote access events * @remote_access: whether to synthesize remote access events
* @mem: whether to synthesize memory events * @mem: whether to synthesize memory events
* @timeless_decoding: prefer "timeless" decoding i.e. ignore timestamps
* @callchain_sz: maximum callchain size * @callchain_sz: maximum callchain size
* @last_branch_sz: branch context size * @last_branch_sz: branch context size
* @period: 'instructions' events period * @period: 'instructions' events period
...@@ -128,6 +129,7 @@ struct itrace_synth_opts { ...@@ -128,6 +129,7 @@ struct itrace_synth_opts {
bool tlb; bool tlb;
bool remote_access; bool remote_access;
bool mem; bool mem;
bool timeless_decoding;
unsigned int callchain_sz; unsigned int callchain_sz;
unsigned int last_branch_sz; unsigned int last_branch_sz;
unsigned long long period; unsigned long long period;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment