diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-04-30 07:41:01 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-04-30 07:41:01 -0700 | 
| commit | e0972916e8fe943f342b0dd1c9d43dbf5bc261c2 (patch) | |
| tree | 690c436f1f9b839c4ba34d17ab3efa63b97a2dce /tools/perf/util/evsel.c | |
| parent | 1f889ec62c3f0d8913f3c32f9aff2a1e15099346 (diff) | |
| parent | 5ac2b5c2721501a8f5c5e1cd4116cbc31ace6886 (diff) | |
| download | olio-linux-3.10-e0972916e8fe943f342b0dd1c9d43dbf5bc261c2.tar.xz olio-linux-3.10-e0972916e8fe943f342b0dd1c9d43dbf5bc261c2.zip | |
Merge branch 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull perf updates from Ingo Molnar:
 "Features:
   - Add "uretprobes" - an optimization to uprobes, like kretprobes are
     an optimization to kprobes.  "perf probe -x file sym%return" now
     works like kretprobes.  By Oleg Nesterov.
   - Introduce per core aggregation in 'perf stat', from Stephane
     Eranian.
   - Add memory profiling via PEBS, from Stephane Eranian.
   - Event group view for 'annotate' in --stdio, --tui and --gtk, from
     Namhyung Kim.
   - Add support for AMD NB and L2I "uncore" counters, by Jacob Shin.
   - Add Ivy Bridge-EP uncore support, by Zheng Yan
   - IBM zEnterprise EC12 oprofile support patchlet from Robert Richter.
   - Add perf test entries for checking breakpoint overflow signal
     handler issues, from Jiri Olsa.
   - Add perf test entry for for checking number of EXIT events, from
     Namhyung Kim.
   - Add perf test entries for checking --cpu in record and stat, from
     Jiri Olsa.
   - Introduce perf stat --repeat forever, from Frederik Deweerdt.
   - Add --no-demangle to report/top, from Namhyung Kim.
   - PowerPC fixes plus a couple of cleanups/optimizations in uprobes
     and trace_uprobes, by Oleg Nesterov.
  Various fixes and refactorings:
   - Fix dependency of the python binding wrt libtraceevent, from
     Naohiro Aota.
   - Simplify some perf_evlist methods and to allow 'stat' to share code
     with 'record' and 'trace', by Arnaldo Carvalho de Melo.
   - Remove dead code in related to libtraceevent integration, from
     Namhyung Kim.
   - Revert "perf sched: Handle PERF_RECORD_EXIT events" to get 'perf
     sched lat' back working, by Arnaldo Carvalho de Melo
   - We don't use Newt anymore, just plain libslang, by Arnaldo Carvalho
     de Melo.
   - Kill a bunch of die() calls, from Namhyung Kim.
   - Fix build on non-glibc systems due to libio.h absence, from Cody P
     Schafer.
   - Remove some perf_session and tracing dead code, from David Ahern.
   - Honor parallel jobs, fix from Borislav Petkov
   - Introduce tools/lib/lk library, initially just removing duplication
     among tools/perf and tools/vm.  from Borislav Petkov
  ... and many more I missed to list, see the shortlog and git log for
  more details."
