Commit 1df7b8cd authored by Hans Verkuil's avatar Hans Verkuil

media: videobuf2: improve max_num_buffers sanity checks

Ensure that drivers set max_num_buffers to a value >= 32.
For now there is no reason for drivers to request a lower
limit and doing so might potentially cause userspace issues.
Note that the old check of > MAX_BUFFER_INDEX was pointless
since q->max_num_buffers was already limited to MAX_BUFFER_INDEX
or less.

Also add a sanity check in __vb2_init_fileio(), returning
-ENOSPC if a driver returns more than 32 buffers from
VIDIOC_REQBUFS with count = q->min_reqbufs_allocation.

The vb2_fileio_data struct only supports up to 32 buffers,
so we need a check there.
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
parent e85bfd15
...@@ -2584,7 +2584,7 @@ int vb2_core_queue_init(struct vb2_queue *q) ...@@ -2584,7 +2584,7 @@ int vb2_core_queue_init(struct vb2_queue *q)
WARN_ON(!q->ops->buf_queue)) WARN_ON(!q->ops->buf_queue))
return -EINVAL; return -EINVAL;
if (WARN_ON(q->max_num_buffers > MAX_BUFFER_INDEX) || if (WARN_ON(q->max_num_buffers < VB2_MAX_FRAME) ||
WARN_ON(q->min_queued_buffers > q->max_num_buffers)) WARN_ON(q->min_queued_buffers > q->max_num_buffers))
return -EINVAL; return -EINVAL;
...@@ -2855,6 +2855,12 @@ static int __vb2_init_fileio(struct vb2_queue *q, int read) ...@@ -2855,6 +2855,12 @@ static int __vb2_init_fileio(struct vb2_queue *q, int read)
ret = vb2_core_reqbufs(q, fileio->memory, 0, &fileio->count); ret = vb2_core_reqbufs(q, fileio->memory, 0, &fileio->count);
if (ret) if (ret)
goto err_kfree; goto err_kfree;
/* vb2_fileio_data supports max VB2_MAX_FRAME buffers */
if (fileio->count > VB2_MAX_FRAME) {
dprintk(q, 1, "fileio: more than VB2_MAX_FRAME buffers requested\n");
ret = -ENOSPC;
goto err_reqbufs;
}
/* /*
* Userspace can never add or delete buffers later, so there * Userspace can never add or delete buffers later, so there
......
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