Re: [PATCH RFCv3 03/17] [media] DocBook: Use the generic error code page also for MC API

From: Hans Verkuil
Date: Thu Jul 07 2011 - 13:29:09 EST


On Thursday, July 07, 2011 19:15:24 Mauro Carvalho Chehab wrote:
> Em 07-07-2011 12:29, Hans Verkuil escreveu:
> > On Wednesday, July 06, 2011 20:03:52 Mauro Carvalho Chehab wrote:
> >> Instead of having their own generic error codes at the MC API, move
> >> its section to the generic one and be sure that all media ioctl's
> >> will point to it.
> >>
> >> Signed-off-by: Mauro Carvalho Chehab <mchehab@xxxxxxxxxx>
> >>
> >> diff --git a/Documentation/DocBook/media/v4l/gen-errors.xml b/Documentation/DocBook/media/v4l/gen-errors.xml
> >> index 6ef476a..a7f73c9 100644
> >> --- a/Documentation/DocBook/media/v4l/gen-errors.xml
> >> +++ b/Documentation/DocBook/media/v4l/gen-errors.xml
> >> @@ -5,6 +5,11 @@
> >> <tgroup cols="2">
> >> &cs-str;
> >> <tbody valign="top">
> >> + <!-- Keep it ordered alphabetically -->
> >> + <row>
> >> + <entry>EBADF</entry>
> >> + <entry><parameter>fd</parameter> is not a valid open file descriptor.</entry>
> >> + </row>
> >> <row>
> >> <entry>EBUSY</entry>
> >> <entry>The ioctl can't be handled because the device is busy. This is
> >> @@ -15,7 +20,16 @@
> >> problem first (typically: stop the stream before retrying).</entry>
> >> </row>
> >> <row>
> >> + <entry>EFAULT</entry>
> >> + <entry><parameter>fd</parameter> is not a valid open file descriptor.</entry>
> >
> > This seems to be a copy-and-paste error. The original text in media-func-ioctl.xml says this:
> >
> > <para><parameter>argp</parameter> references an inaccessible memory
> > area.</para>
>
> Ah, yes. Anyway, a latter patch changes it to:

OK, I missed that. It was a bit confusing to review.

>
> <entry>EFAULT</entry>
> <entry>There was a failure while copying data from/to userspace.</entry>
> </row>
>
> referencing a parameter name there is a bad thing anyway, as this is now at the common
> ioctl error code.
>
> Instead of just using a posix-like error code:
> EFAULT Bad address (POSIX.1)
>
> I opted to use a more valuable description, explaining the reason for such error,
> e. g. that there was a failure at the data copy from/to userspace.
>
> It may be better to change it to:
>
> <entry>EFAULT</entry>
> <entry>There was a failure while copying data from/to userspace, probably
> caused by an invalid pointer reference.</entry>
>
> I think I'll add the above description at the latter patch.
>
> I was intending to add there the other possible error causes found at V4L/DVB API's
> and drivers, but the changes I did took me a longer time than I was expecting
> originally. I'll eventually do that when I have more time.
>
> It would be really great if we could find some volunteer to help syncing
> the media API specs with the code.
>
> >> + </row>
> >> + <row>
> >> <entry>EINVAL</entry>
> >> + <entry>One or more of the ioctl parameters are invalid. This is a widely
> >
> > widely -> widely used
> >
> >> + error code. see the individual ioctl requests for actual causes.</entry>
> >
> > see -> See
>
> Fixed.

OK, with these changes you have my

Acked-by: Hans Verkuil <hans.verkuil@xxxxxxxxx>

as well for this patch.

Just for my understanding: do you plan on merging this for 3.1? I have no objection to
that. Together with the querycap version changes it is easy to add compatibility support
to libv4l should that be necessary. I'm not convinced there won't be any fallout from
this change, but at least there is a decent way of working around it if needed. And there
is no doubt that -ENOTTY is a much better return code.

When this is merged I'll modify v4l2-compliance, v4l2-ctl (if necessary) and qv4l2.

Regards,

Hans
--
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/