Commit 91b9286d authored by David S. Miller's avatar David S. Miller

sparc64: Provide hypervisor tracing bit support for perf counters.

A PMU need only specify which bit in the PCR enabled hypervisor
tracing in order to enable this.

This will be used in Niagara-2 perf counter support.
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 59abbd1e
...@@ -77,6 +77,7 @@ struct sparc_pmu { ...@@ -77,6 +77,7 @@ struct sparc_pmu {
int upper_shift; int upper_shift;
int lower_shift; int lower_shift;
int event_mask; int event_mask;
int hv_bit;
}; };
static const struct perf_event_map ultra3i_perfmon_event_map[] = { static const struct perf_event_map ultra3i_perfmon_event_map[] = {
...@@ -178,7 +179,7 @@ void hw_perf_disable(void) ...@@ -178,7 +179,7 @@ void hw_perf_disable(void)
cpuc->enabled = 0; cpuc->enabled = 0;
val = pcr_ops->read(); val = pcr_ops->read();
val &= ~(PCR_UTRACE | PCR_STRACE); val &= ~(PCR_UTRACE | PCR_STRACE | sparc_pmu->hv_bit);
pcr_ops->write(val); pcr_ops->write(val);
} }
...@@ -377,6 +378,8 @@ static int __hw_perf_counter_init(struct perf_counter *counter) ...@@ -377,6 +378,8 @@ static int __hw_perf_counter_init(struct perf_counter *counter)
hwc->config_base |= PCR_UTRACE; hwc->config_base |= PCR_UTRACE;
if (!attr->exclude_kernel) if (!attr->exclude_kernel)
hwc->config_base |= PCR_STRACE; hwc->config_base |= PCR_STRACE;
if (!attr->exclude_hv)
hwc->config_base |= sparc_pmu->hv_bit;
if (!hwc->sample_period) { if (!hwc->sample_period) {
hwc->sample_period = MAX_PERIOD; hwc->sample_period = MAX_PERIOD;
......
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