media: uvcvideo: Return -EACCES for Wrong state error
authorRicardo Ribalda <ribalda@chromium.org>
Tue, 3 Jan 2023 14:36:21 +0000 (15:36 +0100)
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Sun, 15 Jan 2023 21:45:12 +0000 (23:45 +0200)
Error 2 is defined by UVC as:

  Wrong State: The device is in a state that disallows the specific
  request. The device will remain in this state until a specific action
  from the host or the user is completed.

This is documented as happening when attempting to set the value of a
manual control when the device is in auto mode. While V4L2 allows this,
the closest error code defined by VIDIOC_S_CTRL is EACCES:

  EACCES: Attempt to set a read-only control or to get a write-only
  control. Or if there is an attempt to set an inactive control and the
  driver is not capable of caching the new value until the control is
  active again.

Replace EILSEQ with EACCES.

Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Suggested-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Ricardo Ribalda <ribalda@chromium.org>
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
drivers/media/usb/uvc/uvc_video.c

index f35674fb89124939d8d0e27d32dbc9f679bb1373..3d3753a4c1f84b3bee848b99a1b9d1e0f1d22ac4 100644 (file)
@@ -108,7 +108,7 @@ int uvc_query_ctrl(struct uvc_device *dev, u8 query, u8 unit,
        case 1: /* Not ready */
                return -EBUSY;
        case 2: /* Wrong state */
-               return -EILSEQ;
+               return -EACCES;
        case 3: /* Power */
                return -EREMOTE;
        case 4: /* Out of range */