diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-10-10 14:55:15 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2014-10-14 16:32:53 -0400 |
commit | 4112eb1899c0e711b2ab1491f51215359cf94d74 (patch) | |
tree | 652b1c4f26dd1238daa911d9ee331e68fd13da28 | |
parent | 1aaf63b1ee912abd7675681f9d6ffaaf2ffc0451 (diff) |
perf evlist: Default to syswide target when no thread/cpu maps set
If all a tool wants is to do system wide event monitoring, there is no
more the need to setup thread_map and cpu_map objects, just call
perf_evlist__open() and it will do create one fd per CPU monitoring all
threads.
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Borislav Petkov <bp@suse.de>
Cc: David Ahern <dsahern@gmail.com>
Cc: Don Zickus <dzickus@redhat.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jean Pihet <jean.pihet@linaro.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-poovolkigu72brx4783uq4cf@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
-rw-r--r-- | tools/perf/util/evlist.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/tools/perf/util/evlist.c b/tools/perf/util/evlist.c index 5fc7bd42c803..b4b54d84e9b0 100644 --- a/tools/perf/util/evlist.c +++ b/tools/perf/util/evlist.c | |||
@@ -1175,11 +1175,51 @@ void perf_evlist__close(struct perf_evlist *evlist) | |||
1175 | } | 1175 | } |
1176 | } | 1176 | } |
1177 | 1177 | ||
1178 | static int perf_evlist__create_syswide_maps(struct perf_evlist *evlist) | ||
1179 | { | ||
1180 | int err = -ENOMEM; | ||
1181 | |||
1182 | /* | ||
1183 | * Try reading /sys/devices/system/cpu/online to get | ||
1184 | * an all cpus map. | ||
1185 | * | ||
1186 | * FIXME: -ENOMEM is the best we can do here, the cpu_map | ||
1187 | * code needs an overhaul to properly forward the | ||
1188 | * error, and we may not want to do that fallback to a | ||
1189 | * default cpu identity map :-\ | ||
1190 | */ | ||
1191 | evlist->cpus = cpu_map__new(NULL); | ||
1192 | if (evlist->cpus == NULL) | ||
1193 | goto out; | ||
1194 | |||
1195 | evlist->threads = thread_map__new_dummy(); | ||
1196 | if (evlist->threads == NULL) | ||
1197 | goto out_free_cpus; | ||
1198 | |||
1199 | err = 0; | ||
1200 | out: | ||
1201 | return err; | ||
1202 | out_free_cpus: | ||
1203 | cpu_map__delete(evlist->cpus); | ||
1204 | evlist->cpus = NULL; | ||
1205 | goto out; | ||
1206 | } | ||
1207 | |||
1178 | int perf_evlist__open(struct perf_evlist *evlist) | 1208 | int perf_evlist__open(struct perf_evlist *evlist) |
1179 | { | 1209 | { |
1180 | struct perf_evsel *evsel; | 1210 | struct perf_evsel *evsel; |
1181 | int err; | 1211 | int err; |
1182 | 1212 | ||
1213 | /* | ||
1214 | * Default: one fd per CPU, all threads, aka systemwide | ||
1215 | * as sys_perf_event_open(cpu = -1, thread = -1) is EINVAL | ||
1216 | */ | ||
1217 | if (evlist->threads == NULL && evlist->cpus == NULL) { | ||
1218 | err = perf_evlist__create_syswide_maps(evlist); | ||
1219 | if (err < 0) | ||
1220 | goto out_err; | ||
1221 | } | ||
1222 | |||
1183 | perf_evlist__update_id_pos(evlist); | 1223 | perf_evlist__update_id_pos(evlist); |
1184 | 1224 | ||
1185 | evlist__for_each(evlist, evsel) { | 1225 | evlist__for_each(evlist, evsel) { |