Commit 34b41472 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

media: media-request: return -EINVAL for invalid request_fds

Instead of returning -ENOENT when a request_fd was not found (VIDIOC_QBUF
and VIDIOC_G/S/TRY_EXT_CTRLS), we now return -EINVAL. This is in line
with what we do when invalid dmabuf fds are passed to e.g. VIDIOC_QBUF.

Also document that EINVAL is returned for invalid m.fd values, we never
documented that.
Signed-off-by: default avatarHans Verkuil <hansverk@cisco.com>
Reviewed-by: default avatarTomasz Figa <tfiga@chromium.org>
Acked-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+samsung@kernel.org>
parent 757fdb51
...@@ -313,8 +313,8 @@ struct v4l2_buffer ...@@ -313,8 +313,8 @@ struct v4l2_buffer
queued to that request. This is set by the user when calling queued to that request. This is set by the user when calling
:ref:`ioctl VIDIOC_QBUF <VIDIOC_QBUF>` and ignored by other ioctls. :ref:`ioctl VIDIOC_QBUF <VIDIOC_QBUF>` and ignored by other ioctls.
If the device does not support requests, then ``EPERM`` will be returned. If the device does not support requests, then ``EPERM`` will be returned.
If requests are supported but an invalid request FD is given, then If requests are supported but an invalid request file descriptor is
``ENOENT`` will be returned. given, then ``EINVAL`` will be returned.
......
...@@ -101,8 +101,8 @@ then the controls are not applied immediately when calling ...@@ -101,8 +101,8 @@ then the controls are not applied immediately when calling
:ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>`, but instead are applied by :ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>`, but instead are applied by
the driver for the buffer associated with the same request. the driver for the buffer associated with the same request.
If the device does not support requests, then ``EPERM`` will be returned. If the device does not support requests, then ``EPERM`` will be returned.
If requests are supported but an invalid request FD is given, then If requests are supported but an invalid request file descriptor is given,
``ENOENT`` will be returned. then ``EINVAL`` will be returned.
An attempt to call :ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` for a An attempt to call :ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` for a
request that has already been queued will result in an ``EBUSY`` error. request that has already been queued will result in an ``EBUSY`` error.
...@@ -301,8 +301,8 @@ still cause this situation. ...@@ -301,8 +301,8 @@ still cause this situation.
- File descriptor of the request to be used by this operation. Only - File descriptor of the request to be used by this operation. Only
valid if ``which`` is set to ``V4L2_CTRL_WHICH_REQUEST_VAL``. valid if ``which`` is set to ``V4L2_CTRL_WHICH_REQUEST_VAL``.
If the device does not support requests, then ``EPERM`` will be returned. If the device does not support requests, then ``EPERM`` will be returned.
If requests are supported but an invalid request FD is given, then If requests are supported but an invalid request file descriptor is
``ENOENT`` will be returned. given, then ``EINVAL`` will be returned.
* - __u32 * - __u32
- ``reserved``\ [1] - ``reserved``\ [1]
- Reserved for future extensions. - Reserved for future extensions.
...@@ -378,11 +378,13 @@ appropriately. The generic error codes are described at the ...@@ -378,11 +378,13 @@ appropriately. The generic error codes are described at the
EINVAL EINVAL
The struct :c:type:`v4l2_ext_control` ``id`` is The struct :c:type:`v4l2_ext_control` ``id`` is
invalid, the struct :c:type:`v4l2_ext_controls` invalid, or the struct :c:type:`v4l2_ext_controls`
``which`` is invalid, or the struct ``which`` is invalid, or the struct
:c:type:`v4l2_ext_control` ``value`` was :c:type:`v4l2_ext_control` ``value`` was
inappropriate (e.g. the given menu index is not supported by the inappropriate (e.g. the given menu index is not supported by the
driver). This error code is also returned by the driver), or the ``which`` field was set to ``V4L2_CTRL_WHICH_REQUEST_VAL``
but the given ``request_fd`` was invalid.
This error code is also returned by the
:ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` and :ref:`VIDIOC_TRY_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` ioctls if two or :ref:`VIDIOC_S_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` and :ref:`VIDIOC_TRY_EXT_CTRLS <VIDIOC_G_EXT_CTRLS>` ioctls if two or
more control values are in conflict. more control values are in conflict.
...@@ -409,7 +411,3 @@ EACCES ...@@ -409,7 +411,3 @@ EACCES
EPERM EPERM
The ``which`` field was set to ``V4L2_CTRL_WHICH_REQUEST_VAL`` but the The ``which`` field was set to ``V4L2_CTRL_WHICH_REQUEST_VAL`` but the
device does not support requests. device does not support requests.
ENOENT
The ``which`` field was set to ``V4L2_CTRL_WHICH_REQUEST_VAL`` but the
the given ``request_fd`` was invalid.
...@@ -105,8 +105,8 @@ until the request itself is queued. Also, the driver will apply any ...@@ -105,8 +105,8 @@ until the request itself is queued. Also, the driver will apply any
settings associated with the request for this buffer. This field will settings associated with the request for this buffer. This field will
be ignored unless the ``V4L2_BUF_FLAG_REQUEST_FD`` flag is set. be ignored unless the ``V4L2_BUF_FLAG_REQUEST_FD`` flag is set.
If the device does not support requests, then ``EPERM`` will be returned. If the device does not support requests, then ``EPERM`` will be returned.
If requests are supported but an invalid request FD is given, then If requests are supported but an invalid request file descriptor is given,
``ENOENT`` will be returned. then ``EINVAL`` will be returned.
.. caution:: .. caution::
It is not allowed to mix queuing requests with queuing buffers directly. It is not allowed to mix queuing requests with queuing buffers directly.
...@@ -152,7 +152,9 @@ EAGAIN ...@@ -152,7 +152,9 @@ EAGAIN
EINVAL EINVAL
The buffer ``type`` is not supported, or the ``index`` is out of The buffer ``type`` is not supported, or the ``index`` is out of
bounds, or no buffers have been allocated yet, or the ``userptr`` or bounds, or no buffers have been allocated yet, or the ``userptr`` or
``length`` are invalid. ``length`` are invalid, or the ``V4L2_BUF_FLAG_REQUEST_FD`` flag was
set but the the given ``request_fd`` was invalid, or ``m.fd`` was
an invalid DMABUF file descriptor.
EIO EIO
``VIDIOC_DQBUF`` failed due to an internal error. Can also indicate ``VIDIOC_DQBUF`` failed due to an internal error. Can also indicate
...@@ -179,7 +181,3 @@ EPERM ...@@ -179,7 +181,3 @@ EPERM
the application now tries to queue it directly, or vice versa (it is the application now tries to queue it directly, or vice versa (it is
not permitted to mix the two APIs). Or an attempt is made to queue a not permitted to mix the two APIs). Or an attempt is made to queue a
CAPTURE buffer to a request for a :ref:`memory-to-memory device <codec>`. CAPTURE buffer to a request for a :ref:`memory-to-memory device <codec>`.
ENOENT
The ``V4L2_BUF_FLAG_REQUEST_FD`` flag was set but the the given
``request_fd`` was invalid.
...@@ -244,7 +244,7 @@ media_request_get_by_fd(struct media_device *mdev, int request_fd) ...@@ -244,7 +244,7 @@ media_request_get_by_fd(struct media_device *mdev, int request_fd)
filp = fget(request_fd); filp = fget(request_fd);
if (!filp) if (!filp)
return ERR_PTR(-ENOENT); goto err_no_req_fd;
if (filp->f_op != &request_fops) if (filp->f_op != &request_fops)
goto err_fput; goto err_fput;
...@@ -268,7 +268,9 @@ media_request_get_by_fd(struct media_device *mdev, int request_fd) ...@@ -268,7 +268,9 @@ media_request_get_by_fd(struct media_device *mdev, int request_fd)
err_fput: err_fput:
fput(filp); fput(filp);
return ERR_PTR(-ENOENT); err_no_req_fd:
dev_dbg(mdev->dev, "cannot find request_fd %d\n", request_fd);
return ERR_PTR(-EINVAL);
} }
EXPORT_SYMBOL_GPL(media_request_get_by_fd); EXPORT_SYMBOL_GPL(media_request_get_by_fd);
......
...@@ -153,7 +153,7 @@ void media_request_put(struct media_request *req); ...@@ -153,7 +153,7 @@ void media_request_put(struct media_request *req);
* by the media device. * by the media device.
* *
* Return a -EPERM error pointer if requests are not supported * Return a -EPERM error pointer if requests are not supported
* by this driver. Return -ENOENT if the request was not found. * by this driver. Return -EINVAL if the request was not found.
* Return the pointer to the request if found: the caller will * Return the pointer to the request if found: the caller will
* have to call @media_request_put when it finished using the * have to call @media_request_put when it finished using the
* request. * request.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment