summaryrefslogtreecommitdiff
path: root/linux/drivers/media/video/v4l2-common.c
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2006-02-18 08:52:34 -0200
committerMauro Carvalho Chehab <mchehab@infradead.org>2006-02-18 08:52:34 -0200
commit13fcc7a7f00cc567fb53091876bc6649f100761b (patch)
tree34d9811fe6b814c592388bf938aeb0cd9e493a7d /linux/drivers/media/video/v4l2-common.c
parent9730e168922552fa3f337e985ac02b7a2fa95faf (diff)
downloadmediapointer-dvb-s2-13fcc7a7f00cc567fb53091876bc6649f100761b.tar.gz
mediapointer-dvb-s2-13fcc7a7f00cc567fb53091876bc6649f100761b.tar.bz2
Debug messages for ioctl improved
From: Mauro Carvalho Chehab <mchehab@infradead.org> Adds field and type name to debug message. Also prints now format for type=capture. Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'linux/drivers/media/video/v4l2-common.c')
-rw-r--r--linux/drivers/media/video/v4l2-common.c43
1 files changed, 37 insertions, 6 deletions
diff --git a/linux/drivers/media/video/v4l2-common.c b/linux/drivers/media/video/v4l2-common.c
index 2df9b70c5..b95b7b244 100644
--- a/linux/drivers/media/video/v4l2-common.c
+++ b/linux/drivers/media/video/v4l2-common.c
@@ -343,6 +343,16 @@ static const char *v4l2_int_ioctls[] = {
};
#define V4L2_INT_IOCTLS ARRAY_SIZE(v4l2_int_ioctls)
+static void v4l_print_pix_fmt (char *s, struct v4l2_pix_format *fmt)
+{
+ printk ("%s: width=%d, height=%d, format=%d, field=%s, "
+ "bytesperline=%d sizeimage=%d, colorspace=%d\n", s,
+ fmt->width,fmt->height,fmt->pixelformat,
+ ((fmt->field>=0)&&(fmt->field<ARRAY_SIZE(v4l2_field_names)))?
+ v4l2_field_names[fmt->field]:"unknown",
+ fmt->bytesperline,fmt->sizeimage,fmt->colorspace);
+};
+
/* Common ioctl debug function. This function can be used by
external ioctl messages as well as internal V4L ioctl */
void v4l_printk_ioctl(unsigned int cmd)
@@ -469,15 +479,18 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)
{
struct v4l2_buffer *p=arg;
struct v4l2_timecode *tc=&p->timecode;
- printk ("%s: %02ld:%02d:%02d.%08ld index=%d, type=%d, "
+ printk ("%s: %02ld:%02d:%02d.%08ld index=%d, type=%s, "
"bytesused=%d, flags=0x%08d, "
- "field=%0d, sequence=%d, memory=%d, offset/userptr=0x%08lx,",
+ "field=%0d, sequence=%d, memory=%d, offset/userptr=0x%08lx\n",
s,
(p->timestamp.tv_sec/3600),
(int)(p->timestamp.tv_sec/60)%60,
(int)(p->timestamp.tv_sec%60),
p->timestamp.tv_usec,
- p->index,p->type,p->bytesused,p->flags,
+ p->index,
+ ((p->type>=0)&&(p->type<ARRAY_SIZE(v4l2_type_names)))?
+ v4l2_type_names[p->type]:"unknown",
+ p->bytesused,p->flags,
p->field,p->sequence,p->memory,p->m.userptr);
printk ("%s: timecode= %02d:%02d:%02d type=%d, "
"flags=0x%08d, frames=%d, userbits=0x%08x",
@@ -542,17 +555,35 @@ void v4l_printk_ioctl_arg(char *s,unsigned int cmd, void *arg)
case VIDIOC_TRY_FMT:
{
struct v4l2_format *p=arg;
+ printk ("%s: type=%s\n", s,
+ ((p->type>=0)&&(p->type<ARRAY_SIZE(v4l2_type_names)))?
+ v4l2_type_names[p->type]:"unknown");
+ switch (p->type) {
+ case V4L2_BUF_TYPE_VIDEO_CAPTURE:
+ v4l_print_pix_fmt (s, &p->fmt.pix);
+ break;
+#if 0
/* FIXME: Should be one dump per type*/
- printk ("%s: type=%d\n", s,p->type);
- break;
+ case V4L2_BUF_TYPE_VIDEO_OUTPUT:
+ case V4L2_BUF_TYPE_VIDEO_OVERLAY:
+ case V4L2_BUF_TYPE_VBI_CAPTURE:
+ case V4L2_BUF_TYPE_VBI_OUTPUT:
+ case V4L2_BUF_TYPE_SLICED_VBI_CAPTURE:
+ case V4L2_BUF_TYPE_SLICED_VBI_OUTPUT:
+ case V4L2_BUF_TYPE_PRIVATE:
+ break;
+#endif
+ default:
+ break;
+ }
}
case VIDIOC_G_FBUF:
case VIDIOC_S_FBUF:
{
struct v4l2_framebuffer *p=arg;
- /*FIXME: should show also struct v4l2_pix_format p->fmt field */
printk ("%s: capability=%d, flags=%d, base=0x%08lx\n", s,
p->capability,p->flags, (unsigned long)p->base);
+ v4l_print_pix_fmt (s, &p->fmt);
break;
}
case VIDIOC_G_FREQUENCY: