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 | |
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>
-rw-r--r-- | arch/powerpc/include/asm/perf_counter.h | 35 | ||||
-rw-r--r-- | arch/powerpc/kernel/perf_counter.c | 20 | ||||
-rw-r--r-- | arch/powerpc/kernel/power4-pmu.c | 74 | ||||
-rw-r--r-- | arch/powerpc/kernel/power5+-pmu.c | 79 | ||||
-rw-r--r-- | arch/powerpc/kernel/power5-pmu.c | 83 | ||||
-rw-r--r-- | arch/powerpc/kernel/power6-pmu.c | 57 | ||||
-rw-r--r-- | arch/powerpc/kernel/power7-pmu.c | 46 | ||||
-rw-r--r-- | arch/powerpc/kernel/ppc970-pmu.c | 47 |
8 files changed, 229 insertions, 212 deletions
diff --git a/arch/powerpc/include/asm/perf_counter.h b/arch/powerpc/include/asm/perf_counter.h index 2c2d9f643df0..2ceb0fefa93a 100644 --- a/arch/powerpc/include/asm/perf_counter.h +++ b/arch/powerpc/include/asm/perf_counter.h | |||
@@ -21,21 +21,22 @@ | |||
21 | * describe the PMU on a particular POWER-family CPU. | 21 | * describe the PMU on a particular POWER-family CPU. |
22 | */ | 22 | */ |
23 | struct power_pmu { | 23 | struct power_pmu { |
24 | int n_counter; | 24 | int n_counter; |
25 | int max_alternatives; | 25 | int max_alternatives; |
26 | u64 add_fields; | 26 | unsigned long add_fields; |
27 | u64 test_adder; | 27 | unsigned long test_adder; |
28 | int (*compute_mmcr)(u64 events[], int n_ev, | 28 | int (*compute_mmcr)(u64 events[], int n_ev, |
29 | unsigned int hwc[], u64 mmcr[]); | 29 | unsigned int hwc[], unsigned long mmcr[]); |
30 | int (*get_constraint)(u64 event, u64 *mskp, u64 *valp); | 30 | int (*get_constraint)(u64 event, unsigned long *mskp, |
31 | int (*get_alternatives)(u64 event, unsigned int flags, | 31 | unsigned long *valp); |
32 | u64 alt[]); | 32 | int (*get_alternatives)(u64 event, unsigned int flags, |
33 | void (*disable_pmc)(unsigned int pmc, u64 mmcr[]); | 33 | u64 alt[]); |
34 | int (*limited_pmc_event)(u64 event); | 34 | void (*disable_pmc)(unsigned int pmc, unsigned long mmcr[]); |
35 | u32 flags; | 35 | int (*limited_pmc_event)(u64 event); |
36 | int n_generic; | 36 | u32 flags; |
37 | int *generic_events; | 37 | int n_generic; |
38 | int (*cache_events)[PERF_COUNT_HW_CACHE_MAX] | 38 | int *generic_events; |
39 | int (*cache_events)[PERF_COUNT_HW_CACHE_MAX] | ||
39 | [PERF_COUNT_HW_CACHE_OP_MAX] | 40 | [PERF_COUNT_HW_CACHE_OP_MAX] |
40 | [PERF_COUNT_HW_CACHE_RESULT_MAX]; | 41 | [PERF_COUNT_HW_CACHE_RESULT_MAX]; |
41 | }; | 42 | }; |
@@ -68,8 +69,8 @@ extern unsigned long perf_instruction_pointer(struct pt_regs *regs); | |||
68 | #endif | 69 | #endif |
69 | 70 | ||
70 | /* | 71 | /* |
71 | * The power_pmu.get_constraint function returns a 64-bit value and | 72 | * The power_pmu.get_constraint function returns a 32/64-bit value and |
72 | * a 64-bit mask that express the constraints between this event and | 73 | * a 32/64-bit mask that express the constraints between this event and |
73 | * other events. | 74 | * other events. |
74 | * | 75 | * |
75 | * The value and mask are divided up into (non-overlapping) bitfields | 76 | * The value and mask are divided up into (non-overlapping) bitfields |
diff --git a/arch/powerpc/kernel/perf_counter.c b/arch/powerpc/kernel/perf_counter.c index e6dc1850191c..9300638b8c26 100644 --- a/arch/powerpc/kernel/perf_counter.c +++ b/arch/powerpc/kernel/perf_counter.c | |||
@@ -29,7 +29,7 @@ struct cpu_hw_counters { | |||
29 | struct perf_counter *counter[MAX_HWCOUNTERS]; | 29 | struct perf_counter *counter[MAX_HWCOUNTERS]; |
30 | u64 events[MAX_HWCOUNTERS]; | 30 | u64 events[MAX_HWCOUNTERS]; |
31 | unsigned int flags[MAX_HWCOUNTERS]; | 31 | unsigned int flags[MAX_HWCOUNTERS]; |
32 | u64 mmcr[3]; | 32 | unsigned long mmcr[3]; |
33 | struct perf_counter *limited_counter[MAX_LIMITED_HWCOUNTERS]; | 33 | struct perf_counter *limited_counter[MAX_LIMITED_HWCOUNTERS]; |
34 | u8 limited_hwidx[MAX_LIMITED_HWCOUNTERS]; | 34 | u8 limited_hwidx[MAX_LIMITED_HWCOUNTERS]; |
35 | }; | 35 | }; |
@@ -135,15 +135,15 @@ static void write_pmc(int idx, unsigned long val) | |||
135 | static int power_check_constraints(u64 event[], unsigned int cflags[], | 135 | static int power_check_constraints(u64 event[], unsigned int cflags[], |
136 | int n_ev) | 136 | int n_ev) |
137 | { | 137 | { |
138 | u64 mask, value, nv; | 138 | unsigned long mask, value, nv; |
139 | u64 alternatives[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; | 139 | u64 alternatives[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; |
140 | u64 amasks[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; | 140 | unsigned long amasks[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; |
141 | u64 avalues[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; | 141 | unsigned long avalues[MAX_HWCOUNTERS][MAX_EVENT_ALTERNATIVES]; |
142 | u64 smasks[MAX_HWCOUNTERS], svalues[MAX_HWCOUNTERS]; | 142 | unsigned long smasks[MAX_HWCOUNTERS], svalues[MAX_HWCOUNTERS]; |
143 | int n_alt[MAX_HWCOUNTERS], choice[MAX_HWCOUNTERS]; | 143 | int n_alt[MAX_HWCOUNTERS], choice[MAX_HWCOUNTERS]; |
144 | int i, j; | 144 | int i, j; |
145 | u64 addf = ppmu->add_fields; | 145 | unsigned long addf = ppmu->add_fields; |
146 | u64 tadd = ppmu->test_adder; | 146 | unsigned long tadd = ppmu->test_adder; |
147 | 147 | ||
148 | if (n_ev > ppmu->n_counter) | 148 | if (n_ev > ppmu->n_counter) |
149 | return -1; | 149 | return -1; |
@@ -403,14 +403,12 @@ static void write_mmcr0(struct cpu_hw_counters *cpuhw, unsigned long mmcr0) | |||
403 | void hw_perf_disable(void) | 403 | void hw_perf_disable(void) |
404 | { | 404 | { |
405 | struct cpu_hw_counters *cpuhw; | 405 | struct cpu_hw_counters *cpuhw; |
406 | unsigned long ret; | ||
407 | unsigned long flags; | 406 | unsigned long flags; |
408 | 407 | ||
409 | local_irq_save(flags); | 408 | local_irq_save(flags); |
410 | cpuhw = &__get_cpu_var(cpu_hw_counters); | 409 | cpuhw = &__get_cpu_var(cpu_hw_counters); |
411 | 410 | ||
412 | ret = cpuhw->disabled; | 411 | if (!cpuhw->disabled) { |
413 | if (!ret) { | ||
414 | cpuhw->disabled = 1; | 412 | cpuhw->disabled = 1; |
415 | cpuhw->n_added = 0; | 413 | cpuhw->n_added = 0; |
416 | 414 | ||
@@ -1013,9 +1011,9 @@ static void record_and_restart(struct perf_counter *counter, long val, | |||
1013 | struct pt_regs *regs, int nmi) | 1011 | struct pt_regs *regs, int nmi) |
1014 | { | 1012 | { |
1015 | u64 period = counter->hw.sample_period; | 1013 | u64 period = counter->hw.sample_period; |
1014 | unsigned long mmcra, sdsync; | ||
1016 | s64 prev, delta, left; | 1015 | s64 prev, delta, left; |
1017 | int record = 0; | 1016 | int record = 0; |
1018 | u64 mmcra, sdsync; | ||
1019 | 1017 | ||
1020 | /* we don't have to worry about interrupts here */ | 1018 | /* we don't have to worry about interrupts here */ |
1021 | prev = atomic64_read(&counter->hw.prev_count); | 1019 | prev = atomic64_read(&counter->hw.prev_count); |
diff --git a/arch/powerpc/kernel/power4-pmu.c b/arch/powerpc/kernel/power4-pmu.c index 07bd308a5fa7..81a1708f83b2 100644 --- a/arch/powerpc/kernel/power4-pmu.c +++ b/arch/powerpc/kernel/power4-pmu.c | |||
@@ -179,22 +179,22 @@ static short mmcr1_adder_bits[8] = { | |||
179 | */ | 179 | */ |
180 | 180 | ||
181 | static struct unitinfo { | 181 | static struct unitinfo { |
182 | u64 value, mask; | 182 | unsigned long value, mask; |
183 | int unit; | 183 | int unit; |
184 | int lowerbit; | 184 | int lowerbit; |
185 | } p4_unitinfo[16] = { | 185 | } p4_unitinfo[16] = { |
186 | [PM_FPU] = { 0x44000000000000ull, 0x88000000000000ull, PM_FPU, 0 }, | 186 | [PM_FPU] = { 0x44000000000000ul, 0x88000000000000ul, PM_FPU, 0 }, |
187 | [PM_ISU1] = { 0x20080000000000ull, 0x88000000000000ull, PM_ISU1, 0 }, | 187 | [PM_ISU1] = { 0x20080000000000ul, 0x88000000000000ul, PM_ISU1, 0 }, |
188 | [PM_ISU1_ALT] = | 188 | [PM_ISU1_ALT] = |
189 | { 0x20080000000000ull, 0x88000000000000ull, PM_ISU1, 0 }, | 189 | { 0x20080000000000ul, 0x88000000000000ul, PM_ISU1, 0 }, |
190 | [PM_IFU] = { 0x02200000000000ull, 0x08820000000000ull, PM_IFU, 41 }, | 190 | [PM_IFU] = { 0x02200000000000ul, 0x08820000000000ul, PM_IFU, 41 }, |
191 | [PM_IFU_ALT] = | 191 | [PM_IFU_ALT] = |
192 | { 0x02200000000000ull, 0x08820000000000ull, PM_IFU, 41 }, | 192 | { 0x02200000000000ul, 0x08820000000000ul, PM_IFU, 41 }, |
193 | [PM_IDU0] = { 0x10100000000000ull, 0x80840000000000ull, PM_IDU0, 1 }, | 193 | [PM_IDU0] = { 0x10100000000000ul, 0x80840000000000ul, PM_IDU0, 1 }, |
194 | [PM_ISU2] = { 0x10140000000000ull, 0x80840000000000ull, PM_ISU2, 0 }, | 194 | [PM_ISU2] = { 0x10140000000000ul, 0x80840000000000ul, PM_ISU2, 0 }, |
195 | [PM_LSU0] = { 0x01400000000000ull, 0x08800000000000ull, PM_LSU0, 0 }, | 195 | [PM_LSU0] = { 0x01400000000000ul, 0x08800000000000ul, PM_LSU0, 0 }, |
196 | [PM_LSU1] = { 0x00000000000000ull, 0x00010000000000ull, PM_LSU1, 40 }, | 196 | [PM_LSU1] = { 0x00000000000000ul, 0x00010000000000ul, PM_LSU1, 40 }, |
197 | [PM_GPS] = { 0x00000000000000ull, 0x00000000000000ull, PM_GPS, 0 } | 197 | [PM_GPS] = { 0x00000000000000ul, 0x00000000000000ul, PM_GPS, 0 } |
198 | }; | 198 | }; |
199 | 199 | ||
200 | static unsigned char direct_marked_event[8] = { | 200 | static unsigned char direct_marked_event[8] = { |
@@ -249,10 +249,11 @@ static int p4_marked_instr_event(u64 event) | |||
249 | return (mask >> (byte * 8 + bit)) & 1; | 249 | return (mask >> (byte * 8 + bit)) & 1; |
250 | } | 250 | } |
251 | 251 | ||
252 | static int p4_get_constraint(u64 event, u64 *maskp, u64 *valp) | 252 | static int p4_get_constraint(u64 event, unsigned long *maskp, |
253 | unsigned long *valp) | ||
253 | { | 254 | { |
254 | int pmc, byte, unit, lower, sh; | 255 | int pmc, byte, unit, lower, sh; |
255 | u64 mask = 0, value = 0; | 256 | unsigned long mask = 0, value = 0; |
256 | int grp = -1; | 257 | int grp = -1; |
257 | 258 | ||
258 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 259 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
@@ -282,14 +283,14 @@ static int p4_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
282 | value |= p4_unitinfo[unit].value; | 283 | value |= p4_unitinfo[unit].value; |
283 | sh = p4_unitinfo[unit].lowerbit; | 284 | sh = p4_unitinfo[unit].lowerbit; |
284 | if (sh > 1) | 285 | if (sh > 1) |
285 | value |= (u64)lower << sh; | 286 | value |= (unsigned long)lower << sh; |
286 | else if (lower != sh) | 287 | else if (lower != sh) |
287 | return -1; | 288 | return -1; |
288 | unit = p4_unitinfo[unit].unit; | 289 | unit = p4_unitinfo[unit].unit; |
289 | 290 | ||
290 | /* Set byte lane select field */ | 291 | /* Set byte lane select field */ |
291 | mask |= 0xfULL << (28 - 4 * byte); | 292 | mask |= 0xfULL << (28 - 4 * byte); |
292 | value |= (u64)unit << (28 - 4 * byte); | 293 | value |= (unsigned long)unit << (28 - 4 * byte); |
293 | } | 294 | } |
294 | if (grp == 0) { | 295 | if (grp == 0) { |
295 | /* increment PMC1/2/5/6 field */ | 296 | /* increment PMC1/2/5/6 field */ |
@@ -353,9 +354,9 @@ static int p4_get_alternatives(u64 event, unsigned int flags, u64 alt[]) | |||
353 | } | 354 | } |
354 | 355 | ||
355 | static int p4_compute_mmcr(u64 event[], int n_ev, | 356 | static int p4_compute_mmcr(u64 event[], int n_ev, |
356 | unsigned int hwc[], u64 mmcr[]) | 357 | unsigned int hwc[], unsigned long mmcr[]) |
357 | { | 358 | { |
358 | u64 mmcr0 = 0, mmcr1 = 0, mmcra = 0; | 359 | unsigned long mmcr0 = 0, mmcr1 = 0, mmcra = 0; |
359 | unsigned int pmc, unit, byte, psel, lower; | 360 | unsigned int pmc, unit, byte, psel, lower; |
360 | unsigned int ttm, grp; | 361 | unsigned int ttm, grp; |
361 | unsigned int pmc_inuse = 0; | 362 | unsigned int pmc_inuse = 0; |
@@ -429,9 +430,11 @@ static int p4_compute_mmcr(u64 event[], int n_ev, | |||
429 | return -1; | 430 | return -1; |
430 | 431 | ||
431 | /* Set TTMxSEL fields. Note, units 1-3 => TTM0SEL codes 0-2 */ | 432 | /* Set TTMxSEL fields. Note, units 1-3 => TTM0SEL codes 0-2 */ |
432 | mmcr1 |= (u64)(unituse[3] * 2 + unituse[2]) << MMCR1_TTM0SEL_SH; | 433 | mmcr1 |= (unsigned long)(unituse[3] * 2 + unituse[2]) |
433 | mmcr1 |= (u64)(unituse[7] * 3 + unituse[6] * 2) << MMCR1_TTM1SEL_SH; | 434 | << MMCR1_TTM0SEL_SH; |
434 | mmcr1 |= (u64)unituse[9] << MMCR1_TTM2SEL_SH; | 435 | mmcr1 |= (unsigned long)(unituse[7] * 3 + unituse[6] * 2) |
436 | << MMCR1_TTM1SEL_SH; | ||
437 | mmcr1 |= (unsigned long)unituse[9] << MMCR1_TTM2SEL_SH; | ||
435 | 438 | ||
436 | /* Set TTCxSEL fields. */ | 439 | /* Set TTCxSEL fields. */ |
437 | if (unitlower & 0xe) | 440 | if (unitlower & 0xe) |
@@ -456,7 +459,8 @@ static int p4_compute_mmcr(u64 event[], int n_ev, | |||
456 | ttm = unit - 1; /* 2->1, 3->2 */ | 459 | ttm = unit - 1; /* 2->1, 3->2 */ |
457 | else | 460 | else |
458 | ttm = unit >> 2; | 461 | ttm = unit >> 2; |
459 | mmcr1 |= (u64)ttm << (MMCR1_TD_CP_DBG0SEL_SH - 2*byte); | 462 | mmcr1 |= (unsigned long)ttm |
463 | << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | ||
460 | } | 464 | } |
461 | } | 465 | } |
462 | 466 | ||
@@ -519,7 +523,7 @@ static int p4_compute_mmcr(u64 event[], int n_ev, | |||
519 | return 0; | 523 | return 0; |
520 | } | 524 | } |
521 | 525 | ||
522 | static void p4_disable_pmc(unsigned int pmc, u64 mmcr[]) | 526 | static void p4_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
523 | { | 527 | { |
524 | /* | 528 | /* |
525 | * Setting the PMCxSEL field to 0 disables PMC x. | 529 | * Setting the PMCxSEL field to 0 disables PMC x. |
@@ -584,15 +588,15 @@ static int power4_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
584 | }; | 588 | }; |
585 | 589 | ||
586 | struct power_pmu power4_pmu = { | 590 | struct power_pmu power4_pmu = { |
587 | .n_counter = 8, | 591 | .n_counter = 8, |
588 | .max_alternatives = 5, | 592 | .max_alternatives = 5, |
589 | .add_fields = 0x0000001100005555ull, | 593 | .add_fields = 0x0000001100005555ul, |
590 | .test_adder = 0x0011083300000000ull, | 594 | .test_adder = 0x0011083300000000ul, |
591 | .compute_mmcr = p4_compute_mmcr, | 595 | .compute_mmcr = p4_compute_mmcr, |
592 | .get_constraint = p4_get_constraint, | 596 | .get_constraint = p4_get_constraint, |
593 | .get_alternatives = p4_get_alternatives, | 597 | .get_alternatives = p4_get_alternatives, |
594 | .disable_pmc = p4_disable_pmc, | 598 | .disable_pmc = p4_disable_pmc, |
595 | .n_generic = ARRAY_SIZE(p4_generic_events), | 599 | .n_generic = ARRAY_SIZE(p4_generic_events), |
596 | .generic_events = p4_generic_events, | 600 | .generic_events = p4_generic_events, |
597 | .cache_events = &power4_cache_events, | 601 | .cache_events = &power4_cache_events, |
598 | }; | 602 | }; |
diff --git a/arch/powerpc/kernel/power5+-pmu.c b/arch/powerpc/kernel/power5+-pmu.c index 41e5d2d958d4..aef144d503b0 100644 --- a/arch/powerpc/kernel/power5+-pmu.c +++ b/arch/powerpc/kernel/power5+-pmu.c | |||
@@ -126,20 +126,21 @@ static const int grsel_shift[8] = { | |||
126 | }; | 126 | }; |
127 | 127 | ||
128 | /* Masks and values for using events from the various units */ | 128 | /* Masks and values for using events from the various units */ |
129 | static u64 unit_cons[PM_LASTUNIT+1][2] = { | 129 | static unsigned long unit_cons[PM_LASTUNIT+1][2] = { |
130 | [PM_FPU] = { 0x3200000000ull, 0x0100000000ull }, | 130 | [PM_FPU] = { 0x3200000000ul, 0x0100000000ul }, |
131 | [PM_ISU0] = { 0x0200000000ull, 0x0080000000ull }, | 131 | [PM_ISU0] = { 0x0200000000ul, 0x0080000000ul }, |
132 | [PM_ISU1] = { 0x3200000000ull, 0x3100000000ull }, | 132 | [PM_ISU1] = { 0x3200000000ul, 0x3100000000ul }, |
133 | [PM_IFU] = { 0x3200000000ull, 0x2100000000ull }, | 133 | [PM_IFU] = { 0x3200000000ul, 0x2100000000ul }, |
134 | [PM_IDU] = { 0x0e00000000ull, 0x0040000000ull }, | 134 | [PM_IDU] = { 0x0e00000000ul, 0x0040000000ul }, |
135 | [PM_GRS] = { 0x0e00000000ull, 0x0c40000000ull }, | 135 | [PM_GRS] = { 0x0e00000000ul, 0x0c40000000ul }, |
136 | }; | 136 | }; |
137 | 137 | ||
138 | static int power5p_get_constraint(u64 event, u64 *maskp, u64 *valp) | 138 | static int power5p_get_constraint(u64 event, unsigned long *maskp, |
139 | unsigned long *valp) | ||
139 | { | 140 | { |
140 | int pmc, byte, unit, sh; | 141 | int pmc, byte, unit, sh; |
141 | int bit, fmask; | 142 | int bit, fmask; |
142 | u64 mask = 0, value = 0; | 143 | unsigned long mask = 0, value = 0; |
143 | 144 | ||
144 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 145 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
145 | if (pmc) { | 146 | if (pmc) { |
@@ -171,17 +172,18 @@ static int power5p_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
171 | bit = event & 7; | 172 | bit = event & 7; |
172 | fmask = (bit == 6)? 7: 3; | 173 | fmask = (bit == 6)? 7: 3; |
173 | sh = grsel_shift[bit]; | 174 | sh = grsel_shift[bit]; |
174 | mask |= (u64)fmask << sh; | 175 | mask |= (unsigned long)fmask << sh; |
175 | value |= (u64)((event >> PM_GRS_SH) & fmask) << sh; | 176 | value |= (unsigned long)((event >> PM_GRS_SH) & fmask) |
177 | << sh; | ||
176 | } | 178 | } |
177 | /* Set byte lane select field */ | 179 | /* Set byte lane select field */ |
178 | mask |= 0xfULL << (24 - 4 * byte); | 180 | mask |= 0xfUL << (24 - 4 * byte); |
179 | value |= (u64)unit << (24 - 4 * byte); | 181 | value |= (unsigned long)unit << (24 - 4 * byte); |
180 | } | 182 | } |
181 | if (pmc < 5) { | 183 | if (pmc < 5) { |
182 | /* need a counter from PMC1-4 set */ | 184 | /* need a counter from PMC1-4 set */ |
183 | mask |= 0x8000000000000ull; | 185 | mask |= 0x8000000000000ul; |
184 | value |= 0x1000000000000ull; | 186 | value |= 0x1000000000000ul; |
185 | } | 187 | } |
186 | *maskp = mask; | 188 | *maskp = mask; |
187 | *valp = value; | 189 | *valp = value; |
@@ -452,10 +454,10 @@ static int power5p_marked_instr_event(u64 event) | |||
452 | } | 454 | } |
453 | 455 | ||
454 | static int power5p_compute_mmcr(u64 event[], int n_ev, | 456 | static int power5p_compute_mmcr(u64 event[], int n_ev, |
455 | unsigned int hwc[], u64 mmcr[]) | 457 | unsigned int hwc[], unsigned long mmcr[]) |
456 | { | 458 | { |
457 | u64 mmcr1 = 0; | 459 | unsigned long mmcr1 = 0; |
458 | u64 mmcra = 0; | 460 | unsigned long mmcra = 0; |
459 | unsigned int pmc, unit, byte, psel; | 461 | unsigned int pmc, unit, byte, psel; |
460 | unsigned int ttm; | 462 | unsigned int ttm; |
461 | int i, isbus, bit, grsel; | 463 | int i, isbus, bit, grsel; |
@@ -517,7 +519,7 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
517 | continue; | 519 | continue; |
518 | if (ttmuse++) | 520 | if (ttmuse++) |
519 | return -1; | 521 | return -1; |
520 | mmcr1 |= (u64)i << MMCR1_TTM0SEL_SH; | 522 | mmcr1 |= (unsigned long)i << MMCR1_TTM0SEL_SH; |
521 | } | 523 | } |
522 | ttmuse = 0; | 524 | ttmuse = 0; |
523 | for (; i <= PM_GRS; ++i) { | 525 | for (; i <= PM_GRS; ++i) { |
@@ -525,7 +527,7 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
525 | continue; | 527 | continue; |
526 | if (ttmuse++) | 528 | if (ttmuse++) |
527 | return -1; | 529 | return -1; |
528 | mmcr1 |= (u64)(i & 3) << MMCR1_TTM1SEL_SH; | 530 | mmcr1 |= (unsigned long)(i & 3) << MMCR1_TTM1SEL_SH; |
529 | } | 531 | } |
530 | if (ttmuse > 1) | 532 | if (ttmuse > 1) |
531 | return -1; | 533 | return -1; |
@@ -540,10 +542,11 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
540 | unit = PM_ISU0_ALT; | 542 | unit = PM_ISU0_ALT; |
541 | } else if (unit == PM_LSU1 + 1) { | 543 | } else if (unit == PM_LSU1 + 1) { |
542 | /* select lower word of LSU1 for this byte */ | 544 | /* select lower word of LSU1 for this byte */ |
543 | mmcr1 |= 1ull << (MMCR1_TTM3SEL_SH + 3 - byte); | 545 | mmcr1 |= 1ul << (MMCR1_TTM3SEL_SH + 3 - byte); |
544 | } | 546 | } |
545 | ttm = unit >> 2; | 547 | ttm = unit >> 2; |
546 | mmcr1 |= (u64)ttm << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | 548 | mmcr1 |= (unsigned long)ttm |
549 | << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | ||
547 | } | 550 | } |
548 | 551 | ||
549 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ | 552 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ |
@@ -568,7 +571,7 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
568 | if (isbus && (byte & 2) && | 571 | if (isbus && (byte & 2) && |
569 | (psel == 8 || psel == 0x10 || psel == 0x28)) | 572 | (psel == 8 || psel == 0x10 || psel == 0x28)) |
570 | /* add events on higher-numbered bus */ | 573 | /* add events on higher-numbered bus */ |
571 | mmcr1 |= 1ull << (MMCR1_PMC1_ADDER_SEL_SH - pmc); | 574 | mmcr1 |= 1ul << (MMCR1_PMC1_ADDER_SEL_SH - pmc); |
572 | } else { | 575 | } else { |
573 | /* Instructions or run cycles on PMC5/6 */ | 576 | /* Instructions or run cycles on PMC5/6 */ |
574 | --pmc; | 577 | --pmc; |
@@ -576,7 +579,7 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
576 | if (isbus && unit == PM_GRS) { | 579 | if (isbus && unit == PM_GRS) { |
577 | bit = psel & 7; | 580 | bit = psel & 7; |
578 | grsel = (event[i] >> PM_GRS_SH) & PM_GRS_MSK; | 581 | grsel = (event[i] >> PM_GRS_SH) & PM_GRS_MSK; |
579 | mmcr1 |= (u64)grsel << grsel_shift[bit]; | 582 | mmcr1 |= (unsigned long)grsel << grsel_shift[bit]; |
580 | } | 583 | } |
581 | if (power5p_marked_instr_event(event[i])) | 584 | if (power5p_marked_instr_event(event[i])) |
582 | mmcra |= MMCRA_SAMPLE_ENABLE; | 585 | mmcra |= MMCRA_SAMPLE_ENABLE; |
@@ -599,7 +602,7 @@ static int power5p_compute_mmcr(u64 event[], int n_ev, | |||
599 | return 0; | 602 | return 0; |
600 | } | 603 | } |
601 | 604 | ||
602 | static void power5p_disable_pmc(unsigned int pmc, u64 mmcr[]) | 605 | static void power5p_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
603 | { | 606 | { |
604 | if (pmc <= 3) | 607 | if (pmc <= 3) |
605 | mmcr[1] &= ~(0x7fUL << MMCR1_PMCSEL_SH(pmc)); | 608 | mmcr[1] &= ~(0x7fUL << MMCR1_PMCSEL_SH(pmc)); |
@@ -655,17 +658,17 @@ static int power5p_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
655 | }; | 658 | }; |
656 | 659 | ||
657 | struct power_pmu power5p_pmu = { | 660 | struct power_pmu power5p_pmu = { |
658 | .n_counter = 6, | 661 | .n_counter = 6, |
659 | .max_alternatives = MAX_ALT, | 662 | .max_alternatives = MAX_ALT, |
660 | .add_fields = 0x7000000000055ull, | 663 | .add_fields = 0x7000000000055ul, |
661 | .test_adder = 0x3000040000000ull, | 664 | .test_adder = 0x3000040000000ul, |
662 | .compute_mmcr = power5p_compute_mmcr, | 665 | .compute_mmcr = power5p_compute_mmcr, |
663 | .get_constraint = power5p_get_constraint, | 666 | .get_constraint = power5p_get_constraint, |
664 | .get_alternatives = power5p_get_alternatives, | 667 | .get_alternatives = power5p_get_alternatives, |
665 | .disable_pmc = power5p_disable_pmc, | 668 | .disable_pmc = power5p_disable_pmc, |
666 | .limited_pmc_event = power5p_limited_pmc_event, | 669 | .limited_pmc_event = power5p_limited_pmc_event, |
667 | .flags = PPMU_LIMITED_PMC5_6, | 670 | .flags = PPMU_LIMITED_PMC5_6, |
668 | .n_generic = ARRAY_SIZE(power5p_generic_events), | 671 | .n_generic = ARRAY_SIZE(power5p_generic_events), |
669 | .generic_events = power5p_generic_events, | 672 | .generic_events = power5p_generic_events, |
670 | .cache_events = &power5p_cache_events, | 673 | .cache_events = &power5p_cache_events, |
671 | }; | 674 | }; |
diff --git a/arch/powerpc/kernel/power5-pmu.c b/arch/powerpc/kernel/power5-pmu.c index 05600b66221a..8694c73bfb52 100644 --- a/arch/powerpc/kernel/power5-pmu.c +++ b/arch/powerpc/kernel/power5-pmu.c | |||
@@ -130,20 +130,21 @@ static const int grsel_shift[8] = { | |||
130 | }; | 130 | }; |
131 | 131 | ||
132 | /* Masks and values for using events from the various units */ | 132 | /* Masks and values for using events from the various units */ |
133 | static u64 unit_cons[PM_LASTUNIT+1][2] = { | 133 | static unsigned long unit_cons[PM_LASTUNIT+1][2] = { |
134 | [PM_FPU] = { 0xc0002000000000ull, 0x00001000000000ull }, | 134 | [PM_FPU] = { 0xc0002000000000ul, 0x00001000000000ul }, |
135 | [PM_ISU0] = { 0x00002000000000ull, 0x00000800000000ull }, | 135 | [PM_ISU0] = { 0x00002000000000ul, 0x00000800000000ul }, |
136 | [PM_ISU1] = { 0xc0002000000000ull, 0xc0001000000000ull }, | 136 | [PM_ISU1] = { 0xc0002000000000ul, 0xc0001000000000ul }, |
137 | [PM_IFU] = { 0xc0002000000000ull, 0x80001000000000ull }, | 137 | [PM_IFU] = { 0xc0002000000000ul, 0x80001000000000ul }, |
138 | [PM_IDU] = { 0x30002000000000ull, 0x00000400000000ull }, | 138 | [PM_IDU] = { 0x30002000000000ul, 0x00000400000000ul }, |
139 | [PM_GRS] = { 0x30002000000000ull, 0x30000400000000ull }, | 139 | [PM_GRS] = { 0x30002000000000ul, 0x30000400000000ul }, |
140 | }; | 140 | }; |
141 | 141 | ||
142 | static int power5_get_constraint(u64 event, u64 *maskp, u64 *valp) | 142 | static int power5_get_constraint(u64 event, unsigned long *maskp, |
143 | unsigned long *valp) | ||
143 | { | 144 | { |
144 | int pmc, byte, unit, sh; | 145 | int pmc, byte, unit, sh; |
145 | int bit, fmask; | 146 | int bit, fmask; |
146 | u64 mask = 0, value = 0; | 147 | unsigned long mask = 0, value = 0; |
147 | int grp = -1; | 148 | int grp = -1; |
148 | 149 | ||
149 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 150 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
@@ -178,8 +179,9 @@ static int power5_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
178 | bit = event & 7; | 179 | bit = event & 7; |
179 | fmask = (bit == 6)? 7: 3; | 180 | fmask = (bit == 6)? 7: 3; |
180 | sh = grsel_shift[bit]; | 181 | sh = grsel_shift[bit]; |
181 | mask |= (u64)fmask << sh; | 182 | mask |= (unsigned long)fmask << sh; |
182 | value |= (u64)((event >> PM_GRS_SH) & fmask) << sh; | 183 | value |= (unsigned long)((event >> PM_GRS_SH) & fmask) |
184 | << sh; | ||
183 | } | 185 | } |
184 | /* | 186 | /* |
185 | * Bus events on bytes 0 and 2 can be counted | 187 | * Bus events on bytes 0 and 2 can be counted |
@@ -188,22 +190,22 @@ static int power5_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
188 | if (!pmc) | 190 | if (!pmc) |
189 | grp = byte & 1; | 191 | grp = byte & 1; |
190 | /* Set byte lane select field */ | 192 | /* Set byte lane select field */ |
191 | mask |= 0xfULL << (24 - 4 * byte); | 193 | mask |= 0xfUL << (24 - 4 * byte); |
192 | value |= (u64)unit << (24 - 4 * byte); | 194 | value |= (unsigned long)unit << (24 - 4 * byte); |
193 | } | 195 | } |
194 | if (grp == 0) { | 196 | if (grp == 0) { |
195 | /* increment PMC1/2 field */ | 197 | /* increment PMC1/2 field */ |
196 | mask |= 0x200000000ull; | 198 | mask |= 0x200000000ul; |
197 | value |= 0x080000000ull; | 199 | value |= 0x080000000ul; |
198 | } else if (grp == 1) { | 200 | } else if (grp == 1) { |
199 | /* increment PMC3/4 field */ | 201 | /* increment PMC3/4 field */ |
200 | mask |= 0x40000000ull; | 202 | mask |= 0x40000000ul; |
201 | value |= 0x10000000ull; | 203 | value |= 0x10000000ul; |
202 | } | 204 | } |
203 | if (pmc < 5) { | 205 | if (pmc < 5) { |
204 | /* need a counter from PMC1-4 set */ | 206 | /* need a counter from PMC1-4 set */ |
205 | mask |= 0x8000000000000ull; | 207 | mask |= 0x8000000000000ul; |
206 | value |= 0x1000000000000ull; | 208 | value |= 0x1000000000000ul; |
207 | } | 209 | } |
208 | *maskp = mask; | 210 | *maskp = mask; |
209 | *valp = value; | 211 | *valp = value; |
@@ -383,10 +385,10 @@ static int power5_marked_instr_event(u64 event) | |||
383 | } | 385 | } |
384 | 386 | ||
385 | static int power5_compute_mmcr(u64 event[], int n_ev, | 387 | static int power5_compute_mmcr(u64 event[], int n_ev, |
386 | unsigned int hwc[], u64 mmcr[]) | 388 | unsigned int hwc[], unsigned long mmcr[]) |
387 | { | 389 | { |
388 | u64 mmcr1 = 0; | 390 | unsigned long mmcr1 = 0; |
389 | u64 mmcra = 0; | 391 | unsigned long mmcra = 0; |
390 | unsigned int pmc, unit, byte, psel; | 392 | unsigned int pmc, unit, byte, psel; |
391 | unsigned int ttm, grp; | 393 | unsigned int ttm, grp; |
392 | int i, isbus, bit, grsel; | 394 | int i, isbus, bit, grsel; |
@@ -457,7 +459,7 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
457 | continue; | 459 | continue; |
458 | if (ttmuse++) | 460 | if (ttmuse++) |
459 | return -1; | 461 | return -1; |
460 | mmcr1 |= (u64)i << MMCR1_TTM0SEL_SH; | 462 | mmcr1 |= (unsigned long)i << MMCR1_TTM0SEL_SH; |
461 | } | 463 | } |
462 | ttmuse = 0; | 464 | ttmuse = 0; |
463 | for (; i <= PM_GRS; ++i) { | 465 | for (; i <= PM_GRS; ++i) { |
@@ -465,7 +467,7 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
465 | continue; | 467 | continue; |
466 | if (ttmuse++) | 468 | if (ttmuse++) |
467 | return -1; | 469 | return -1; |
468 | mmcr1 |= (u64)(i & 3) << MMCR1_TTM1SEL_SH; | 470 | mmcr1 |= (unsigned long)(i & 3) << MMCR1_TTM1SEL_SH; |
469 | } | 471 | } |
470 | if (ttmuse > 1) | 472 | if (ttmuse > 1) |
471 | return -1; | 473 | return -1; |
@@ -480,10 +482,11 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
480 | unit = PM_ISU0_ALT; | 482 | unit = PM_ISU0_ALT; |
481 | } else if (unit == PM_LSU1 + 1) { | 483 | } else if (unit == PM_LSU1 + 1) { |
482 | /* select lower word of LSU1 for this byte */ | 484 | /* select lower word of LSU1 for this byte */ |
483 | mmcr1 |= 1ull << (MMCR1_TTM3SEL_SH + 3 - byte); | 485 | mmcr1 |= 1ul << (MMCR1_TTM3SEL_SH + 3 - byte); |
484 | } | 486 | } |
485 | ttm = unit >> 2; | 487 | ttm = unit >> 2; |
486 | mmcr1 |= (u64)ttm << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | 488 | mmcr1 |= (unsigned long)ttm |
489 | << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | ||
487 | } | 490 | } |
488 | 491 | ||
489 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ | 492 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ |
@@ -513,7 +516,7 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
513 | --pmc; | 516 | --pmc; |
514 | if ((psel == 8 || psel == 0x10) && isbus && (byte & 2)) | 517 | if ((psel == 8 || psel == 0x10) && isbus && (byte & 2)) |
515 | /* add events on higher-numbered bus */ | 518 | /* add events on higher-numbered bus */ |
516 | mmcr1 |= 1ull << (MMCR1_PMC1_ADDER_SEL_SH - pmc); | 519 | mmcr1 |= 1ul << (MMCR1_PMC1_ADDER_SEL_SH - pmc); |
517 | } else { | 520 | } else { |
518 | /* Instructions or run cycles on PMC5/6 */ | 521 | /* Instructions or run cycles on PMC5/6 */ |
519 | --pmc; | 522 | --pmc; |
@@ -521,7 +524,7 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
521 | if (isbus && unit == PM_GRS) { | 524 | if (isbus && unit == PM_GRS) { |
522 | bit = psel & 7; | 525 | bit = psel & 7; |
523 | grsel = (event[i] >> PM_GRS_SH) & PM_GRS_MSK; | 526 | grsel = (event[i] >> PM_GRS_SH) & PM_GRS_MSK; |
524 | mmcr1 |= (u64)grsel << grsel_shift[bit]; | 527 | mmcr1 |= (unsigned long)grsel << grsel_shift[bit]; |
525 | } | 528 | } |
526 | if (power5_marked_instr_event(event[i])) | 529 | if (power5_marked_instr_event(event[i])) |
527 | mmcra |= MMCRA_SAMPLE_ENABLE; | 530 | mmcra |= MMCRA_SAMPLE_ENABLE; |
@@ -541,7 +544,7 @@ static int power5_compute_mmcr(u64 event[], int n_ev, | |||
541 | return 0; | 544 | return 0; |
542 | } | 545 | } |
543 | 546 | ||
544 | static void power5_disable_pmc(unsigned int pmc, u64 mmcr[]) | 547 | static void power5_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
545 | { | 548 | { |
546 | if (pmc <= 3) | 549 | if (pmc <= 3) |
547 | mmcr[1] &= ~(0x7fUL << MMCR1_PMCSEL_SH(pmc)); | 550 | mmcr[1] &= ~(0x7fUL << MMCR1_PMCSEL_SH(pmc)); |
@@ -597,15 +600,15 @@ static int power5_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
597 | }; | 600 | }; |
598 | 601 | ||
599 | struct power_pmu power5_pmu = { | 602 | struct power_pmu power5_pmu = { |
600 | .n_counter = 6, | 603 | .n_counter = 6, |
601 | .max_alternatives = MAX_ALT, | 604 | .max_alternatives = MAX_ALT, |
602 | .add_fields = 0x7000090000555ull, | 605 | .add_fields = 0x7000090000555ul, |
603 | .test_adder = 0x3000490000000ull, | 606 | .test_adder = 0x3000490000000ul, |
604 | .compute_mmcr = power5_compute_mmcr, | 607 | .compute_mmcr = power5_compute_mmcr, |
605 | .get_constraint = power5_get_constraint, | 608 | .get_constraint = power5_get_constraint, |
606 | .get_alternatives = power5_get_alternatives, | 609 | .get_alternatives = power5_get_alternatives, |
607 | .disable_pmc = power5_disable_pmc, | 610 | .disable_pmc = power5_disable_pmc, |
608 | .n_generic = ARRAY_SIZE(power5_generic_events), | 611 | .n_generic = ARRAY_SIZE(power5_generic_events), |
609 | .generic_events = power5_generic_events, | 612 | .generic_events = power5_generic_events, |
610 | .cache_events = &power5_cache_events, | 613 | .cache_events = &power5_cache_events, |
611 | }; | 614 | }; |
diff --git a/arch/powerpc/kernel/power6-pmu.c b/arch/powerpc/kernel/power6-pmu.c index 46f74bebcfd9..8898622ac28c 100644 --- a/arch/powerpc/kernel/power6-pmu.c +++ b/arch/powerpc/kernel/power6-pmu.c | |||
@@ -41,9 +41,9 @@ | |||
41 | #define MMCR1_NESTSEL_SH 45 | 41 | #define MMCR1_NESTSEL_SH 45 |
42 | #define MMCR1_NESTSEL_MSK 0x7 | 42 | #define MMCR1_NESTSEL_MSK 0x7 |
43 | #define MMCR1_NESTSEL(m) (((m) >> MMCR1_NESTSEL_SH) & MMCR1_NESTSEL_MSK) | 43 | #define MMCR1_NESTSEL(m) (((m) >> MMCR1_NESTSEL_SH) & MMCR1_NESTSEL_MSK) |
44 | #define MMCR1_PMC1_LLA ((u64)1 << 44) | 44 | #define MMCR1_PMC1_LLA (1ul << 44) |
45 | #define MMCR1_PMC1_LLA_VALUE ((u64)1 << 39) | 45 | #define MMCR1_PMC1_LLA_VALUE (1ul << 39) |
46 | #define MMCR1_PMC1_ADDR_SEL ((u64)1 << 35) | 46 | #define MMCR1_PMC1_ADDR_SEL (1ul << 35) |
47 | #define MMCR1_PMC1SEL_SH 24 | 47 | #define MMCR1_PMC1SEL_SH 24 |
48 | #define MMCR1_PMCSEL_SH(n) (MMCR1_PMC1SEL_SH - (n) * 8) | 48 | #define MMCR1_PMCSEL_SH(n) (MMCR1_PMC1SEL_SH - (n) * 8) |
49 | #define MMCR1_PMCSEL_MSK 0xff | 49 | #define MMCR1_PMCSEL_MSK 0xff |
@@ -173,10 +173,10 @@ static int power6_marked_instr_event(u64 event) | |||
173 | * Assign PMC numbers and compute MMCR1 value for a set of events | 173 | * Assign PMC numbers and compute MMCR1 value for a set of events |
174 | */ | 174 | */ |
175 | static int p6_compute_mmcr(u64 event[], int n_ev, | 175 | static int p6_compute_mmcr(u64 event[], int n_ev, |
176 | unsigned int hwc[], u64 mmcr[]) | 176 | unsigned int hwc[], unsigned long mmcr[]) |
177 | { | 177 | { |
178 | u64 mmcr1 = 0; | 178 | unsigned long mmcr1 = 0; |
179 | u64 mmcra = 0; | 179 | unsigned long mmcra = 0; |
180 | int i; | 180 | int i; |
181 | unsigned int pmc, ev, b, u, s, psel; | 181 | unsigned int pmc, ev, b, u, s, psel; |
182 | unsigned int ttmset = 0; | 182 | unsigned int ttmset = 0; |
@@ -215,7 +215,7 @@ static int p6_compute_mmcr(u64 event[], int n_ev, | |||
215 | /* check for conflict on this byte of event bus */ | 215 | /* check for conflict on this byte of event bus */ |
216 | if ((ttmset & (1 << b)) && MMCR1_TTMSEL(mmcr1, b) != u) | 216 | if ((ttmset & (1 << b)) && MMCR1_TTMSEL(mmcr1, b) != u) |
217 | return -1; | 217 | return -1; |
218 | mmcr1 |= (u64)u << MMCR1_TTMSEL_SH(b); | 218 | mmcr1 |= (unsigned long)u << MMCR1_TTMSEL_SH(b); |
219 | ttmset |= 1 << b; | 219 | ttmset |= 1 << b; |
220 | if (u == 5) { | 220 | if (u == 5) { |
221 | /* Nest events have a further mux */ | 221 | /* Nest events have a further mux */ |
@@ -224,7 +224,7 @@ static int p6_compute_mmcr(u64 event[], int n_ev, | |||
224 | MMCR1_NESTSEL(mmcr1) != s) | 224 | MMCR1_NESTSEL(mmcr1) != s) |
225 | return -1; | 225 | return -1; |
226 | ttmset |= 0x10; | 226 | ttmset |= 0x10; |
227 | mmcr1 |= (u64)s << MMCR1_NESTSEL_SH; | 227 | mmcr1 |= (unsigned long)s << MMCR1_NESTSEL_SH; |
228 | } | 228 | } |
229 | if (0x30 <= psel && psel <= 0x3d) { | 229 | if (0x30 <= psel && psel <= 0x3d) { |
230 | /* these need the PMCx_ADDR_SEL bits */ | 230 | /* these need the PMCx_ADDR_SEL bits */ |
@@ -243,7 +243,7 @@ static int p6_compute_mmcr(u64 event[], int n_ev, | |||
243 | if (power6_marked_instr_event(event[i])) | 243 | if (power6_marked_instr_event(event[i])) |
244 | mmcra |= MMCRA_SAMPLE_ENABLE; | 244 | mmcra |= MMCRA_SAMPLE_ENABLE; |
245 | if (pmc < 4) | 245 | if (pmc < 4) |
246 | mmcr1 |= (u64)psel << MMCR1_PMCSEL_SH(pmc); | 246 | mmcr1 |= (unsigned long)psel << MMCR1_PMCSEL_SH(pmc); |
247 | } | 247 | } |
248 | mmcr[0] = 0; | 248 | mmcr[0] = 0; |
249 | if (pmc_inuse & 1) | 249 | if (pmc_inuse & 1) |
@@ -265,10 +265,11 @@ static int p6_compute_mmcr(u64 event[], int n_ev, | |||
265 | * 20-23, 24-27, 28-31 ditto for bytes 1, 2, 3 | 265 | * 20-23, 24-27, 28-31 ditto for bytes 1, 2, 3 |
266 | * 32-34 select field: nest (subunit) event selector | 266 | * 32-34 select field: nest (subunit) event selector |
267 | */ | 267 | */ |
268 | static int p6_get_constraint(u64 event, u64 *maskp, u64 *valp) | 268 | static int p6_get_constraint(u64 event, unsigned long *maskp, |
269 | unsigned long *valp) | ||
269 | { | 270 | { |
270 | int pmc, byte, sh, subunit; | 271 | int pmc, byte, sh, subunit; |
271 | u64 mask = 0, value = 0; | 272 | unsigned long mask = 0, value = 0; |
272 | 273 | ||
273 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 274 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
274 | if (pmc) { | 275 | if (pmc) { |
@@ -282,11 +283,11 @@ static int p6_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
282 | byte = (event >> PM_BYTE_SH) & PM_BYTE_MSK; | 283 | byte = (event >> PM_BYTE_SH) & PM_BYTE_MSK; |
283 | sh = byte * 4 + (16 - PM_UNIT_SH); | 284 | sh = byte * 4 + (16 - PM_UNIT_SH); |
284 | mask |= PM_UNIT_MSKS << sh; | 285 | mask |= PM_UNIT_MSKS << sh; |
285 | value |= (u64)(event & PM_UNIT_MSKS) << sh; | 286 | value |= (unsigned long)(event & PM_UNIT_MSKS) << sh; |
286 | if ((event & PM_UNIT_MSKS) == (5 << PM_UNIT_SH)) { | 287 | if ((event & PM_UNIT_MSKS) == (5 << PM_UNIT_SH)) { |
287 | subunit = (event >> PM_SUBUNIT_SH) & PM_SUBUNIT_MSK; | 288 | subunit = (event >> PM_SUBUNIT_SH) & PM_SUBUNIT_MSK; |
288 | mask |= (u64)PM_SUBUNIT_MSK << 32; | 289 | mask |= (unsigned long)PM_SUBUNIT_MSK << 32; |
289 | value |= (u64)subunit << 32; | 290 | value |= (unsigned long)subunit << 32; |
290 | } | 291 | } |
291 | } | 292 | } |
292 | if (pmc <= 4) { | 293 | if (pmc <= 4) { |
@@ -458,7 +459,7 @@ static int p6_get_alternatives(u64 event, unsigned int flags, u64 alt[]) | |||
458 | return nalt; | 459 | return nalt; |
459 | } | 460 | } |
460 | 461 | ||
461 | static void p6_disable_pmc(unsigned int pmc, u64 mmcr[]) | 462 | static void p6_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
462 | { | 463 | { |
463 | /* Set PMCxSEL to 0 to disable PMCx */ | 464 | /* Set PMCxSEL to 0 to disable PMCx */ |
464 | if (pmc <= 3) | 465 | if (pmc <= 3) |
@@ -516,17 +517,17 @@ static int power6_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
516 | }; | 517 | }; |
517 | 518 | ||
518 | struct power_pmu power6_pmu = { | 519 | struct power_pmu power6_pmu = { |
519 | .n_counter = 6, | 520 | .n_counter = 6, |
520 | .max_alternatives = MAX_ALT, | 521 | .max_alternatives = MAX_ALT, |
521 | .add_fields = 0x1555, | 522 | .add_fields = 0x1555, |
522 | .test_adder = 0x3000, | 523 | .test_adder = 0x3000, |
523 | .compute_mmcr = p6_compute_mmcr, | 524 | .compute_mmcr = p6_compute_mmcr, |
524 | .get_constraint = p6_get_constraint, | 525 | .get_constraint = p6_get_constraint, |
525 | .get_alternatives = p6_get_alternatives, | 526 | .get_alternatives = p6_get_alternatives, |
526 | .disable_pmc = p6_disable_pmc, | 527 | .disable_pmc = p6_disable_pmc, |
527 | .limited_pmc_event = p6_limited_pmc_event, | 528 | .limited_pmc_event = p6_limited_pmc_event, |
528 | .flags = PPMU_LIMITED_PMC5_6 | PPMU_ALT_SIPR, | 529 | .flags = PPMU_LIMITED_PMC5_6 | PPMU_ALT_SIPR, |
529 | .n_generic = ARRAY_SIZE(power6_generic_events), | 530 | .n_generic = ARRAY_SIZE(power6_generic_events), |
530 | .generic_events = power6_generic_events, | 531 | .generic_events = power6_generic_events, |
531 | .cache_events = &power6_cache_events, | 532 | .cache_events = &power6_cache_events, |
532 | }; | 533 | }; |
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 | }; |
diff --git a/arch/powerpc/kernel/ppc970-pmu.c b/arch/powerpc/kernel/ppc970-pmu.c index ba0a357a89f4..3ed88333412f 100644 --- a/arch/powerpc/kernel/ppc970-pmu.c +++ b/arch/powerpc/kernel/ppc970-pmu.c | |||
@@ -183,7 +183,7 @@ static int p970_marked_instr_event(u64 event) | |||
183 | } | 183 | } |
184 | 184 | ||
185 | /* Masks and values for using events from the various units */ | 185 | /* Masks and values for using events from the various units */ |
186 | static u64 unit_cons[PM_LASTUNIT+1][2] = { | 186 | static unsigned long unit_cons[PM_LASTUNIT+1][2] = { |
187 | [PM_FPU] = { 0xc80000000000ull, 0x040000000000ull }, | 187 | [PM_FPU] = { 0xc80000000000ull, 0x040000000000ull }, |
188 | [PM_VPU] = { 0xc80000000000ull, 0xc40000000000ull }, | 188 | [PM_VPU] = { 0xc80000000000ull, 0xc40000000000ull }, |
189 | [PM_ISU] = { 0x080000000000ull, 0x020000000000ull }, | 189 | [PM_ISU] = { 0x080000000000ull, 0x020000000000ull }, |
@@ -192,10 +192,11 @@ 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(u64 event, u64 *maskp, u64 *valp) | 195 | static int p970_get_constraint(u64 event, unsigned long *maskp, |
196 | unsigned long *valp) | ||
196 | { | 197 | { |
197 | int pmc, byte, unit, sh, spcsel; | 198 | int pmc, byte, unit, sh, spcsel; |
198 | u64 mask = 0, value = 0; | 199 | unsigned long mask = 0, value = 0; |
199 | int grp = -1; | 200 | int grp = -1; |
200 | 201 | ||
201 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; | 202 | pmc = (event >> PM_PMC_SH) & PM_PMC_MSK; |
@@ -222,7 +223,7 @@ static int p970_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
222 | grp = byte & 1; | 223 | grp = byte & 1; |
223 | /* Set byte lane select field */ | 224 | /* Set byte lane select field */ |
224 | mask |= 0xfULL << (28 - 4 * byte); | 225 | mask |= 0xfULL << (28 - 4 * byte); |
225 | value |= (u64)unit << (28 - 4 * byte); | 226 | value |= (unsigned long)unit << (28 - 4 * byte); |
226 | } | 227 | } |
227 | if (grp == 0) { | 228 | if (grp == 0) { |
228 | /* increment PMC1/2/5/6 field */ | 229 | /* increment PMC1/2/5/6 field */ |
@@ -236,7 +237,7 @@ static int p970_get_constraint(u64 event, u64 *maskp, u64 *valp) | |||
236 | spcsel = (event >> PM_SPCSEL_SH) & PM_SPCSEL_MSK; | 237 | spcsel = (event >> PM_SPCSEL_SH) & PM_SPCSEL_MSK; |
237 | if (spcsel) { | 238 | if (spcsel) { |
238 | mask |= 3ull << 48; | 239 | mask |= 3ull << 48; |
239 | value |= (u64)spcsel << 48; | 240 | value |= (unsigned long)spcsel << 48; |
240 | } | 241 | } |
241 | *maskp = mask; | 242 | *maskp = mask; |
242 | *valp = value; | 243 | *valp = value; |
@@ -257,9 +258,9 @@ static int p970_get_alternatives(u64 event, unsigned int flags, u64 alt[]) | |||
257 | } | 258 | } |
258 | 259 | ||
259 | static int p970_compute_mmcr(u64 event[], int n_ev, | 260 | static int p970_compute_mmcr(u64 event[], int n_ev, |
260 | unsigned int hwc[], u64 mmcr[]) | 261 | unsigned int hwc[], unsigned long mmcr[]) |
261 | { | 262 | { |
262 | u64 mmcr0 = 0, mmcr1 = 0, mmcra = 0; | 263 | unsigned long mmcr0 = 0, mmcr1 = 0, mmcra = 0; |
263 | unsigned int pmc, unit, byte, psel; | 264 | unsigned int pmc, unit, byte, psel; |
264 | unsigned int ttm, grp; | 265 | unsigned int ttm, grp; |
265 | unsigned int pmc_inuse = 0; | 266 | unsigned int pmc_inuse = 0; |
@@ -320,7 +321,7 @@ static int p970_compute_mmcr(u64 event[], int n_ev, | |||
320 | continue; | 321 | continue; |
321 | ttm = unitmap[i]; | 322 | ttm = unitmap[i]; |
322 | ++ttmuse[(ttm >> 2) & 1]; | 323 | ++ttmuse[(ttm >> 2) & 1]; |
323 | mmcr1 |= (u64)(ttm & ~4) << MMCR1_TTM1SEL_SH; | 324 | mmcr1 |= (unsigned long)(ttm & ~4) << MMCR1_TTM1SEL_SH; |
324 | } | 325 | } |
325 | /* Check only one unit per TTMx */ | 326 | /* Check only one unit per TTMx */ |
326 | if (ttmuse[0] > 1 || ttmuse[1] > 1) | 327 | if (ttmuse[0] > 1 || ttmuse[1] > 1) |
@@ -340,7 +341,8 @@ static int p970_compute_mmcr(u64 event[], int n_ev, | |||
340 | if (unit == PM_LSU1L && byte >= 2) | 341 | if (unit == PM_LSU1L && byte >= 2) |
341 | mmcr1 |= 1ull << (MMCR1_TTM3SEL_SH + 3 - byte); | 342 | mmcr1 |= 1ull << (MMCR1_TTM3SEL_SH + 3 - byte); |
342 | } | 343 | } |
343 | mmcr1 |= (u64)ttm << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | 344 | mmcr1 |= (unsigned long)ttm |
345 | << (MMCR1_TD_CP_DBG0SEL_SH - 2 * byte); | ||
344 | } | 346 | } |
345 | 347 | ||
346 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ | 348 | /* Second pass: assign PMCs, set PMCxSEL and PMCx_ADDER_SEL fields */ |
@@ -386,7 +388,8 @@ static int p970_compute_mmcr(u64 event[], int n_ev, | |||
386 | for (pmc = 0; pmc < 2; ++pmc) | 388 | for (pmc = 0; pmc < 2; ++pmc) |
387 | mmcr0 |= pmcsel[pmc] << (MMCR0_PMC1SEL_SH - 7 * pmc); | 389 | mmcr0 |= pmcsel[pmc] << (MMCR0_PMC1SEL_SH - 7 * pmc); |
388 | for (; pmc < 8; ++pmc) | 390 | for (; pmc < 8; ++pmc) |
389 | mmcr1 |= (u64)pmcsel[pmc] << (MMCR1_PMC3SEL_SH - 5 * (pmc - 2)); | 391 | mmcr1 |= (unsigned long)pmcsel[pmc] |
392 | << (MMCR1_PMC3SEL_SH - 5 * (pmc - 2)); | ||
390 | if (pmc_inuse & 1) | 393 | if (pmc_inuse & 1) |
391 | mmcr0 |= MMCR0_PMC1CE; | 394 | mmcr0 |= MMCR0_PMC1CE; |
392 | if (pmc_inuse & 0xfe) | 395 | if (pmc_inuse & 0xfe) |
@@ -401,7 +404,7 @@ static int p970_compute_mmcr(u64 event[], int n_ev, | |||
401 | return 0; | 404 | return 0; |
402 | } | 405 | } |
403 | 406 | ||
404 | static void p970_disable_pmc(unsigned int pmc, u64 mmcr[]) | 407 | static void p970_disable_pmc(unsigned int pmc, unsigned long mmcr[]) |
405 | { | 408 | { |
406 | int shift, i; | 409 | int shift, i; |
407 | 410 | ||
@@ -468,15 +471,15 @@ static int ppc970_cache_events[C(MAX)][C(OP_MAX)][C(RESULT_MAX)] = { | |||
468 | }; | 471 | }; |
469 | 472 | ||
470 | struct power_pmu ppc970_pmu = { | 473 | struct power_pmu ppc970_pmu = { |
471 | .n_counter = 8, | 474 | .n_counter = 8, |
472 | .max_alternatives = 2, | 475 | .max_alternatives = 2, |
473 | .add_fields = 0x001100005555ull, | 476 | .add_fields = 0x001100005555ull, |
474 | .test_adder = 0x013300000000ull, | 477 | .test_adder = 0x013300000000ull, |
475 | .compute_mmcr = p970_compute_mmcr, | 478 | .compute_mmcr = p970_compute_mmcr, |
476 | .get_constraint = p970_get_constraint, | 479 | .get_constraint = p970_get_constraint, |
477 | .get_alternatives = p970_get_alternatives, | 480 | .get_alternatives = p970_get_alternatives, |
478 | .disable_pmc = p970_disable_pmc, | 481 | .disable_pmc = p970_disable_pmc, |
479 | .n_generic = ARRAY_SIZE(ppc970_generic_events), | 482 | .n_generic = ARRAY_SIZE(ppc970_generic_events), |
480 | .generic_events = ppc970_generic_events, | 483 | .generic_events = ppc970_generic_events, |
481 | .cache_events = &ppc970_cache_events, | 484 | .cache_events = &ppc970_cache_events, |
482 | }; | 485 | }; |