* 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (136 commits)
  perf/x86/intel/P4: Robistify P4 PMU types
  perf/x86/amd: Fix AMD NB and L2I "uncore" support
  perf/x86/amd: Remove old-style NB counter support from perf_event_amd.c
  perf/x86: Check all MSRs before passing hw check
  perf/x86/amd: Add support for AMD NB and L2I "uncore" counters
  perf/x86/intel: Add Ivy Bridge-EP uncore support
  perf/x86/intel: Fix SNB-EP CBO and PCU uncore PMU filter management
  perf/x86: Avoid kfree() in CPU_{STARTING,DYING}
  uprobes/perf: Avoid perf_trace_buf_prepare/submit if ->perf_events is empty
  uprobes/tracing: Don't pass addr=ip to perf_trace_buf_submit()
  uprobes/tracing: Change create_trace_uprobe() to support uretprobes
  uprobes/tracing: Make seq_printf() code uretprobe-friendly
  uprobes/tracing: Make register_uprobe_event() paths uretprobe-friendly
  uprobes/tracing: Make uprobe_{trace,perf}_print() uretprobe-friendly
  uprobes/tracing: Introduce is_ret_probe() and uretprobe_dispatcher()
  uprobes/tracing: Introduce uprobe_{trace,perf}_print() helpers
  uprobes/tracing: Generalize struct uprobe_trace_entry_head
  uprobes/tracing: Kill the pointless local_save_flags/preempt_count calls
  uprobes/tracing: Kill the pointless seq_print_ip_sym() call
  uprobes/tracing: Kill the pointless task_pt_regs() calls
  ...
Diffstat (limited to 'tools/perf/util/evsel.c')
| -rw-r--r-- | tools/perf/util/evsel.c | 32 | 
1 files changed, 28 insertions, 4 deletions
| diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c index 9c82f98f26d..07b1a3ad3e2 100644 --- a/tools/perf/util/evsel.c +++ b/tools/perf/util/evsel.c @@ -10,7 +10,7 @@  #include <byteswap.h>  #include <linux/bitops.h>  #include "asm/bug.h" -#include "debugfs.h" +#include <lk/debugfs.h>  #include "event-parse.h"  #include "evsel.h"  #include "evlist.h" @@ -554,6 +554,9 @@ void perf_evsel__config(struct perf_evsel *evsel,  		perf_evsel__set_sample_bit(evsel, CPU);  	} +	if (opts->sample_address) +		attr->sample_type	|= PERF_SAMPLE_DATA_SRC; +  	if (opts->no_delay) {  		attr->watermark = 0;  		attr->wakeup_events = 1; @@ -563,6 +566,9 @@ void perf_evsel__config(struct perf_evsel *evsel,  		attr->branch_sample_type = opts->branch_stack;  	} +	if (opts->sample_weight) +		attr->sample_type	|= PERF_SAMPLE_WEIGHT; +  	attr->mmap = track;  	attr->comm = track; @@ -633,6 +639,12 @@ int perf_evsel__alloc_id(struct perf_evsel *evsel, int ncpus, int nthreads)  	return 0;  } +void perf_evsel__reset_counts(struct perf_evsel *evsel, int ncpus) +{ +	memset(evsel->counts, 0, (sizeof(*evsel->counts) + +				 (ncpus * sizeof(struct perf_counts_values)))); +} +  int perf_evsel__alloc_counts(struct perf_evsel *evsel, int ncpus)  {  	evsel->counts = zalloc((sizeof(*evsel->counts) + @@ -673,9 +685,8 @@ void perf_evsel__free_counts(struct perf_evsel *evsel)  void perf_evsel__exit(struct perf_evsel *evsel)  {  	assert(list_empty(&evsel->node)); -	xyarray__delete(evsel->fd); -	xyarray__delete(evsel->sample_id); -	free(evsel->id); +	perf_evsel__free_fd(evsel); +	perf_evsel__free_id(evsel);  }  void perf_evsel__delete(struct perf_evsel *evsel) @@ -1012,6 +1023,7 @@ int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event,  	data->cpu = data->pid = data->tid = -1;  	data->stream_id = data->id = data->time = -1ULL;  	data->period = 1; +	data->weight = 0;  	if (event->header.type != PERF_RECORD_SAMPLE) {  		if (!evsel->attr.sample_id_all) @@ -1162,6 +1174,18 @@ int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event,  		}  	} +	data->weight = 0; +	if (type & PERF_SAMPLE_WEIGHT) { +		data->weight = *array; +		array++; +	} + +	data->data_src = PERF_MEM_DATA_SRC_NONE; +	if (type & PERF_SAMPLE_DATA_SRC) { +		data->data_src = *array; +		array++; +	} +  	return 0;  } |