aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorMark Rutland <mark.rutland@arm.com>2016-07-15 06:08:11 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2016-07-18 18:42:47 -0400
commit9a6c582d57a0fc37fa4e13a69d9129fb3d98a401 (patch)
treea2dc1be66870ab9ed15a8265eac5e8ea744a4df3 /tools
parent00e727bb389359c81101b03d34fec8cc7be5168d (diff)
perf cpu_map: Add more helpers
In some cases it's necessry to figure out the map-local index of a given Linux logical CPU ID. Add a new helper, cpu_map__idx, to acquire this. As the logic is largely the same as the existing cpu_map__has, this is rewritten in terms of the new helper. At the same time, add the inverse operation, cpu_map__cpu, which yields the logical CPU id for a map-local index. While this can be performed manually, wrapping this in a helper can make code more legible. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Acked-by: Jiri Olsa <jolsa@kernel.org> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: He Kuang <hekuang@huawei.com> Cc: Kan Liang <kan.liang@intel.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Wang Nan <wangnan0@huawei.com> Link: http://lkml.kernel.org/r/1468577293-19667-3-git-send-email-mark.rutland@arm.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/util/cpumap.c14
-rw-r--r--tools/perf/util/cpumap.h2
2 files changed, 14 insertions, 2 deletions
diff --git a/tools/perf/util/cpumap.c b/tools/perf/util/cpumap.c
index 15f83acac1b8..2c0b52264a46 100644
--- a/tools/perf/util/cpumap.c
+++ b/tools/perf/util/cpumap.c
@@ -589,14 +589,24 @@ int cpu__setup_cpunode_map(void)
589 589
590bool cpu_map__has(struct cpu_map *cpus, int cpu) 590bool cpu_map__has(struct cpu_map *cpus, int cpu)
591{ 591{
592 return cpu_map__idx(cpus, cpu) != -1;
593}
594
595int cpu_map__idx(struct cpu_map *cpus, int cpu)
596{
592 int i; 597 int i;
593 598
594 for (i = 0; i < cpus->nr; ++i) { 599 for (i = 0; i < cpus->nr; ++i) {
595 if (cpus->map[i] == cpu) 600 if (cpus->map[i] == cpu)
596 return true; 601 return i;
597 } 602 }
598 603
599 return false; 604 return -1;
605}
606
607int cpu_map__cpu(struct cpu_map *cpus, int idx)
608{
609 return cpus->map[idx];
600} 610}
601 611
602size_t cpu_map__snprint(struct cpu_map *map, char *buf, size_t size) 612size_t cpu_map__snprint(struct cpu_map *map, char *buf, size_t size)
diff --git a/tools/perf/util/cpumap.h b/tools/perf/util/cpumap.h
index 206dc550354a..06bd689f5989 100644
--- a/tools/perf/util/cpumap.h
+++ b/tools/perf/util/cpumap.h
@@ -68,5 +68,7 @@ int cpu_map__build_map(struct cpu_map *cpus, struct cpu_map **res,
68 int (*f)(struct cpu_map *map, int cpu, void *data), 68 int (*f)(struct cpu_map *map, int cpu, void *data),
69 void *data); 69 void *data);
70 70
71int cpu_map__cpu(struct cpu_map *cpus, int idx);
71bool cpu_map__has(struct cpu_map *cpus, int cpu); 72bool cpu_map__has(struct cpu_map *cpus, int cpu);
73int cpu_map__idx(struct cpu_map *cpus, int cpu);
72#endif /* __PERF_CPUMAP_H */ 74#endif /* __PERF_CPUMAP_H */