diff options
author | Paul Mackerras <paulus@samba.org> | 2009-05-13 23:29:14 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-05-15 10:38:55 -0400 |
commit | ef923214a4816c289e4af2d67a9ebb1a31e4ac61 (patch) | |
tree | bf850f4f53a4f8391b6b9c0335e58364668586d9 /arch/powerpc/kernel/ppc970-pmu.c | |
parent | 2e569d36729c8105ae066a9b105068305442cc77 (diff) |
perf_counter: powerpc: use u64 for event codes internally
Although the perf_counter API allows 63-bit raw event codes,
internally in the powerpc back-end we had been using 32-bit
event codes. This expands them to 64 bits so that we can add
bits for specifying threshold start/stop events and instruction
sampling modes later.
This also corrects the return value of can_go_on_limited_pmc;
we were returning an event code rather than just a 0/1 value in
some circumstances. That didn't particularly matter while event
codes were 32-bit, but now that event codes are 64-bit it
might, so this fixes it.
[ Impact: extend PowerPC perfcounter interfaces from u32 to u64 ]
Signed-off-by: Paul Mackerras <paulus@samba.org>
Acked-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
LKML-Reference: <18955.36874.472452.353104@drongo.ozlabs.ibm.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/powerpc/kernel/ppc970-pmu.c')
-rw-r--r-- | arch/powerpc/kernel/ppc970-pmu.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/arch/powerpc/kernel/ppc970-pmu.c b/arch/powerpc/kernel/ppc970-pmu.c index af2d1884058c..eed47c4523f1 100644 --- a/arch/powerpc/kernel/ppc970-pmu.c +++ b/arch/powerpc/kernel/ppc970-pmu.c | |||
@@ -147,7 +147,7 @@ static unsigned char direct_marked_event[8] = { | |||
147 | * Returns 1 if event counts things relating to marked instructions | 147 | * Returns 1 if event counts things relating to marked instructions |
148 | * and thus needs the MMCRA_SAMPLE_ENABLE bit set, or 0 if not. | 148 | * and thus needs the MMCRA_SAMPLE_ENABLE bit set, or 0 if not. |
149 | */ | 149 | */ |
150 | static int p970_marked_instr_event(unsigned int event) | 150 | static int p970_marked_instr_event(u64 event) |
151 | { | 151 | { |
152 | int pmc, psel, unit, byte, bit; | 152 | int pmc, psel, unit, byte, bit; |
153 | unsigned int mask; | 153 | unsigned int mask; |
@@ -192,7 +192,7 @@ static u64 unit_cons[PM_LASTUNIT+1][2] = { | |||
192 | [PM_STS] = { 0x380000000000ull, 0x310000000000ull }, | 192 | [PM_STS] = { 0x380000000000ull, 0x310000000000ull }, |
193 | }; | 193 | }; |
194 | 194 | ||
195 | static int p970_get_constraint(unsigned int event, u64 *maskp, u64 *valp) | 195 | static int p970_get_constraint(u64 event, u64 *maskp, u64 *valp) |
196 | { | 196 | { |
197 | int pmc, byte, unit, sh, spcsel; | 197 | int pmc, byte, unit, sh, spcsel; |
198 | u64 mask = 0, value = 0; | 198 | u64 mask = 0, value = 0; |
@@ -243,8 +243,7 @@ static int p970_get_constraint(unsigned int event, u64 *maskp, u64 *valp) | |||
243 | return 0; | 243 | return 0; |
244 | } | 244 | } |
245 | 245 | ||
246 | static int p970_get_alternatives(unsigned int event, unsigned int flags, | 246 | static int p970_get_alternatives(u64 event, unsigned int flags, u64 alt[]) |
247 | unsigned int alt[]) | ||
248 | { | 247 | { |
249 | alt[0] = event; | 248 | alt[0] = event; |
250 | 249 | ||
@@ -257,7 +256,7 @@ static int p970_get_alternatives(unsigned int event, unsigned int flags, | |||
257 | return 1; | 256 | return 1; |
258 | } | 257 | } |
259 | 258 | ||
260 | static int p970_compute_mmcr(unsigned int event[], int n_ev, | 259 | static int p970_compute_mmcr(u64 event[], int n_ev, |
261 | unsigned int hwc[], u64 mmcr[]) | 260 | unsigned int hwc[], u64 mmcr[]) |
262 | { | 261 | { |
263 | u64 mmcr0 = 0, mmcr1 = 0, mmcra = 0; | 262 | u64 mmcr0 = 0, mmcr1 = 0, mmcra = 0; |