diff options
author | David S. Miller <davem@davemloft.net> | 2009-09-26 23:54:22 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-09-26 23:54:22 -0400 |
commit | 28e8f9bead060aafc630a4256d23e2a55fb8b97d (patch) | |
tree | fd171b94d3dbc5d8162675a4eeb6f0cee0364a4d /arch/sparc/kernel/perf_event.c | |
parent | 2ce4da2efcaca0dcbfed7a1f24177f18e75e0e89 (diff) |
sparc: Support all ultra3 and ultra4 derivatives.
For the generic events we support, all of these chips have
the same encodings as ultra3i.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc/kernel/perf_event.c')
-rw-r--r-- | arch/sparc/kernel/perf_event.c | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/arch/sparc/kernel/perf_event.c b/arch/sparc/kernel/perf_event.c index 48375f69467..8abdc4d1baa 100644 --- a/arch/sparc/kernel/perf_event.c +++ b/arch/sparc/kernel/perf_event.c | |||
@@ -91,19 +91,19 @@ struct sparc_pmu { | |||
91 | int lower_nop; | 91 | int lower_nop; |
92 | }; | 92 | }; |
93 | 93 | ||
94 | static const struct perf_event_map ultra3i_perfmon_event_map[] = { | 94 | static const struct perf_event_map ultra3_perfmon_event_map[] = { |
95 | [PERF_COUNT_HW_CPU_CYCLES] = { 0x0000, PIC_UPPER | PIC_LOWER }, | 95 | [PERF_COUNT_HW_CPU_CYCLES] = { 0x0000, PIC_UPPER | PIC_LOWER }, |
96 | [PERF_COUNT_HW_INSTRUCTIONS] = { 0x0001, PIC_UPPER | PIC_LOWER }, | 96 | [PERF_COUNT_HW_INSTRUCTIONS] = { 0x0001, PIC_UPPER | PIC_LOWER }, |
97 | [PERF_COUNT_HW_CACHE_REFERENCES] = { 0x0009, PIC_LOWER }, | 97 | [PERF_COUNT_HW_CACHE_REFERENCES] = { 0x0009, PIC_LOWER }, |
98 | [PERF_COUNT_HW_CACHE_MISSES] = { 0x0009, PIC_UPPER }, | 98 | [PERF_COUNT_HW_CACHE_MISSES] = { 0x0009, PIC_UPPER }, |
99 | }; | 99 | }; |
100 | 100 | ||
101 | static const struct perf_event_map *ultra3i_event_map(int event_id) | 101 | static const struct perf_event_map *ultra3_event_map(int event_id) |
102 | { | 102 | { |
103 | return &ultra3i_perfmon_event_map[event_id]; | 103 | return &ultra3_perfmon_event_map[event_id]; |
104 | } | 104 | } |
105 | 105 | ||
106 | static const cache_map_t ultra3i_cache_map = { | 106 | static const cache_map_t ultra3_cache_map = { |
107 | [C(L1D)] = { | 107 | [C(L1D)] = { |
108 | [C(OP_READ)] = { | 108 | [C(OP_READ)] = { |
109 | [C(RESULT_ACCESS)] = { 0x09, PIC_LOWER, }, | 109 | [C(RESULT_ACCESS)] = { 0x09, PIC_LOWER, }, |
@@ -190,10 +190,10 @@ static const cache_map_t ultra3i_cache_map = { | |||
190 | }, | 190 | }, |
191 | }; | 191 | }; |
192 | 192 | ||
193 | static const struct sparc_pmu ultra3i_pmu = { | 193 | static const struct sparc_pmu ultra3_pmu = { |
194 | .event_map = ultra3i_event_map, | 194 | .event_map = ultra3_event_map, |
195 | .cache_map = &ultra3i_cache_map, | 195 | .cache_map = &ultra3_cache_map, |
196 | .max_events = ARRAY_SIZE(ultra3i_perfmon_event_map), | 196 | .max_events = ARRAY_SIZE(ultra3_perfmon_event_map), |
197 | .upper_shift = 11, | 197 | .upper_shift = 11, |
198 | .lower_shift = 4, | 198 | .lower_shift = 4, |
199 | .event_mask = 0x3f, | 199 | .event_mask = 0x3f, |
@@ -658,8 +658,11 @@ static __read_mostly struct notifier_block perf_event_nmi_notifier = { | |||
658 | 658 | ||
659 | static bool __init supported_pmu(void) | 659 | static bool __init supported_pmu(void) |
660 | { | 660 | { |
661 | if (!strcmp(sparc_pmu_type, "ultra3i")) { | 661 | if (!strcmp(sparc_pmu_type, "ultra3") || |
662 | sparc_pmu = &ultra3i_pmu; | 662 | !strcmp(sparc_pmu_type, "ultra3+") || |
663 | !strcmp(sparc_pmu_type, "ultra3i") || | ||
664 | !strcmp(sparc_pmu_type, "ultra4+")) { | ||
665 | sparc_pmu = &ultra3_pmu; | ||
663 | return true; | 666 | return true; |
664 | } | 667 | } |
665 | if (!strcmp(sparc_pmu_type, "niagara2")) { | 668 | if (!strcmp(sparc_pmu_type, "niagara2")) { |