@@ -195,6 +195,7 @@ static long media_device_request_cmd(struct media_device *mdev,
{
struct media_device_fh *fh = media_device_fh(filp);
struct media_device_request *req = NULL;
+ unsigned long flags;
int ret;
if (!mdev->ops || !mdev->ops->req_alloc || !mdev->ops->req_free)
@@ -212,8 +213,17 @@ static long media_device_request_cmd(struct media_device *mdev,
break;
case MEDIA_REQ_CMD_DELETE:
- media_device_request_delete(mdev, req);
- ret = 0;
+ spin_lock_irqsave(&mdev->req_lock, flags);
+ if (req->state == MEDIA_DEVICE_REQUEST_STATE_IDLE) {
+ ret = 0;
+ req->state = MEDIA_DEVICE_REQUEST_STATE_DELETED;
+ } else {
+ ret = -EINVAL;
+ }
+ spin_unlock_irqrestore(&mdev->req_lock, flags);
+
+ if (!ret)
+ media_device_request_delete(mdev, req);
break;
case MEDIA_REQ_CMD_APPLY:
@@ -268,6 +268,7 @@ struct media_device;
enum media_device_request_state {
MEDIA_DEVICE_REQUEST_STATE_IDLE,
MEDIA_DEVICE_REQUEST_STATE_QUEUED,
+ MEDIA_DEVICE_REQUEST_STATE_DELETED,
};
/**
Prevent deleting queued requests. Also mark deleted requests as such by adding a new state for them. Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com> --- drivers/media/media-device.c | 14 ++++++++++++-- include/media/media-device.h | 1 + 2 files changed, 13 insertions(+), 2 deletions(-)