diff options
author | Paul Mackerras <paulus@samba.org> | 2009-06-17 07:51:13 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-06-18 05:11:45 -0400 |
commit | 448d64f8f4c147db466c549550767cc515a4d34c (patch) | |
tree | 9c33191273219d8e4d77e3ea78304691e4fb4b56 /arch/powerpc/kernel/power7-pmu.c | |
parent | 105988c015943e77092a6568bc5fb7e386df6ccd (diff) |
perf_counter: powerpc: Use unsigned long for register and constraint values
This changes the powerpc perf_counter back-end to use unsigned long
types for hardware register values and for the value/mask pairs used
in checking whether a given set of events fit within the hardware
constraints. This is in preparation for adding support for the PMU
on some 32-bit powerpc processors. On 32-bit processors the hardware
registers are only 32 bits wide, and the PMU structure is generally
simpler, so 32 bits should be ample for expressing the hardware
constraints. On 64-bit processors, unsigned long is 64 bits wide,
so using unsigned long vs. u64 (unsigned long long) makes no actual
difference.
This makes some other very minor changes: adjusting whitespace to line
things up in initialized structures, and simplifying some code in
hw_perf_disable().
Signed-off-by: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: linuxppc-dev@ozlabs.org
Cc: benh@kernel.crashing.org
LKML-Reference: <19000.55473.26174.331511@cargo.ozlabs.ibm.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/powerpc/kernel/power7-pmu.c')
-rw-r--r-- | arch/powerpc/kernel/power7-pmu.c | 46 |
1 files changed, 25 insertions, 21 deletions
diff --git a/arch/powerpc/kernel/power7-pmu.c b/arch/powerpc/kernel/power7-pmu.c index b72e7a19d054..658d1ae436a0 100644 --- a/arch/powerpc/kernel/power7-pmu.c +++ b/arch/powerpc/kernel/power7-pmu.c | |||
@@ -71,10 +71,11 @@ | |||
71 | * 0-9: Count of events needing PMC1..PMC5 | 71 | * 0-9: Count of events needing PMC1..PMC5 |
72 | */ | 72 | */ |
73 | 73 | ||
74 | static int power7_get_constraint(u64 event, u64 *maskp, u64 *valp) | 74 | static int power7_get_constraint(u64 event, unsigned long *maskp, |
75 | unsigned long *valp) | ||
75 | { | 76 | { |
76 | int pmc, sh; | 77 | int pmc, sh; |
77 | u64 mask = 0, value = 0; | 78 | unsigned long mask = 0, value = 0; |
78 | 79 | ||
79 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 80 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
80 | if (pmc) { | 81 | if (pmc) { |
@@ -224,10 +225,10 @@ static int power7_marked_instr_event(u64 event) | |||
224 | } | 225 | } |
225 | 226 | ||
226 | static int power7_compute_mmcr(u64 event[], int n_ev, | 227 | static int power7_compute_mmcr(u64 event[], int n_ev, |
227 | unsigned int hwc[], u64 mmcr[]) | 228 | unsigned int hwc[], unsigned long mmcr[]) |
228 | { | 229 | { |
229 | u64 mmcr1 = 0; | 230 | unsigned long mmcr1 = 0; |
230 | u64 mmcra = 0; | 231 | unsigned long mmcra = 0; |
231 | unsigned int pmc, unit, combine, l2sel, psel; | 232 | unsigned int pmc, unit, combine, l2sel, psel; |
232 | unsigned int pmc_inuse = 0; | 233 | unsigned int pmc_inuse = 0; |
233 | int i; | 234 | int i; |
@@ -265,11 +266,14 @@ static int power7_compute_mmcr(u64 event[], int n_ev, | |||
265 | --pmc; | 266 | --pmc; |
266 | } | 267 | } |
267 | if (pmc <= 3) { | 268 | if (pmc <= 3) { |
268 | mmcr1 |= (u64) unit << (MMCR1_TTM0SEL_SH - 4 * pmc); | 269 | mmcr1 |= (unsigned long) unit |
269 | mmcr1 |= (u64) combine << (MMCR1_PMC1_COMBINE_SH - pmc); | 270 | << (MMCR1_TTM0SEL_SH - 4 * pmc); |
271 | mmcr1 |= (unsigned long) combine | ||
272 | << (MMCR1_PMC1_COMBINE_SH - pmc); | ||
270 | mmcr1 |= psel << MMCR1_PMCSEL_SH(pmc); | 273 | mmcr1 |= psel << MMCR1_PMCSEL_SH(pmc); |
271 | if (unit == 6) /* L2 events */ | 274 | if (unit == 6) /* L2 events */ |
272 | mmcr1 |= (u64) l2sel << MMCR1_L2SEL_SH; | 275 | mmcr1 |= (unsigned long) l2sel |
276 | << MMCR1_L2SEL_SH; | ||
273 | } | 277 | } |
274 | if (power7_marked_instr_event(event[i])) | 278 | if (power7_marked_instr_event(event[i])) |
275 | mmcra |= MMCRA_SAMPLE_ENABLE; | 279 | mmcra |= MMCRA_SAMPLE_ENABLE; |
@@ -287,10 +291,10 @@ static int power7_compute_mmcr(u64 event[], int n_ev, | |||
287 | return 0; | 291 | return 0; |
288 | } | 292 | } |
289 | 293 | ||
290 | static void power7_disable_pmc(unsigned int pmc, u64 mmcr[]) | 294 | static void power7_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
291 | { | 295 | { |
292 | if (pmc <= 3) | 296 | if (pmc <= 3) |
293 | mmcr[1] &= ~(0xffULL << MMCR1_PMCSEL_SH(pmc)); | 297 | mmcr[1] &= ~(0xffUL << MMCR1_PMCSEL_SH(pmc)); |
294 | } | 298 | } |
295 | 299 | ||
296 | static int power7_generic_events[] = { | 300 | static int power7_generic_events[] = { |
@@ -343,15 +347,15 @@ static int power7_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
343 | }; | 347 | }; |
344 | 348 | ||
345 | struct power_pmu power7_pmu = { | 349 | struct power_pmu power7_pmu = { |
346 | .n_counter = 6, | 350 | .n_counter = 6, |
347 | .max_alternatives = MAX_ALT + 1, | 351 | .max_alternatives = MAX_ALT + 1, |
348 | .add_fields = 0x1555ull, | 352 | .add_fields = 0x1555ul, |
349 | .test_adder = 0x3000ull, | 353 | .test_adder = 0x3000ul, |
350 | .compute_mmcr = power7_compute_mmcr, | 354 | .compute_mmcr = power7_compute_mmcr, |
351 | .get_constraint = power7_get_constraint, | 355 | .get_constraint = power7_get_constraint, |
352 | .get_alternatives = power7_get_alternatives, | 356 | .get_alternatives = power7_get_alternatives, |
353 | .disable_pmc = power7_disable_pmc, | 357 | .disable_pmc = power7_disable_pmc, |
354 | .n_generic = ARRAY_SIZE(power7_generic_events), | 358 | .n_generic = ARRAY_SIZE(power7_generic_events), |
355 | .generic_events = power7_generic_events, | 359 | .generic_events = power7_generic_events, |
356 | .cache_events = &power7_cache_events, | 360 | .cache_events = &power7_cache_events, |
357 | }; | 361 | }; |