Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

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

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
Loading
Loading
Loading
Loading
+4 −1
Original line number Diff line number Diff line
@@ -77,6 +77,7 @@ struct sparc_pmu {
	int				upper_shift;
	int				lower_shift;
	int				event_mask;
	int				hv_bit;
};

static const struct perf_event_map ultra3i_perfmon_event_map[] = {
@@ -178,7 +179,7 @@ void hw_perf_disable(void)
	cpuc->enabled = 0;

	val = pcr_ops->read();
	val &= ~(PCR_UTRACE | PCR_STRACE);
	val &= ~(PCR_UTRACE | PCR_STRACE | sparc_pmu->hv_bit);
	pcr_ops->write(val);
}

@@ -377,6 +378,8 @@ static int __hw_perf_counter_init(struct perf_counter *counter)
		hwc->config_base |= PCR_UTRACE;
	if (!attr->exclude_kernel)
		hwc->config_base |= PCR_STRACE;
	if (!attr->exclude_hv)
		hwc->config_base |= sparc_pmu->hv_bit;

	if (!hwc->sample_period) {
		hwc->sample_period = MAX_PERIOD;