---
 libavdevice/v4l2.c |   58 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 52 insertions(+), 6 deletions(-)

diff --git a/libavdevice/v4l2.c b/libavdevice/v4l2.c
index c1ba756..1bcd39f 100644
--- a/libavdevice/v4l2.c
+++ b/libavdevice/v4l2.c
@@ -101,6 +101,40 @@ static struct fmt_map fmt_conversion_table[] = {
     { PIX_FMT_NONE,    CODEC_ID_MJPEG,    V4L2_PIX_FMT_JPEG    },
 };
 
+static void list_formats(AVFormatContext *ctx, int level, int fd)
+{
+    struct v4l2_fmtdesc vfd = { .type = V4L2_BUF_TYPE_VIDEO_CAPTURE };
+    struct v4l2_frmsizeenum vfse = { 0 };
+
+    while(!ioctl(fd, VIDIOC_ENUM_FMT, &vfd)) {
+        av_log(ctx, level,
+               "%c%c%c%c/%04x %s flags %s%s :",
+               vfd.pixelformat & 0xFF,
+               (vfd.pixelformat >> 8) & 0xFF,
+               (vfd.pixelformat >> 16) & 0xFF,
+               (vfd.pixelformat >> 24) & 0xFF,
+               vfd.pixelformat,
+               vfd.description,
+               vfd.flags & V4L2_FMT_FLAG_EMULATED ? "e" : " ",
+               vfd.flags & V4L2_FMT_FLAG_COMPRESSED ? "c": " ");
+
+        vfse.pixel_format = vfd.pixelformat;
+
+        while(!ioctl(fd, VIDIOC_ENUM_FRAMESIZES, &vfse)) {
+            av_log(ctx, level,
+                   " %ux%u",
+                   vfse.discrete.width, vfse.discrete.height);
+            vfse.index++;
+        }
+
+        vfse.index = 0;
+        vfd.index++;
+
+        av_log(ctx, AV_LOG_INFO, "\n");
+    }
+
+};
+
 static int device_open(AVFormatContext *ctx)
 {
     struct v4l2_capability cap;
@@ -626,12 +660,24 @@ static int v4l2_read_header(AVFormatContext *s1, 
AVFormatParameters *ap)
                s->video_size);
         goto out;
     }
-    if (s->pixel_format &&
-        (pix_fmt = av_get_pix_fmt(s->pixel_format)) == PIX_FMT_NONE) {
-        av_log(s1, AV_LOG_ERROR, "No such pixel format: %s.\n",
-               s->pixel_format);
-        res = AVERROR(EINVAL);
-        goto out;
+
+    if (s->pixel_format) {
+
+        if (!strcmp(s->pixel_format, "list")) {
+            list_formats(s1, AV_LOG_INFO, s->fd);
+            res = AVERROR_EXIT;
+            goto out;
+        }
+
+        pix_fmt = av_get_pix_fmt(s->pixel_format);
+
+        if (pix_fmt == PIX_FMT_NONE) {
+            av_log(s1, AV_LOG_ERROR, "No such pixel format: %s.\n",
+                   s->pixel_format);
+
+            res = AVERROR(EINVAL);
+            goto out;
+        }
     }
 
     if (!s->width && !s->height) {
-- 
1.7.8.rc1

_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to