[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20181003212848.412256-1-songliubraving@fb.com>
Date: Wed, 3 Oct 2018 14:28:46 -0700
From: Song Liu <songliubraving@...com>
To: <linux-kernel@...r.kernel.org>
CC: <kernel-team@...com>, <ravi.bangoria@...ux.ibm.com>,
<naveen.n.rao@...ux.vnet.ibm.com>, <maddy@...ux.vnet.ibm.com>,
Song Liu <songliubraving@...com>, Tejun Heo <tj@...nel.org>,
Peter Zijlstra <peterz@...radead.org>,
Jiri Olsa <jolsa@...nel.org>
Subject: [PATCH/RFC v4 0/2] perf: Sharing PMU counters across compatible events
Changes v3 -> v4:
1. In __perf_install_in_context() always reprogram ctx for cpu and cgroup
events to make sure event duplications set up properly.
2. Add a prototype (2/2) to show potential solution of sharing PMU among
CPU events and task events.
Changes v2 -> v3:
1. Simplified event_pmu_add() as Jiri Olsa suggested
Changes v1 -> v2:
1. Fixed a bug reported by 0day kernel testing robot
This is to follow up earlier discussion on sharing hardware PMU counters
across compatible events:
https://marc.info/?t=151213803600016
https://marc.info/?t=152547569200001
This version limits PMU sharing to events within same ctx. As a result,
compatible events are not evaluated during task schedule. This vesion also
limits PMU sharing to hardware counting events. From our discussion with
internal users, this is sufficient for most cases.
This version introduces virtual master event. The virtual master event
does require careful handling. But it is makes the logic of event add/del
cleaner.
Cc: Tejun Heo <tj@...nel.org>
Cc: Peter Zijlstra <peterz@...radead.org>
Cc: Jiri Olsa <jolsa@...nel.org>
Song Liu (2):
perf: Sharing PMU counters across compatible events
perf tools: monitoring per task counter with per cgroup event
include/linux/perf_event.h | 61 ++++++++
kernel/events/core.c | 294 ++++++++++++++++++++++++++++++++++---
tools/perf/builtin-stat.c | 26 ++++
tools/perf/util/cgroup.c | 76 ++++++++++
tools/perf/util/cgroup.h | 5 +
tools/perf/util/target.h | 1 +
6 files changed, 440 insertions(+), 23 deletions(-)
--
2.17.1
Powered by blists - more mailing lists