Commit 6ea001f9 authored by Benjamin Gaignard's avatar Benjamin Gaignard Committed by Mauro Carvalho Chehab

media: videobuf2: Access vb2_queue bufs array through helper functions

This patch adds 2 helpers functions to add and remove vb2 buffers
from a queue. With these 2 and vb2_get_buffer(), bufs field of
struct vb2_queue becomes like a private member of the structure.

After each call to vb2_get_buffer() we need to be sure that we get
a valid pointer in preparation for when buffers can be deleted.
Signed-off-by: default avatarBenjamin Gaignard <benjamin.gaignard@collabora.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 3c147c29
...@@ -615,11 +615,22 @@ static const struct vb2_buf_ops v4l2_buf_ops = { ...@@ -615,11 +615,22 @@ static const struct vb2_buf_ops v4l2_buf_ops = {
struct vb2_buffer *vb2_find_buffer(struct vb2_queue *q, u64 timestamp) struct vb2_buffer *vb2_find_buffer(struct vb2_queue *q, u64 timestamp)
{ {
unsigned int i; unsigned int i;
struct vb2_buffer *vb2;
for (i = 0; i < q->num_buffers; i++) /*
if (q->bufs[i]->copied_timestamp && * This loop doesn't scale if there is a really large number of buffers.
q->bufs[i]->timestamp == timestamp) * Maybe something more efficient will be needed in this case.
return vb2_get_buffer(q, i); */
for (i = 0; i < q->num_buffers; i++) {
vb2 = vb2_get_buffer(q, i);
if (!vb2)
continue;
if (vb2->copied_timestamp &&
vb2->timestamp == timestamp)
return vb2;
}
return NULL; return NULL;
} }
EXPORT_SYMBOL_GPL(vb2_find_buffer); EXPORT_SYMBOL_GPL(vb2_find_buffer);
...@@ -647,11 +658,12 @@ int vb2_querybuf(struct vb2_queue *q, struct v4l2_buffer *b) ...@@ -647,11 +658,12 @@ int vb2_querybuf(struct vb2_queue *q, struct v4l2_buffer *b)
return -EINVAL; return -EINVAL;
} }
if (b->index >= q->num_buffers) { vb = vb2_get_buffer(q, b->index);
dprintk(q, 1, "buffer index out of range\n"); if (!vb) {
dprintk(q, 1, "can't find the requested buffer %u\n", b->index);
return -EINVAL; return -EINVAL;
} }
vb = q->bufs[b->index];
ret = __verify_planes_array(vb, b); ret = __verify_planes_array(vb, b);
if (!ret) if (!ret)
vb2_core_querybuf(q, vb, b); vb2_core_querybuf(q, vb, b);
...@@ -721,11 +733,11 @@ int vb2_prepare_buf(struct vb2_queue *q, struct media_device *mdev, ...@@ -721,11 +733,11 @@ int vb2_prepare_buf(struct vb2_queue *q, struct media_device *mdev,
if (b->flags & V4L2_BUF_FLAG_REQUEST_FD) if (b->flags & V4L2_BUF_FLAG_REQUEST_FD)
return -EINVAL; return -EINVAL;
if (b->index >= q->num_buffers) { vb = vb2_get_buffer(q, b->index);
dprintk(q, 1, "buffer index out of range\n"); if (!vb) {
dprintk(q, 1, "can't find the requested buffer %u\n", b->index);
return -EINVAL; return -EINVAL;
} }
vb = q->bufs[b->index];
ret = vb2_queue_or_prepare_buf(q, mdev, vb, b, true, NULL); ret = vb2_queue_or_prepare_buf(q, mdev, vb, b, true, NULL);
...@@ -809,7 +821,11 @@ int vb2_qbuf(struct vb2_queue *q, struct media_device *mdev, ...@@ -809,7 +821,11 @@ int vb2_qbuf(struct vb2_queue *q, struct media_device *mdev,
dprintk(q, 1, "buffer index out of range\n"); dprintk(q, 1, "buffer index out of range\n");
return -EINVAL; return -EINVAL;
} }
vb = q->bufs[b->index]; vb = vb2_get_buffer(q, b->index);
if (!vb) {
dprintk(q, 1, "can't find the requested buffer %u\n", b->index);
return -EINVAL;
}
ret = vb2_queue_or_prepare_buf(q, mdev, vb, b, false, &req); ret = vb2_queue_or_prepare_buf(q, mdev, vb, b, false, &req);
if (ret) if (ret)
...@@ -880,7 +896,11 @@ int vb2_expbuf(struct vb2_queue *q, struct v4l2_exportbuffer *eb) ...@@ -880,7 +896,11 @@ int vb2_expbuf(struct vb2_queue *q, struct v4l2_exportbuffer *eb)
dprintk(q, 1, "buffer index out of range\n"); dprintk(q, 1, "buffer index out of range\n");
return -EINVAL; return -EINVAL;
} }
vb = q->bufs[eb->index]; vb = vb2_get_buffer(q, eb->index);
if (!vb) {
dprintk(q, 1, "can't find the requested buffer %u\n", eb->index);
return -EINVAL;
}
return vb2_core_expbuf(q, &eb->fd, eb->type, vb, return vb2_core_expbuf(q, &eb->fd, eb->type, vb,
eb->plane, eb->flags); eb->plane, eb->flags);
......
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