Re: [PATCH] v4l2-dev: Add tracepoints for QBUF and DQBUF

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hans,

Em Wed, 11 Dec 2013 08:29:58 +0100
Hans Verkuil <hverkuil@xxxxxxxxx> escreveu:

> On 12/10/2013 09:53 PM, Mauro Carvalho Chehab wrote:
> > Em Sat, 23 Nov 2013 17:54:48 +0100
> > Hans Verkuil <hverkuil@xxxxxxxxx> escreveu:
> > 
> >> On 11/23/2013 05:30 PM, Sylwester Nawrocki wrote:
> >>> Hi,
> >>>
> >>> On 11/23/2013 12:25 PM, Hans Verkuil wrote:
> >>>> Hi Wade,
> >>>>
> >>>> On 11/22/2013 08:48 PM, Wade Farnsworth wrote:
> >>>>> Add tracepoints to the QBUF and DQBUF ioctls to enable rudimentary
> >>>>> performance measurements using standard kernel tracers.
> >>>>>
> >>>>> Signed-off-by: Wade Farnsworth<wade_farnsworth@xxxxxxxxxx>
> >>>>> ---
> >>>>>
> >>>>> This is the update to the RFC patch I posted a few weeks back.  I've added
> >>>>> several bits of metadata to the tracepoint output per Mauro's suggestion.
> >>>>
> >>>> I don't like this. All v4l2 ioctls can already be traced by doing e.g.
> >>>> echo 1 (or echo 2)>/sys/class/video4linux/video0/debug.
> >>>>
> >>>> So this code basically duplicates that functionality. It would be nice to be able
> >>>> to tie in the existing tracing code (v4l2-ioctl.c) into tracepoints.
> >>>
> >>> I think it would be really nice to have this kind of support for standard
> >>> traces at the v4l2 subsystem. Presumably it could even gradually replace
> >>> the v4l2 custom debug infrastructure.
> >>>
> >>> If I understand things correctly, the current tracing/profiling 
> >>> infrastructure
> >>> is much less invasive than inserting printks all over, which may cause 
> >>> changes
> >>> in control flow. I doubt the system could be reliably profiled by 
> >>> enabling all
> >>> those debug prints.
> >>>
> >>> So my vote would be to add support for standard tracers, like in other
> >>> subsystems in the kernel.
> >>
> >> The reason for the current system is to trace which ioctls are called in
> >> what order by a misbehaving application. It's very useful for that,
> >> especially when trying to debug user problems.
> >>
> >> I don't mind switching to tracepoints as long as this functionality is
> >> kept one way or another.
> > 
> > I agree with Sylwester: we should move to tracepoints, and this is a good
> > start.
> 
> As I mentioned, I don't mind switching to tracepoints, but not in the way the
> current patch does it. I certainly don't agree with you merging this patch
> as-is without further discussion.

Let's not mix the subjects here. There are two different demands that can be
either fulfilled by the same solution or by different ones:
	1) To have a way to enable debugging all parameters passed from/to
userspace;
	2) To be able to measure the driver (and core) performance while
streaming.

This patch's scope is to solve (2), by allowing userspace to hook the two
ioctls that queues/dequeues streaming buffers.

With that regards, what's wrong on this patch? I couldn't see anything bad
there. It is not meant to solve (1).

Before this patch, all we have is (1), as a non-dynamic printk is too
intrusive to be used for performance measurement. So, there's no way to
measure how much time a buffer takes to be filled.

In a matter of fact, in the case you didn't noticed, we are already somewhat
moving to traces, as several drivers are now using dynamic_printk for debug 
messages, Yet, lots of drivers still use either their own normal
printk-based debug macros.

Now, you're proposing to use the same solution for (1) too. 

Ok, we can go on that direction, but this is a separate issue. Converting
the v4l2-ioctl to use tracepoints is the easiest part. However, there are
several things to consider, if we decide to use it for debug purposes:

a) It will likely require to convert all printks to dynamic ones, as we
want to have all debug messages serialized.

Let me explain it better: if some debug messages come via the standard 
printk mechanism while others come via traces, we loose the capability
of receiving the messages at the same order that they were produced, and
it could be harder if not impossible to synchronize them into the right
order.

b) It may make sense to write an userspace tool similar to the rasdaemon
[1] to allow controlling the debug output. That tool directly reads the
events from the raw tracing queues, formatting the data on userspace and
hooking only the events that are needed. 

Currently, the rasdaemon has inside part of the code used by a perf
tool copied on it (as this code is not inside any library yet). However,
that code is being prepared to be used as a library. So, it should be
even easier to write such tool in a near future.

[1] https://git.fedorahosted.org/cgit/rasdaemon.git/

c) I don't think that tracepoints are the right mechanism for a post-mortem
analysis[2]. E. g. if the Kernel crashes, a printk-based mechanism will 
output something, but I'm not sure if doing the same is possible with traces
(e. g. forcing the trace messages to go to to tty).

You should notice that, with the dynamic_printk macros, it is possible to
compile the Kernel to use normal printk macros for debug macros.

However, if we convert the ioctl printk's to tracepoints, we may still
need to have a fallback printk mechanism for ioctl debug messages.

[2] There are actually some discussions at the RAS mailing lists about
how to store the tracing data and printk messages on newer hardware that
offer a non-volatile memory mechanism for that. So, we might actually
have a post-mortem mechanism for tracepoints in the future, depending on
the hardware. Yet, not all types of hardware will have such NVRAM.

Btw, it is possible to use strace to trace all ioctl's. So, the existing
mechanism is actually a duplicated feature, as userspace already covers it.
However, in practice, we opted to explicitly duplicate that feature at
Kernel level, for debugging purposes, because strace doesn't solve (a)
and (c).

What I'm saying is that a project to convert the debug facility into
tracepoints is something that:
	- it is independent of adding some facility for performance 
	  measurement (although it may share the same infrastructure);

	- it will require lots of effort to change every single driver
	  to use dynamic printk's;

	- it may require writing a helper tool to enable just the v4l2
	  traces and eventually collect them;

	- it may require a fallback printk mechanism in order to debug
	  kernel panic.

> To make it official:
> 
> Nacked-by: Hans Verkuil <hans.verkuil@xxxxxxxxx>
> 
> If we do tracepoints, then we do it right and for all ioctls, not in this
> half-baked manner.
> 
> Please revert.

Let's not mix things. If this patch is correct and solves for performance
measurement, I don't see any reason to revert.

Using tracepoints for debug is a separate and independent project.

Such project require lots of tests to proof that it is a viable solution,
several discussions and a huge time frame to convert all drivers to use
tracepoints too, plus some post-mortem debug logic.

Regards,
Mauro
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux