Commit 9d3bf4cd authored by Ezequiel Garcia's avatar Ezequiel Garcia Committed by Mauro Carvalho Chehab

media: vim2m: Remove unneeded buffer lock

This spinlock is used solely to call v4l2_m2m_buf_done().

Since buffers are obtained only after being removed
from the ready queue, there's no concurrent access, and
so no need for synchronization.

Remove the spinlock to make sure no one copies this pattern.

Some archaeology shows this is a small leftover from ancient code.
This driver (then called m2m_testdev) used the videobuf1 framework;
commit d80ee38c ("[media] v4l: mem2mem: port m2m_testdev to vb2")
converted it to videobuf2. The spinlock was then no longer needed,
and this simply went unnoticed.
Signed-off-by: default avatarEzequiel Garcia <ezequiel@collabora.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent e472d6a2
...@@ -216,7 +216,6 @@ struct vim2m_ctx { ...@@ -216,7 +216,6 @@ struct vim2m_ctx {
struct mutex vb_mutex; struct mutex vb_mutex;
struct delayed_work work_run; struct delayed_work work_run;
spinlock_t irqlock;
/* Abort requested by m2m */ /* Abort requested by m2m */
int aborting; int aborting;
...@@ -622,7 +621,6 @@ static void device_work(struct work_struct *w) ...@@ -622,7 +621,6 @@ static void device_work(struct work_struct *w)
struct vim2m_ctx *curr_ctx; struct vim2m_ctx *curr_ctx;
struct vim2m_dev *vim2m_dev; struct vim2m_dev *vim2m_dev;
struct vb2_v4l2_buffer *src_vb, *dst_vb; struct vb2_v4l2_buffer *src_vb, *dst_vb;
unsigned long flags;
curr_ctx = container_of(w, struct vim2m_ctx, work_run.work); curr_ctx = container_of(w, struct vim2m_ctx, work_run.work);
...@@ -638,10 +636,8 @@ static void device_work(struct work_struct *w) ...@@ -638,10 +636,8 @@ static void device_work(struct work_struct *w)
curr_ctx->num_processed++; curr_ctx->num_processed++;
spin_lock_irqsave(&curr_ctx->irqlock, flags);
v4l2_m2m_buf_done(src_vb, VB2_BUF_STATE_DONE); v4l2_m2m_buf_done(src_vb, VB2_BUF_STATE_DONE);
v4l2_m2m_buf_done(dst_vb, VB2_BUF_STATE_DONE); v4l2_m2m_buf_done(dst_vb, VB2_BUF_STATE_DONE);
spin_unlock_irqrestore(&curr_ctx->irqlock, flags);
if (curr_ctx->num_processed == curr_ctx->translen if (curr_ctx->num_processed == curr_ctx->translen
|| curr_ctx->aborting) { || curr_ctx->aborting) {
...@@ -1084,7 +1080,6 @@ static void vim2m_stop_streaming(struct vb2_queue *q) ...@@ -1084,7 +1080,6 @@ static void vim2m_stop_streaming(struct vb2_queue *q)
{ {
struct vim2m_ctx *ctx = vb2_get_drv_priv(q); struct vim2m_ctx *ctx = vb2_get_drv_priv(q);
struct vb2_v4l2_buffer *vbuf; struct vb2_v4l2_buffer *vbuf;
unsigned long flags;
cancel_delayed_work_sync(&ctx->work_run); cancel_delayed_work_sync(&ctx->work_run);
...@@ -1097,9 +1092,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q) ...@@ -1097,9 +1092,7 @@ static void vim2m_stop_streaming(struct vb2_queue *q)
return; return;
v4l2_ctrl_request_complete(vbuf->vb2_buf.req_obj.req, v4l2_ctrl_request_complete(vbuf->vb2_buf.req_obj.req,
&ctx->hdl); &ctx->hdl);
spin_lock_irqsave(&ctx->irqlock, flags);
v4l2_m2m_buf_done(vbuf, VB2_BUF_STATE_ERROR); v4l2_m2m_buf_done(vbuf, VB2_BUF_STATE_ERROR);
spin_unlock_irqrestore(&ctx->irqlock, flags);
} }
} }
...@@ -1226,7 +1219,6 @@ static int vim2m_open(struct file *file) ...@@ -1226,7 +1219,6 @@ static int vim2m_open(struct file *file)
ctx->fh.m2m_ctx = v4l2_m2m_ctx_init(dev->m2m_dev, ctx, &queue_init); ctx->fh.m2m_ctx = v4l2_m2m_ctx_init(dev->m2m_dev, ctx, &queue_init);
mutex_init(&ctx->vb_mutex); mutex_init(&ctx->vb_mutex);
spin_lock_init(&ctx->irqlock);
INIT_DELAYED_WORK(&ctx->work_run, device_work); INIT_DELAYED_WORK(&ctx->work_run, device_work);
if (IS_ERR(ctx->fh.m2m_ctx)) { if (IS_ERR(ctx->fh.m2m_ctx)) {
......
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