aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf
diff options
context:
space:
mode:
authorDavid Ahern <dsahern@gmail.com>2012-05-14 00:01:28 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2012-05-18 15:02:42 -0400
commit5e1c81d98a5621007824b49dde556fead5ff9c6c (patch)
tree36e60a5c25742cde78293d069e9ede5fa1042a4c /tools/perf
parent16ee6576e25b83806d26eb771138249fcfb5eddc (diff)
perf evsel: Create events initially disabled -- again
764e16a changed perf-record to create events disabled by default and enable them once perf initializations are done. This setting was dropped by 0f82ebc. Now perf events are once again generated during perf's initialization phase (e.g., generating maps). As an example, perf opens a lot of files at startup. Unpatched: perf record -e syscalls:sys_enter_open -ga -fo /tmp/perf.data -- sleep 1 [ perf record: Woken up 1 times to write data ] [ perf record: Captured and wrote 0.087 MB /tmp/perf.data (~3798 samples) ] Using perf-script to look at the samples shows the perf command generating 563 of the 566 total events. Patched: perf record -e syscalls:sys_enter_open -ga -fo /tmp/perf.data -- sleep 1 [ perf record: Woken up 1 times to write data ] [ perf record: Captured and wrote 0.028 MB /tmp/perf.data (~1206 samples) ] Using perf-script to look at the samples does not show perf command. Signed-off-by: David Ahern <dsahern@gmail.com> Link: http://lkml.kernel.org/r/1336968088-11531-1-git-send-email-dsahern@gmail.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf')
-rw-r--r--tools/perf/util/evsel.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c
index d7a2b4b9801d..f4f427ce4d64 100644
--- a/tools/perf/util/evsel.c
+++ b/tools/perf/util/evsel.c
@@ -70,6 +70,7 @@ void perf_evsel__config(struct perf_evsel *evsel, struct perf_record_opts *opts,
70 struct perf_event_attr *attr = &evsel->attr; 70 struct perf_event_attr *attr = &evsel->attr;
71 int track = !evsel->idx; /* only the first counter needs these */ 71 int track = !evsel->idx; /* only the first counter needs these */
72 72
73 attr->disabled = 1;
73 attr->sample_id_all = opts->sample_id_all_missing ? 0 : 1; 74 attr->sample_id_all = opts->sample_id_all_missing ? 0 : 1;
74 attr->inherit = !opts->no_inherit; 75 attr->inherit = !opts->no_inherit;
75 attr->read_format = PERF_FORMAT_TOTAL_TIME_ENABLED | 76 attr->read_format = PERF_FORMAT_TOTAL_TIME_ENABLED |
@@ -138,7 +139,6 @@ void perf_evsel__config(struct perf_evsel *evsel, struct perf_record_opts *opts,
138 139
139 if (perf_target__none(&opts->target) && 140 if (perf_target__none(&opts->target) &&
140 (!opts->group || evsel == first)) { 141 (!opts->group || evsel == first)) {
141 attr->disabled = 1;
142 attr->enable_on_exec = 1; 142 attr->enable_on_exec = 1;
143 } 143 }
144} 144}