summaryrefslogtreecommitdiffstats
path: root/kernel/.gitignore
diff options
context:
space:
mode:
authorPaul Mackerras <paulus@samba.org>2009-03-30 19:07:07 +0200
committerIngo Molnar <mingo@elte.hu>2009-04-06 09:30:39 +0200
commit7595d63b3a9ce65d14c4fbd0e7de448a343d7215 (patch)
tree09d9c4defe8805fc3c5cd645c045f6bdab90f748 /kernel/.gitignore
parent3c1ba6fafecaed295017881f8863a18602f32c1d (diff)
downloadop-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
OpenPOWER on IntegriCloud