Commit 28e8f9be authored by David S. Miller's avatar David S. Miller

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: default avatarDavid S. Miller <davem@davemloft.net>
parent 2ce4da2e
...@@ -91,19 +91,19 @@ struct sparc_pmu { ...@@ -91,19 +91,19 @@ struct sparc_pmu {
int lower_nop; int lower_nop;
}; };
static const struct perf_event_map ultra3i_perfmon_event_map[] = { static const struct perf_event_map ultra3_perfmon_event_map[] = {
[PERF_COUNT_HW_CPU_CYCLES] = { 0x0000, PIC_UPPER | PIC_LOWER }, [PERF_COUNT_HW_CPU_CYCLES] = { 0x0000, PIC_UPPER | PIC_LOWER },
[PERF_COUNT_HW_INSTRUCTIONS] = { 0x0001, PIC_UPPER | PIC_LOWER }, [PERF_COUNT_HW_INSTRUCTIONS] = { 0x0001, PIC_UPPER | PIC_LOWER },
[PERF_COUNT_HW_CACHE_REFERENCES] = { 0x0009, PIC_LOWER }, [PERF_COUNT_HW_CACHE_REFERENCES] = { 0x0009, PIC_LOWER },
[PERF_COUNT_HW_CACHE_MISSES] = { 0x0009, PIC_UPPER }, [PERF_COUNT_HW_CACHE_MISSES] = { 0x0009, PIC_UPPER },
}; };
static const struct perf_event_map *ultra3i_event_map(int event_id) static const struct perf_event_map *ultra3_event_map(int event_id)
{ {
return &ultra3i_perfmon_event_map[event_id]; return &ultra3_perfmon_event_map[event_id];
} }
static const cache_map_t ultra3i_cache_map = { static const cache_map_t ultra3_cache_map = {
[C(L1D)] = { [C(L1D)] = {
[C(OP_READ)] = { [C(OP_READ)] = {
[C(RESULT_ACCESS)] = { 0x09, PIC_LOWER, }, [C(RESULT_ACCESS)] = { 0x09, PIC_LOWER, },
...@@ -190,10 +190,10 @@ static const cache_map_t ultra3i_cache_map = { ...@@ -190,10 +190,10 @@ static const cache_map_t ultra3i_cache_map = {
}, },
}; };
static const struct sparc_pmu ultra3i_pmu = { static const struct sparc_pmu ultra3_pmu = {
.event_map = ultra3i_event_map, .event_map = ultra3_event_map,
.cache_map = &ultra3i_cache_map, .cache_map = &ultra3_cache_map,
.max_events = ARRAY_SIZE(ultra3i_perfmon_event_map), .max_events = ARRAY_SIZE(ultra3_perfmon_event_map),
.upper_shift = 11, .upper_shift = 11,
.lower_shift = 4, .lower_shift = 4,
.event_mask = 0x3f, .event_mask = 0x3f,
...@@ -658,8 +658,11 @@ static __read_mostly struct notifier_block perf_event_nmi_notifier = { ...@@ -658,8 +658,11 @@ static __read_mostly struct notifier_block perf_event_nmi_notifier = {
static bool __init supported_pmu(void) static bool __init supported_pmu(void)
{ {
if (!strcmp(sparc_pmu_type, "ultra3i")) { if (!strcmp(sparc_pmu_type, "ultra3") ||
sparc_pmu = &ultra3i_pmu; !strcmp(sparc_pmu_type, "ultra3+") ||
!strcmp(sparc_pmu_type, "ultra3i") ||
!strcmp(sparc_pmu_type, "ultra4+")) {
sparc_pmu = &ultra3_pmu;
return true; return true;
} }
if (!strcmp(sparc_pmu_type, "niagara2")) { if (!strcmp(sparc_pmu_type, "niagara2")) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment