提交 152ea1c8 编写于 作者: P Philipp Zabel 提交者: Mauro Carvalho Chehab

[media] coda: Use mem-to-mem ioctl helpers

Use the mem2mem helpers introduced to get rid of some duplicated code.
Signed-off-by: NPhilipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: NKamil Debski <k.debski@samsung.com>
Signed-off-by: NMauro Carvalho Chehab <m.chehab@samsung.com>
上级 32b6f206
...@@ -778,22 +778,6 @@ static int coda_s_fmt_vid_out(struct file *file, void *priv, ...@@ -778,22 +778,6 @@ static int coda_s_fmt_vid_out(struct file *file, void *priv,
return ret; return ret;
} }
static int coda_reqbufs(struct file *file, void *priv,
struct v4l2_requestbuffers *reqbufs)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
return v4l2_m2m_reqbufs(file, ctx->m2m_ctx, reqbufs);
}
static int coda_querybuf(struct file *file, void *priv,
struct v4l2_buffer *buf)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
return v4l2_m2m_querybuf(file, ctx->m2m_ctx, buf);
}
static int coda_qbuf(struct file *file, void *priv, static int coda_qbuf(struct file *file, void *priv,
struct v4l2_buffer *buf) struct v4l2_buffer *buf)
{ {
...@@ -802,14 +786,6 @@ static int coda_qbuf(struct file *file, void *priv, ...@@ -802,14 +786,6 @@ static int coda_qbuf(struct file *file, void *priv,
return v4l2_m2m_qbuf(file, ctx->m2m_ctx, buf); return v4l2_m2m_qbuf(file, ctx->m2m_ctx, buf);
} }
static int coda_expbuf(struct file *file, void *priv,
struct v4l2_exportbuffer *eb)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
return v4l2_m2m_expbuf(file, ctx->m2m_ctx, eb);
}
static bool coda_buf_is_end_of_stream(struct coda_ctx *ctx, static bool coda_buf_is_end_of_stream(struct coda_ctx *ctx,
struct v4l2_buffer *buf) struct v4l2_buffer *buf)
{ {
...@@ -842,40 +818,6 @@ static int coda_dqbuf(struct file *file, void *priv, ...@@ -842,40 +818,6 @@ static int coda_dqbuf(struct file *file, void *priv,
return ret; return ret;
} }
static int coda_create_bufs(struct file *file, void *priv,
struct v4l2_create_buffers *create)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
return v4l2_m2m_create_bufs(file, ctx->m2m_ctx, create);
}
static int coda_streamon(struct file *file, void *priv,
enum v4l2_buf_type type)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
return v4l2_m2m_streamon(file, ctx->m2m_ctx, type);
}
static int coda_streamoff(struct file *file, void *priv,
enum v4l2_buf_type type)
{
struct coda_ctx *ctx = fh_to_ctx(priv);
int ret;
/*
* This indirectly calls __vb2_queue_cancel, which dequeues all buffers.
* We therefore have to lock it against running hardware in this context,
* which still needs the buffers.
*/
mutex_lock(&ctx->buffer_mutex);
ret = v4l2_m2m_streamoff(file, ctx->m2m_ctx, type);
mutex_unlock(&ctx->buffer_mutex);
return ret;
}
static int coda_g_selection(struct file *file, void *fh, static int coda_g_selection(struct file *file, void *fh,
struct v4l2_selection *s) struct v4l2_selection *s)
{ {
...@@ -987,16 +929,16 @@ static const struct v4l2_ioctl_ops coda_ioctl_ops = { ...@@ -987,16 +929,16 @@ static const struct v4l2_ioctl_ops coda_ioctl_ops = {
.vidioc_try_fmt_vid_out = coda_try_fmt_vid_out, .vidioc_try_fmt_vid_out = coda_try_fmt_vid_out,
.vidioc_s_fmt_vid_out = coda_s_fmt_vid_out, .vidioc_s_fmt_vid_out = coda_s_fmt_vid_out,
.vidioc_reqbufs = coda_reqbufs, .vidioc_reqbufs = v4l2_m2m_ioctl_reqbufs,
.vidioc_querybuf = coda_querybuf, .vidioc_querybuf = v4l2_m2m_ioctl_querybuf,
.vidioc_qbuf = coda_qbuf, .vidioc_qbuf = coda_qbuf,
.vidioc_expbuf = coda_expbuf, .vidioc_expbuf = v4l2_m2m_ioctl_expbuf,
.vidioc_dqbuf = coda_dqbuf, .vidioc_dqbuf = coda_dqbuf,
.vidioc_create_bufs = coda_create_bufs, .vidioc_create_bufs = v4l2_m2m_ioctl_create_bufs,
.vidioc_streamon = coda_streamon, .vidioc_streamon = v4l2_m2m_ioctl_streamon,
.vidioc_streamoff = coda_streamoff, .vidioc_streamoff = v4l2_m2m_ioctl_streamoff,
.vidioc_g_selection = coda_g_selection, .vidioc_g_selection = coda_g_selection,
...@@ -1675,18 +1617,6 @@ static void coda_buf_queue(struct vb2_buffer *vb) ...@@ -1675,18 +1617,6 @@ static void coda_buf_queue(struct vb2_buffer *vb)
} }
} }
static void coda_wait_prepare(struct vb2_queue *q)
{
struct coda_ctx *ctx = vb2_get_drv_priv(q);
coda_unlock(ctx);
}
static void coda_wait_finish(struct vb2_queue *q)
{
struct coda_ctx *ctx = vb2_get_drv_priv(q);
coda_lock(ctx);
}
static void coda_parabuf_write(struct coda_ctx *ctx, int index, u32 value) static void coda_parabuf_write(struct coda_ctx *ctx, int index, u32 value)
{ {
struct coda_dev *dev = ctx->dev; struct coda_dev *dev = ctx->dev;
...@@ -2648,10 +2578,10 @@ static struct vb2_ops coda_qops = { ...@@ -2648,10 +2578,10 @@ static struct vb2_ops coda_qops = {
.queue_setup = coda_queue_setup, .queue_setup = coda_queue_setup,
.buf_prepare = coda_buf_prepare, .buf_prepare = coda_buf_prepare,
.buf_queue = coda_buf_queue, .buf_queue = coda_buf_queue,
.wait_prepare = coda_wait_prepare,
.wait_finish = coda_wait_finish,
.start_streaming = coda_start_streaming, .start_streaming = coda_start_streaming,
.stop_streaming = coda_stop_streaming, .stop_streaming = coda_stop_streaming,
.wait_prepare = vb2_ops_wait_prepare,
.wait_finish = vb2_ops_wait_finish,
}; };
static int coda_s_ctrl(struct v4l2_ctrl *ctrl) static int coda_s_ctrl(struct v4l2_ctrl *ctrl)
...@@ -2774,6 +2704,7 @@ static int coda_queue_init(void *priv, struct vb2_queue *src_vq, ...@@ -2774,6 +2704,7 @@ static int coda_queue_init(void *priv, struct vb2_queue *src_vq,
src_vq->ops = &coda_qops; src_vq->ops = &coda_qops;
src_vq->mem_ops = &vb2_dma_contig_memops; src_vq->mem_ops = &vb2_dma_contig_memops;
src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY; src_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
src_vq->lock = &ctx->dev->dev_mutex;
ret = vb2_queue_init(src_vq); ret = vb2_queue_init(src_vq);
if (ret) if (ret)
...@@ -2786,6 +2717,7 @@ static int coda_queue_init(void *priv, struct vb2_queue *src_vq, ...@@ -2786,6 +2717,7 @@ static int coda_queue_init(void *priv, struct vb2_queue *src_vq,
dst_vq->ops = &coda_qops; dst_vq->ops = &coda_qops;
dst_vq->mem_ops = &vb2_dma_contig_memops; dst_vq->mem_ops = &vb2_dma_contig_memops;
dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY; dst_vq->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_COPY;
dst_vq->lock = &ctx->dev->dev_mutex;
return vb2_queue_init(dst_vq); return vb2_queue_init(dst_vq);
} }
...@@ -2854,6 +2786,8 @@ static int coda_open(struct file *file) ...@@ -2854,6 +2786,8 @@ static int coda_open(struct file *file)
__func__, ret); __func__, ret);
goto err_ctx_init; goto err_ctx_init;
} }
ctx->fh.m2m_ctx = ctx->m2m_ctx;
ret = coda_ctrls_setup(ctx); ret = coda_ctrls_setup(ctx);
if (ret) { if (ret) {
v4l2_err(&dev->v4l2_dev, "failed to setup coda controls\n"); v4l2_err(&dev->v4l2_dev, "failed to setup coda controls\n");
...@@ -2953,32 +2887,13 @@ static int coda_release(struct file *file) ...@@ -2953,32 +2887,13 @@ static int coda_release(struct file *file)
return 0; return 0;
} }
static unsigned int coda_poll(struct file *file,
struct poll_table_struct *wait)
{
struct coda_ctx *ctx = fh_to_ctx(file->private_data);
int ret;
coda_lock(ctx);
ret = v4l2_m2m_poll(file, ctx->m2m_ctx, wait);
coda_unlock(ctx);
return ret;
}
static int coda_mmap(struct file *file, struct vm_area_struct *vma)
{
struct coda_ctx *ctx = fh_to_ctx(file->private_data);
return v4l2_m2m_mmap(file, ctx->m2m_ctx, vma);
}
static const struct v4l2_file_operations coda_fops = { static const struct v4l2_file_operations coda_fops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.open = coda_open, .open = coda_open,
.release = coda_release, .release = coda_release,
.poll = coda_poll, .poll = v4l2_m2m_fop_poll,
.unlocked_ioctl = video_ioctl2, .unlocked_ioctl = video_ioctl2,
.mmap = coda_mmap, .mmap = v4l2_m2m_fop_mmap,
}; };
static void coda_finish_decode(struct coda_ctx *ctx) static void coda_finish_decode(struct coda_ctx *ctx)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册