Re: perf overlapping maps...
From: David Miller
Date: Tue Oct 23 2018 - 14:15:07 EST
From: Arnaldo Carvalho de Melo <acme@xxxxxxxxxx>
Date: Tue, 23 Oct 2018 15:05:03 -0300
> IIRC this was first done for 'perf record', where we have to stash those
> events in the perf.data file, to then, later, 'perf report' to process
> those, so when working on 'perf top', it just reuses that machinery.
>
> Sure, with some love and care 'perf top' could do better and update all
> the data structures directly :-)
Thanks for the history, it is useful information :)
> Anyway, have you guys considered tweaking using event->header.misc |=
> PERF_RECORD_MISC_USER? The kernel leaves that as zero for the
> PERF_RECORD_FORK it emits:
I really would like to steer the approach away from using UAPI
perf_event fields in an internal way.
I am really very sorry for suggesting such a scheme myself in the
first place. It really was a bad idea upon much consideration.
The synthetic fork is not really a fork, it's more like a "create".
And this fundamental semantic difference is why we have all of these
issues wrt. handling COMM and parent map inheritance.
There is also a bunch of non-trivial code to deal with whether we
synthetically create the child or the parent first, wrt. finding
thread leaders and parent threads.
What I'm trying to say is that there is a clean design based solution
hiding somewhere in here and I'd like to find it :-)