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

media: amphion: Use vb2_get_buffer() instead of directly access to buffers array

Use vb2_get_buffer() instead of direct access to the vb2_queue bufs array.
This allows us to change the type of the bufs in the future.
After each call to vb2_get_buffer() we need to be sure that we get
a valid pointer so check the return value of all of them.
Signed-off-by: default avatarBenjamin Gaignard <benjamin.gaignard@collabora.com>
Reviewed-by: default avatarAndrzej Pietrasiewicz <andrzej.p@collabora.com>
CC: Ming Qian <ming.qian@nxp.com>
CC: Zhou Peng <eagle.zhou@nxp.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent da8fc26b
...@@ -140,11 +140,18 @@ static int vpu_dbg_instance(struct seq_file *s, void *data) ...@@ -140,11 +140,18 @@ static int vpu_dbg_instance(struct seq_file *s, void *data)
vq = v4l2_m2m_get_src_vq(inst->fh.m2m_ctx); vq = v4l2_m2m_get_src_vq(inst->fh.m2m_ctx);
for (i = 0; i < vq->num_buffers; i++) { for (i = 0; i < vq->num_buffers; i++) {
struct vb2_buffer *vb = vq->bufs[i]; struct vb2_buffer *vb;
struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb); struct vb2_v4l2_buffer *vbuf;
vb = vb2_get_buffer(vq, i);
if (!vb)
continue;
if (vb->state == VB2_BUF_STATE_DEQUEUED) if (vb->state == VB2_BUF_STATE_DEQUEUED)
continue; continue;
vbuf = to_vb2_v4l2_buffer(vb);
num = scnprintf(str, sizeof(str), num = scnprintf(str, sizeof(str),
"output [%2d] state = %10s, %8s\n", "output [%2d] state = %10s, %8s\n",
i, vb2_stat_name[vb->state], i, vb2_stat_name[vb->state],
...@@ -155,11 +162,18 @@ static int vpu_dbg_instance(struct seq_file *s, void *data) ...@@ -155,11 +162,18 @@ static int vpu_dbg_instance(struct seq_file *s, void *data)
vq = v4l2_m2m_get_dst_vq(inst->fh.m2m_ctx); vq = v4l2_m2m_get_dst_vq(inst->fh.m2m_ctx);
for (i = 0; i < vq->num_buffers; i++) { for (i = 0; i < vq->num_buffers; i++) {
struct vb2_buffer *vb = vq->bufs[i]; struct vb2_buffer *vb;
struct vb2_v4l2_buffer *vbuf = to_vb2_v4l2_buffer(vb); struct vb2_v4l2_buffer *vbuf;
vb = vb2_get_buffer(vq, i);
if (!vb)
continue;
if (vb->state == VB2_BUF_STATE_DEQUEUED) if (vb->state == VB2_BUF_STATE_DEQUEUED)
continue; continue;
vbuf = to_vb2_v4l2_buffer(vb);
num = scnprintf(str, sizeof(str), num = scnprintf(str, sizeof(str),
"capture[%2d] state = %10s, %8s\n", "capture[%2d] state = %10s, %8s\n",
i, vb2_stat_name[vb->state], i, vb2_stat_name[vb->state],
......
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