From: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
To: Hans Verkuil <hverkuil@xs4all.nl>,
Linux Media Mailing List <linux-media@vger.kernel.org>
Subject: Re: [PATCH] DocBook/media: fix querycap error code
Date: Mon, 18 May 2015 16:17:51 -0300 [thread overview]
Message-ID: <20150518161751.57127058@recife.lan> (raw)
In-Reply-To: <5549B63F.7020009@xs4all.nl>
Em Wed, 06 May 2015 08:35:43 +0200
Hans Verkuil <hverkuil@xs4all.nl> escreveu:
> The most likely error you will get when calling VIDIOC_QUERYCAP for a
> device node that does not support it is ENOTTY, not EINVAL.
>
> Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
> ---
> Documentation/DocBook/media/v4l/vidioc-querycap.xml | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/Documentation/DocBook/media/v4l/vidioc-querycap.xml b/Documentation/DocBook/media/v4l/vidioc-querycap.xml
> index 20fda75..131abca 100644
> --- a/Documentation/DocBook/media/v4l/vidioc-querycap.xml
> +++ b/Documentation/DocBook/media/v4l/vidioc-querycap.xml
> @@ -54,7 +54,7 @@ kernel devices compatible with this specification and to obtain
> information about driver and hardware capabilities. The ioctl takes a
> pointer to a &v4l2-capability; which is filled by the driver. When the
> driver is not compatible with this specification the ioctl returns an
> -&EINVAL;.</para>
> +error, most likely the &ENOTTY;.</para>
Hmm... "likely"...
This is not nice... This is an specification. It should properly define
the error code, and not let the user to guess.
This should be, instead:
"All V4L2 drivers should support VIDIOC_QUERYCAP."
The Documentation already points to to the generic error codes,
with would actually happen only in the case something goes deadly wrong.
There are very few error codes that could actually happen on this point,
like EFAULT, if, for some reason, the Kernel fails to copy data to
userspace, or ENODEV is a device got removed.
Of course, if onse sends this ioctl to a non-v4l2 device, an error
code will be returned, but the actual error code will depend on the
device where this is sent, as, except if one janitor did a huge
changeset fixing this, I'm almost sure that not all devices will
return ENOTTY when an ioctl is not implemented.
Yet, for userspace, it is safe to assume that, if VIDIOC_QUERYCAP
fails, either the device is not V4L2 or the V4L2 device won't work
anyway, as there's something really broken there.
Regards,
Mauro
>
> <table pgwide="1" frame="none" id="v4l2-capability">
> <title>struct <structname>v4l2_capability</structname></title>
next prev parent reply other threads:[~2015-05-18 19:17 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-05-06 6:35 [PATCH] DocBook/media: fix querycap error code Hans Verkuil
2015-05-18 19:17 ` Mauro Carvalho Chehab [this message]
2015-05-19 6:29 ` Hans Verkuil
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=20150518161751.57127058@recife.lan \
--to=mchehab@osg.samsung.com \
--cc=hverkuil@xs4all.nl \
--cc=linux-media@vger.kernel.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