blackfin, perf: Use common PMU interrupt disabled code
Transition to using the new generic PERF_PMU_CAP_NO_INTERRUPT method for failing a sampling event when no PMU interrupt is available. Signed-off-by: Vince Weaver <vincent.weaver@maine.edu> Signed-off-by: Peter Zijlstra <peterz@infradead.org> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Steven Miao <realmz6@gmail.com> Cc: adi-buildroot-devel@lists.sourceforge.net Link: http://lkml.kernel.org/r/alpine.DEB.2.10.1406150200360.16738@vincent-weaver-1.umelst.maine.edu Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
2cc9e588b0
commit
6e316f9c19
|
@ -389,14 +389,6 @@ static int bfin_pmu_event_init(struct perf_event *event)
|
||||||
if (attr->exclude_hv || attr->exclude_idle)
|
if (attr->exclude_hv || attr->exclude_idle)
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
|
|
||||||
/*
|
|
||||||
* All of the on-chip counters are "limited", in that they have
|
|
||||||
* no interrupts, and are therefore unable to do sampling without
|
|
||||||
* further work and timer assistance.
|
|
||||||
*/
|
|
||||||
if (hwc->sample_period)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
switch (attr->type) {
|
switch (attr->type) {
|
||||||
case PERF_TYPE_RAW:
|
case PERF_TYPE_RAW:
|
||||||
|
@ -490,6 +482,13 @@ static int __init bfin_pmu_init(void)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* All of the on-chip counters are "limited", in that they have
|
||||||
|
* no interrupts, and are therefore unable to do sampling without
|
||||||
|
* further work and timer assistance.
|
||||||
|
*/
|
||||||
|
pmu.capabilities |= PERF_PMU_CAP_NO_INTERRUPT;
|
||||||
|
|
||||||
ret = perf_pmu_register(&pmu, "cpu", PERF_TYPE_RAW);
|
ret = perf_pmu_register(&pmu, "cpu", PERF_TYPE_RAW);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
perf_cpu_notifier(bfin_pmu_notifier);
|
perf_cpu_notifier(bfin_pmu_notifier);
|
||||||
|
|
Loading…
Reference in a new issue