diff options
author | Paul Mackerras <paulus@samba.org> | 2009-03-30 19:07:07 +0200 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-04-06 09:30:39 +0200 |
commit | 7595d63b3a9ce65d14c4fbd0e7de448a343d7215 (patch) | |
tree | 09d9c4defe8805fc3c5cd645c045f6bdab90f748 /kernel/.gitignore | |
parent | 3c1ba6fafecaed295017881f8863a18602f32c1d (diff) | |
download | op-kernel-dev-7595d63b3a9ce65d14c4fbd0e7de448a343d7215.zip op-kernel-dev-7595d63b3a9ce65d14c4fbd0e7de448a343d7215.tar.gz |
perf_counter: powerpc: only reserve PMU hardware when we need it
Impact: cooperate with oprofile
At present, on PowerPC, if you have perf_counters compiled in, oprofile
doesn't work. There is code to allow the PMU to be shared between
competing subsystems, such as perf_counters and oprofile, but currently
the perf_counter subsystem reserves the PMU for itself at boot time,
and never releases it.
This makes perf_counter play nicely with oprofile. Now we keep a count
of how many perf_counter instances are counting hardware events, and
reserve the PMU when that count becomes non-zero, and release the PMU
when that count becomes zero. This means that it is possible to have
perf_counters compiled in and still use oprofile, as long as there are
no hardware perf_counters active. This also means that if oprofile is
active, sys_perf_counter_open will fail if the hw_event specifies a
hardware event.
To avoid races with other tasks creating and destroying perf_counters,
we use a mutex. We use atomic_inc_not_zero and atomic_add_unless to
avoid having to take the mutex unless there is a possibility of the
count going between 0 and 1.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Orig-LKML-Reference: <20090330171023.627912475@chello.nl>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/.gitignore')
0 files changed, 0 insertions, 0 deletions