Commit b820935b authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

media: vb2: Print the queue pointer in debug messages

When debugging issues that involve more than one video queue, messages
related to multiple queues get interleaved without any easy way to tell
which queue they relate to. Fix this by adding a queue name to
vb2_queue, and printing it in all debug messages in the vb2 core and
V4L2 layers. If the name isn't set by drivers, it is automatically
filled with the queue direction and address.
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 030b161c
...@@ -35,10 +35,11 @@ ...@@ -35,10 +35,11 @@
static int debug; static int debug;
module_param(debug, int, 0644); module_param(debug, int, 0644);
#define dprintk(level, fmt, arg...) \ #define dprintk(q, level, fmt, arg...) \
do { \ do { \
if (debug >= level) \ if (debug >= level) \
pr_info("vb2-v4l2: %s: " fmt, __func__, ## arg); \ pr_info("vb2-v4l2: [%p] %s: " fmt, \
(q)->name, __func__, ## arg); \
} while (0) } while (0)
/* Flags that are set by us */ /* Flags that are set by us */
...@@ -66,12 +67,14 @@ static int __verify_planes_array(struct vb2_buffer *vb, const struct v4l2_buffer ...@@ -66,12 +67,14 @@ static int __verify_planes_array(struct vb2_buffer *vb, const struct v4l2_buffer
/* Is memory for copying plane information present? */ /* Is memory for copying plane information present? */
if (b->m.planes == NULL) { if (b->m.planes == NULL) {
dprintk(1, "multi-planar buffer passed but planes array not provided\n"); dprintk(vb->vb2_queue, 1,
"multi-planar buffer passed but planes array not provided\n");
return -EINVAL; return -EINVAL;
} }
if (b->length < vb->num_planes || b->length > VB2_MAX_PLANES) { if (b->length < vb->num_planes || b->length > VB2_MAX_PLANES) {
dprintk(1, "incorrect planes array length, expected %d, got %d\n", dprintk(vb->vb2_queue, 1,
"incorrect planes array length, expected %d, got %d\n",
vb->num_planes, b->length); vb->num_planes, b->length);
return -EINVAL; return -EINVAL;
} }
...@@ -179,7 +182,7 @@ static int vb2_fill_vb2_v4l2_buffer(struct vb2_buffer *vb, struct v4l2_buffer *b ...@@ -179,7 +182,7 @@ static int vb2_fill_vb2_v4l2_buffer(struct vb2_buffer *vb, struct v4l2_buffer *b
ret = __verify_length(vb, b); ret = __verify_length(vb, b);
if (ret < 0) { if (ret < 0) {
dprintk(1, "plane parameters verification failed: %d\n", ret); dprintk(q, 1, "plane parameters verification failed: %d\n", ret);
return ret; return ret;
} }
if (b->field == V4L2_FIELD_ALTERNATE && q->is_output) { if (b->field == V4L2_FIELD_ALTERNATE && q->is_output) {
...@@ -192,7 +195,7 @@ static int vb2_fill_vb2_v4l2_buffer(struct vb2_buffer *vb, struct v4l2_buffer *b ...@@ -192,7 +195,7 @@ static int vb2_fill_vb2_v4l2_buffer(struct vb2_buffer *vb, struct v4l2_buffer *b
* that just says that it is either a top or a bottom field, * that just says that it is either a top or a bottom field,
* but not which of the two it is. * but not which of the two it is.
*/ */
dprintk(1, "the field is incorrectly set to ALTERNATE for an output buffer\n"); dprintk(q, 1, "the field is incorrectly set to ALTERNATE for an output buffer\n");
return -EINVAL; return -EINVAL;
} }
vbuf->sequence = 0; vbuf->sequence = 0;
...@@ -395,23 +398,23 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md ...@@ -395,23 +398,23 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md
int ret; int ret;
if (b->type != q->type) { if (b->type != q->type) {
dprintk(1, "%s: invalid buffer type\n", opname); dprintk(q, 1, "%s: invalid buffer type\n", opname);
return -EINVAL; return -EINVAL;
} }
if (b->index >= q->num_buffers) { if (b->index >= q->num_buffers) {
dprintk(1, "%s: buffer index out of range\n", opname); dprintk(q, 1, "%s: buffer index out of range\n", opname);
return -EINVAL; return -EINVAL;
} }
if (q->bufs[b->index] == NULL) { if (q->bufs[b->index] == NULL) {
/* Should never happen */ /* Should never happen */
dprintk(1, "%s: buffer is NULL\n", opname); dprintk(q, 1, "%s: buffer is NULL\n", opname);
return -EINVAL; return -EINVAL;
} }
if (b->memory != q->memory) { if (b->memory != q->memory) {
dprintk(1, "%s: invalid memory type\n", opname); dprintk(q, 1, "%s: invalid memory type\n", opname);
return -EINVAL; return -EINVAL;
} }
...@@ -423,7 +426,7 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md ...@@ -423,7 +426,7 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md
if (!is_prepare && (b->flags & V4L2_BUF_FLAG_REQUEST_FD) && if (!is_prepare && (b->flags & V4L2_BUF_FLAG_REQUEST_FD) &&
vb->state != VB2_BUF_STATE_DEQUEUED) { vb->state != VB2_BUF_STATE_DEQUEUED) {
dprintk(1, "%s: buffer is not in dequeued state\n", opname); dprintk(q, 1, "%s: buffer is not in dequeued state\n", opname);
return -EINVAL; return -EINVAL;
} }
...@@ -442,19 +445,19 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md ...@@ -442,19 +445,19 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md
if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD)) { if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD)) {
if (q->requires_requests) { if (q->requires_requests) {
dprintk(1, "%s: queue requires requests\n", opname); dprintk(q, 1, "%s: queue requires requests\n", opname);
return -EBADR; return -EBADR;
} }
if (q->uses_requests) { if (q->uses_requests) {
dprintk(1, "%s: queue uses requests\n", opname); dprintk(q, 1, "%s: queue uses requests\n", opname);
return -EBUSY; return -EBUSY;
} }
return 0; return 0;
} else if (!q->supports_requests) { } else if (!q->supports_requests) {
dprintk(1, "%s: queue does not support requests\n", opname); dprintk(q, 1, "%s: queue does not support requests\n", opname);
return -EBADR; return -EBADR;
} else if (q->uses_qbuf) { } else if (q->uses_qbuf) {
dprintk(1, "%s: queue does not use requests\n", opname); dprintk(q, 1, "%s: queue does not use requests\n", opname);
return -EBUSY; return -EBUSY;
} }
...@@ -484,13 +487,13 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md ...@@ -484,13 +487,13 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md
return -EINVAL; return -EINVAL;
if (b->request_fd < 0) { if (b->request_fd < 0) {
dprintk(1, "%s: request_fd < 0\n", opname); dprintk(q, 1, "%s: request_fd < 0\n", opname);
return -EINVAL; return -EINVAL;
} }
req = media_request_get_by_fd(mdev, b->request_fd); req = media_request_get_by_fd(mdev, b->request_fd);
if (IS_ERR(req)) { if (IS_ERR(req)) {
dprintk(1, "%s: invalid request_fd\n", opname); dprintk(q, 1, "%s: invalid request_fd\n", opname);
return PTR_ERR(req); return PTR_ERR(req);
} }
...@@ -500,7 +503,7 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md ...@@ -500,7 +503,7 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, struct media_device *md
*/ */
if (req->state != MEDIA_REQUEST_STATE_IDLE && if (req->state != MEDIA_REQUEST_STATE_IDLE &&
req->state != MEDIA_REQUEST_STATE_UPDATING) { req->state != MEDIA_REQUEST_STATE_UPDATING) {
dprintk(1, "%s: request is not idle\n", opname); dprintk(q, 1, "%s: request is not idle\n", opname);
media_request_put(req); media_request_put(req);
return -EBUSY; return -EBUSY;
} }
...@@ -683,12 +686,12 @@ int vb2_querybuf(struct vb2_queue *q, struct v4l2_buffer *b) ...@@ -683,12 +686,12 @@ int vb2_querybuf(struct vb2_queue *q, struct v4l2_buffer *b)
int ret; int ret;
if (b->type != q->type) { if (b->type != q->type) {
dprintk(1, "wrong buffer type\n"); dprintk(q, 1, "wrong buffer type\n");
return -EINVAL; return -EINVAL;
} }
if (b->index >= q->num_buffers) { if (b->index >= q->num_buffers) {
dprintk(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 = q->bufs[b->index];
...@@ -743,7 +746,7 @@ int vb2_prepare_buf(struct vb2_queue *q, struct media_device *mdev, ...@@ -743,7 +746,7 @@ int vb2_prepare_buf(struct vb2_queue *q, struct media_device *mdev,
int ret; int ret;
if (vb2_fileio_is_active(q)) { if (vb2_fileio_is_active(q)) {
dprintk(1, "file io in progress\n"); dprintk(q, 1, "file io in progress\n");
return -EBUSY; return -EBUSY;
} }
...@@ -823,7 +826,7 @@ int vb2_qbuf(struct vb2_queue *q, struct media_device *mdev, ...@@ -823,7 +826,7 @@ int vb2_qbuf(struct vb2_queue *q, struct media_device *mdev,
int ret; int ret;
if (vb2_fileio_is_active(q)) { if (vb2_fileio_is_active(q)) {
dprintk(1, "file io in progress\n"); dprintk(q, 1, "file io in progress\n");
return -EBUSY; return -EBUSY;
} }
...@@ -842,12 +845,12 @@ int vb2_dqbuf(struct vb2_queue *q, struct v4l2_buffer *b, bool nonblocking) ...@@ -842,12 +845,12 @@ int vb2_dqbuf(struct vb2_queue *q, struct v4l2_buffer *b, bool nonblocking)
int ret; int ret;
if (vb2_fileio_is_active(q)) { if (vb2_fileio_is_active(q)) {
dprintk(1, "file io in progress\n"); dprintk(q, 1, "file io in progress\n");
return -EBUSY; return -EBUSY;
} }
if (b->type != q->type) { if (b->type != q->type) {
dprintk(1, "invalid buffer type\n"); dprintk(q, 1, "invalid buffer type\n");
return -EINVAL; return -EINVAL;
} }
...@@ -871,7 +874,7 @@ EXPORT_SYMBOL_GPL(vb2_dqbuf); ...@@ -871,7 +874,7 @@ EXPORT_SYMBOL_GPL(vb2_dqbuf);
int vb2_streamon(struct vb2_queue *q, enum v4l2_buf_type type) int vb2_streamon(struct vb2_queue *q, enum v4l2_buf_type type)
{ {
if (vb2_fileio_is_active(q)) { if (vb2_fileio_is_active(q)) {
dprintk(1, "file io in progress\n"); dprintk(q, 1, "file io in progress\n");
return -EBUSY; return -EBUSY;
} }
return vb2_core_streamon(q, type); return vb2_core_streamon(q, type);
...@@ -881,7 +884,7 @@ EXPORT_SYMBOL_GPL(vb2_streamon); ...@@ -881,7 +884,7 @@ EXPORT_SYMBOL_GPL(vb2_streamon);
int vb2_streamoff(struct vb2_queue *q, enum v4l2_buf_type type) int vb2_streamoff(struct vb2_queue *q, enum v4l2_buf_type type)
{ {
if (vb2_fileio_is_active(q)) { if (vb2_fileio_is_active(q)) {
dprintk(1, "file io in progress\n"); dprintk(q, 1, "file io in progress\n");
return -EBUSY; return -EBUSY;
} }
return vb2_core_streamoff(q, type); return vb2_core_streamoff(q, type);
...@@ -895,7 +898,7 @@ int vb2_expbuf(struct vb2_queue *q, struct v4l2_exportbuffer *eb) ...@@ -895,7 +898,7 @@ int vb2_expbuf(struct vb2_queue *q, struct v4l2_exportbuffer *eb)
} }
EXPORT_SYMBOL_GPL(vb2_expbuf); EXPORT_SYMBOL_GPL(vb2_expbuf);
int vb2_queue_init(struct vb2_queue *q) int vb2_queue_init_name(struct vb2_queue *q, const char *name)
{ {
/* /*
* Sanity check * Sanity check
...@@ -931,8 +934,19 @@ int vb2_queue_init(struct vb2_queue *q) ...@@ -931,8 +934,19 @@ int vb2_queue_init(struct vb2_queue *q)
*/ */
q->quirk_poll_must_check_waiting_for_buffers = true; q->quirk_poll_must_check_waiting_for_buffers = true;
if (name)
strscpy(q->name, name, sizeof(q->name));
else
q->name[0] = '\0';
return vb2_core_queue_init(q); return vb2_core_queue_init(q);
} }
EXPORT_SYMBOL_GPL(vb2_queue_init_name);
int vb2_queue_init(struct vb2_queue *q)
{
return vb2_queue_init_name(q, NULL);
}
EXPORT_SYMBOL_GPL(vb2_queue_init); EXPORT_SYMBOL_GPL(vb2_queue_init);
void vb2_queue_release(struct vb2_queue *q) void vb2_queue_release(struct vb2_queue *q)
......
...@@ -561,6 +561,8 @@ struct vb2_buf_ops { ...@@ -561,6 +561,8 @@ struct vb2_buf_ops {
* when a buffer with the %V4L2_BUF_FLAG_LAST is dequeued. * when a buffer with the %V4L2_BUF_FLAG_LAST is dequeued.
* @fileio: file io emulator internal data, used only if emulator is active * @fileio: file io emulator internal data, used only if emulator is active
* @threadio: thread io internal data, used only if thread is active * @threadio: thread io internal data, used only if thread is active
* @name: queue name, used for logging purpose. Initialized automatically
* if left empty by drivers.
*/ */
struct vb2_queue { struct vb2_queue {
unsigned int type; unsigned int type;
...@@ -622,6 +624,8 @@ struct vb2_queue { ...@@ -622,6 +624,8 @@ struct vb2_queue {
struct vb2_fileio_data *fileio; struct vb2_fileio_data *fileio;
struct vb2_threadio_data *threadio; struct vb2_threadio_data *threadio;
char name[32];
#ifdef CONFIG_VIDEO_ADV_DEBUG #ifdef CONFIG_VIDEO_ADV_DEBUG
/* /*
* Counters for how often these queue-related ops are * Counters for how often these queue-related ops are
......
...@@ -236,6 +236,19 @@ int vb2_streamoff(struct vb2_queue *q, enum v4l2_buf_type type); ...@@ -236,6 +236,19 @@ int vb2_streamoff(struct vb2_queue *q, enum v4l2_buf_type type);
*/ */
int __must_check vb2_queue_init(struct vb2_queue *q); int __must_check vb2_queue_init(struct vb2_queue *q);
/**
* vb2_queue_init_name() - initialize a videobuf2 queue with a name
* @q: pointer to &struct vb2_queue with videobuf2 queue.
* @name: the queue name
*
* This function initializes the vb2_queue exactly like vb2_queue_init(),
* and additionally sets the queue name. The queue name is used for logging
* purpose, and should uniquely identify the queue within the context of the
* device it belongs to. This is useful to attribute kernel log messages to the
* right queue for m2m devices or other devices that handle multiple queues.
*/
int __must_check vb2_queue_init_name(struct vb2_queue *q, const char *name);
/** /**
* vb2_queue_release() - stop streaming, release the queue and free memory * vb2_queue_release() - stop streaming, release the queue and free memory
* @q: pointer to &struct vb2_queue with videobuf2 queue. * @q: pointer to &struct vb2_queue with videobuf2 queue.
......
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