From: Ingo Molnar <mingo@kernel.org>
To: Pawel Moll <pawel.moll@arm.com>
Cc: Ingo Molnar <mingo@redhat.com>,
Arnaldo Carvalho de Melo <acme@kernel.org>,
Richard Cochran <richardcochran@gmail.com>,
Steven Rostedt <rostedt@goodmis.org>,
Peter Zijlstra <peterz@infradead.org>,
Paul Mackerras <paulus@samba.org>,
John Stultz <john.stultz@linaro.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"linux-api@vger.kernel.org" <linux-api@vger.kernel.org>
Subject: Re: [PATCH 2/2] perf: Userspace software event and ioctl
Date: Thu, 25 Sep 2014 20:33:43 +0200 [thread overview]
Message-ID: <20140925183342.GB6854@gmail.com> (raw)
In-Reply-To: <1411665649.4768.84.camel@hornet>
* Pawel Moll <pawel.moll@arm.com> wrote:
> On Wed, 2014-09-24 at 08:49 +0100, Ingo Molnar wrote:
> > * Pawel Moll <pawel.moll@arm.com> wrote:
> >
> > > On Thu, 2014-09-18 at 15:34 +0100, Pawel Moll wrote:
> > > > This patch adds a PERF_COUNT_SW_USERSPACE_EVENT type,
> > > > which can be generated by user with PERF_EVENT_IOC_ENTRY
> > > > ioctl command, which injects an event of said type into
> > > > the perf buffer.
> > >
> > > It occurred to me last night that currently perf doesn't handle "write"
> > > syscall at all, while this seems like the most natural way of
> > > "injecting" userspace events into perf buffer.
> > >
> > > An ioctl would still be needed to set a type of the following events,
> > > something like:
> > >
> > > ioctl(SET_TYPE, 0x42);
> > > write(perf_fd, binaryblob, size);
> > > ioctl(SET_TYPE, 0);
> > > dprintf(perf_fd, "String");
> > >
> > > which is fine for use cases when the type doesn't change often,
> > > but would double the amount of syscalls when every single event
> > > is of a different type. Perhaps there still should be a
> > > "generating ioctl" taking both type and data/size in one go?
> >
> > Absolutely, there should be a single syscall.
>
> Yeah, it's my gut feeling as well. I just wonder if we still want to
> keep write() handler for operations on perf fds? This seems natural -
> takes data buffer and its size. The only issue is the type.
>
> > I'd even argue it should be a new prctl(): that way we could both
> > generate user events for specific perf fds, but also into any
> > currently active context (that allows just generation/injection
> > of user events). In the latter case we might have no fd to work
> > off from.
>
> When Arnaldo suggested that the "user events" could be used by perf
> trace, it was exactly my first thought. I just didn't have answer how to
> present it to the user (an extra syscall didn't seem like a good idea),
> but prctl seems interesting, something like this?
>
> prctl(PR_TRACE_UEVENT, type, size, data, 0);
Exactly!
> How would we select tasks that can write to a given buffer? Maybe an
> ioctl() on a perf fd? Something like this?
>
> ioctl(perf_fd, PERF_EVENT_IOC_ENABLE_UEVENT, pid);
> ioctl(perf_fd, PERF_EVENT_IOC_DISABLE_UEVENT, pid);
No, I think there's a simpler way: this should be a regular
perf_attr flag, which defaults to '0' (tasks cannot do this), but
which can be set to 1 if the profiler explicitly allows such
event injection.
perf-trace might want to set this flag by default.
I.e. whether user-events are allowed is controlled by the
profiling/tracing context, via the regular perf syscall. It would
propagate into the perf context, so it would be easy to check at
event generation time.
Thanks,
Ingo
next prev parent reply other threads:[~2014-09-25 18:33 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-09-18 14:34 [PATCH 0/2] perf: User/kernel time correlation and event generation Pawel Moll
2014-09-18 14:34 ` [PATCH 1/2] perf: Add sampling of the raw monotonic clock Pawel Moll
2014-09-29 15:28 ` Peter Zijlstra
2014-09-29 15:45 ` Pawel Moll
2014-09-18 14:34 ` [PATCH 2/2] perf: Userspace software event and ioctl Pawel Moll
2014-09-23 17:02 ` Pawel Moll
2014-09-24 7:49 ` Ingo Molnar
2014-09-25 17:20 ` Pawel Moll
2014-09-25 18:33 ` Ingo Molnar [this message]
2014-09-26 10:48 ` Pawel Moll
2014-09-26 11:23 ` Ingo Molnar
2014-09-26 11:26 ` Pawel Moll
2014-09-26 11:31 ` Ingo Molnar
2014-09-27 17:14 ` Frederic Weisbecker
2014-09-29 14:52 ` Pawel Moll
2014-09-29 15:32 ` Peter Zijlstra
2014-09-29 15:53 ` Pawel Moll
2014-11-03 14:48 ` Tomeu Vizoso
2014-11-03 15:04 ` Pawel Moll
2014-09-18 15:02 ` [PATCH 0/2] perf: User/kernel time correlation and event generation Christopher Covington
2014-09-18 15:07 ` Pawel Moll
2014-09-18 15:48 ` Christopher Covington
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140925183342.GB6854@gmail.com \
--to=mingo@kernel.org \
--cc=acme@kernel.org \
--cc=john.stultz@linaro.org \
--cc=linux-api@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@redhat.com \
--cc=paulus@samba.org \
--cc=pawel.moll@arm.com \
--cc=peterz@infradead.org \
--cc=richardcochran@gmail.com \
--cc=rostedt@goodmis.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox