Re: [RFC PATCH -v2 0/4] Persistent events

From: Borislav Petkov
Date: Tue Aug 21 2012 - 09:11:41 EST


On Tue, Aug 21, 2012 at 12:30:50PM +0200, Peter Zijlstra wrote:
> Good progress there, there's still a few things though:
>
> - the point also raised by Steven, I'm pretty sure that the placing of
> the debugfs files unfortunate. I would much rather see something
> like /debug/perf/persistent/$foo, also dropping your
> perf_event_desc::dir_name.

Ok, how do we want to do the per-CPU layout there? Like this:

/debug/perf/persistent/mce_record0
/debug/perf/persistent/mce_record1
...

or rather

/debug/perf/persistent/cpu0/mce_record
/debug/perf/persistent/cpu1/mce_record

?

The thing is, I'm not sure we want to make persistent events per-CPU
implicitly. If yes, then the second layout would fit better. Hmm.

> - I would make perf_add_persistent_on_cpu() static and create
> something like perf_add_persistent() which iterates all CPUs and
> creates: "%s-%04d", perf_event_desc::fname, cpu.

Ok.

> This needs a little extra for cpu-hotplug, not sure what to do there.

get/put_online_cpus()?

and then maybe check whether some of the CPUs are offline and warn if
so?

> - related to the first point, by not tying them to actual events
> you can create a persistent 'event' that contains multiple events.
> Its quite possible to create multiple kernel events and use the
> equivalent of PERF_EVENT_IOC_SET_OUTPUT on them to the exposed FD.

Hm, interesting.

So, in that case, the persistent thing would have a per-CPU buffer and
a file descriptor connected to it and one would be able to add events
which would log into the per-CPU buffer. Ok.

> - It might be good to provide means of changing the persistent
> event's buffer size, or maybe even 'destroy' persistent buffers.

ioctl? Or something else?

Thanks.

--
Regards/Gruss,
Boris.

Advanced Micro Devices GmbH
Einsteinring 24, 85609 Dornach
GM: Alberto Bozzo
Reg: Dornach, Landkreis Muenchen
HRB Nr. 43632 WEEE Registernr: 129 19551
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/