diff options
| author | Ingo Molnar <mingo@kernel.org> | 2016-10-24 20:42:42 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2016-10-24 20:42:42 +0200 | 
| commit | 76e2d2617d767c445498c4c4b1162eb2201cdd77 (patch) | |
| tree | e03764dba70ea6993366e25d16e1735b2d40cd26 /tools/perf/builtin-script.c | |
| parent | e9c848928abf4cb60601e9ae7d336f0333c98bca (diff) | |
| parent | 04b553ad7dc347eabd3cb4705932272453175a80 (diff) | |
Merge tag 'perf-core-for-mingo-20161024' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux into perf/core
Pull perf/core improvements and fixes from Arnaldo Carvalho de Melo:
New features:
- Dynamicly change verbosity level by pressing 'V' in the 'perf top/report'
  hists TUI browser (Alexis Berlemont)
- Implement 'perf trace --delay' in the same fashion as in 'perf record --delay',
  to skip sampling workload initialization events (Alexis Berlemont)
- Make vendor named events case insensitive in 'perf list', i.e.
  'perf list LONGEST_LAT' works just the same as  'perf list longest_lat' (Andi Kleen)
- Show instruction bytes and lenght in 'perf script' for Intel PT and BTS (Andi Kleen, Adrian Hunter)
   E.g:
    % perf record -e intel_pt// foo
    % perf script --itrace=i0ns -F ip,insn,insnlen
     ffffffff8101232f ilen: 5 insn: 0f 1f 44 00 00
     ffffffff81012334 ilen: 1 insn: 5b
     ffffffff81012335 ilen: 1 insn: 5d
     ffffffff81012336 ilen: 1 insn: c3
     ffffffff810123e3 ilen: 1 insn: 5b
     ffffffff810123e4 ilen: 2 insn: 41 5c
     ffffffff810123e6 ilen: 1 insn: 5d
     ffffffff810123e7 ilen: 1 insn: c3
     ffffffff810124a6 ilen: 2 insn: 31 c0
     ffffffff810124a8 ilen: 9 insn: 41 83 bc 24 a8 01 00 00 01
     ffffffff810124b1 ilen: 2 insn: 75 87
- Allow enabling the perf_event_attr.branch_type attribute member: (Andi Kleen)
  perf record -e sched:sched_switch,cpu/cpu-cycles,branch_type=any/ ...
- Add unwinding support for jitdump (Stefano Sanfilippo)
Fixes:
- Use raw_syscall:sys_enter timestamp in 'perf trace' (Arnaldo Carvalho de Melo)
Infrastructure:
- Allow jitdump to be built without libdwarf (Maciej Debski)
- Sync x86's syscall table tools/ copy (Arnaldo Carvalho de Melo)
- Fixes to avoid calling die() in library fuctions already propagating other
  errors (Arnaldo Carvalho de Melo)
- Improvements to allow libtraceevent to be properly installed in distro
  packages (Jiri Olsa)
- Removing coresight miscellaneous debug output (Mathieu Poirier)
- Cache align the 'perf bench futex' worker struct (Sebastian Andrzej Siewior)
Documentation:
- Minor improvements on the documentation of event parameters (Andi Kleen)
- Add jitdump format specification document (Stephane Eranian)
Spelling fixes:
- Fix typo "No enough" to "Not enough" (Alexander Alemayhu)
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/perf/builtin-script.c')
| -rw-r--r-- | tools/perf/builtin-script.c | 24 | 
1 files changed, 22 insertions, 2 deletions
| diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c index 7228d141a789..412fb6e65ac0 100644 --- a/tools/perf/builtin-script.c +++ b/tools/perf/builtin-script.c @@ -66,6 +66,8 @@ enum perf_output_field {  	PERF_OUTPUT_WEIGHT	    = 1U << 18,  	PERF_OUTPUT_BPF_OUTPUT	    = 1U << 19,  	PERF_OUTPUT_CALLINDENT	    = 1U << 20, +	PERF_OUTPUT_INSN	    = 1U << 21, +	PERF_OUTPUT_INSNLEN	    = 1U << 22,  };  struct output_option { @@ -93,6 +95,8 @@ struct output_option {  	{.str = "weight",   .field = PERF_OUTPUT_WEIGHT},  	{.str = "bpf-output",   .field = PERF_OUTPUT_BPF_OUTPUT},  	{.str = "callindent", .field = PERF_OUTPUT_CALLINDENT}, +	{.str = "insn", .field = PERF_OUTPUT_INSN}, +	{.str = "insnlen", .field = PERF_OUTPUT_INSNLEN},  };  /* default set to maintain compatibility with current format */ @@ -624,6 +628,20 @@ static void print_sample_callindent(struct perf_sample *sample,  		printf("%*s", spacing - len, "");  } +static void print_insn(struct perf_sample *sample, +		       struct perf_event_attr *attr) +{ +	if (PRINT_FIELD(INSNLEN)) +		printf(" ilen: %d", sample->insn_len); +	if (PRINT_FIELD(INSN)) { +		int i; + +		printf(" insn:"); +		for (i = 0; i < sample->insn_len; i++) +			printf(" %02x", (unsigned char)sample->insn[i]); +	} +} +  static void print_sample_bts(struct perf_sample *sample,  			     struct perf_evsel *evsel,  			     struct thread *thread, @@ -668,6 +686,8 @@ static void print_sample_bts(struct perf_sample *sample,  	if (print_srcline_last)  		map__fprintf_srcline(al->map, al->addr, "\n  ", stdout); +	print_insn(sample, attr); +  	printf("\n");  } @@ -911,7 +931,7 @@ static void process_event(struct perf_script *script,  	if (perf_evsel__is_bpf_output(evsel) && PRINT_FIELD(BPF_OUTPUT))  		print_sample_bpf_output(sample); - +	print_insn(sample, attr);  	printf("\n");  } @@ -2124,7 +2144,7 @@ int cmd_script(int argc, const char **argv, const char *prefix __maybe_unused)  		     "Valid types: hw,sw,trace,raw. "  		     "Fields: comm,tid,pid,time,cpu,event,trace,ip,sym,dso,"  		     "addr,symoff,period,iregs,brstack,brstacksym,flags," -		     "bpf-output,callindent", parse_output_fields), +		     "bpf-output,callindent,insn,insnlen", parse_output_fields),  	OPT_BOOLEAN('a', "all-cpus", &system_wide,  		    "system-wide collection from all CPUs"),  	OPT_STRING('S', "symbols", &symbol_conf.sym_list_str, "symbol[,symbol...]", | 
