[media] vivid: add new format fields
authorHans Verkuil <hans.verkuil@cisco.com>
Sat, 7 Mar 2015 18:04:49 +0000 (15:04 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Thu, 2 Apr 2015 23:50:14 +0000 (20:50 -0300)
These fields are necessary to handle the new planar formats.

Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/platform/vivid/vivid-core.h
drivers/media/platform/vivid/vivid-vid-cap.c
drivers/media/platform/vivid/vivid-vid-common.c
drivers/media/platform/vivid/vivid-vid-out.c

index 191d9b5..bcefd19 100644 (file)
@@ -79,12 +79,14 @@ extern unsigned vivid_debug;
 struct vivid_fmt {
        const char *name;
        u32     fourcc;          /* v4l2 format id */
-       u8      depth;
        bool    is_yuv;
        bool    can_do_overlay;
+       u8      vdownsampling[TPG_MAX_PLANES];
        u32     alpha_mask;
        u8      planes;
+       u8      buffers;
        u32     data_offset[TPG_MAX_PLANES];
+       u32     bit_depth[TPG_MAX_PLANES];
 };
 
 extern struct vivid_fmt vivid_formats[];
index d41ac44..4d50961 100644 (file)
@@ -42,20 +42,26 @@ static const struct vivid_fmt formats_ovl[] = {
        {
                .name     = "RGB565 (LE)",
                .fourcc   = V4L2_PIX_FMT_RGB565, /* gggbbbbb rrrrrggg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "XRGB555 (LE)",
                .fourcc   = V4L2_PIX_FMT_XRGB555, /* gggbbbbb arrrrrgg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "ARGB555 (LE)",
                .fourcc   = V4L2_PIX_FMT_ARGB555, /* gggbbbbb arrrrrgg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
        },
 };
 
@@ -597,9 +603,9 @@ int vivid_try_fmt_vid_cap(struct file *file, void *priv,
        /* This driver supports custom bytesperline values */
 
        /* Calculate the minimum supported bytesperline value */
-       bytesperline = (mp->width * fmt->depth) >> 3;
+       bytesperline = (mp->width * fmt->bit_depth[0]) >> 3;
        /* Calculate the maximum supported bytesperline value */
-       max_bpl = (MAX_ZOOM * MAX_WIDTH * fmt->depth) >> 3;
+       max_bpl = (MAX_ZOOM * MAX_WIDTH * fmt->bit_depth[0]) >> 3;
        mp->num_planes = fmt->planes;
        for (p = 0; p < mp->num_planes; p++) {
                if (pfmt[p].bytesperline > max_bpl)
@@ -1224,7 +1230,7 @@ int vivid_vid_cap_s_fbuf(struct file *file, void *fh,
        fmt = vivid_get_format(dev, a->fmt.pixelformat);
        if (!fmt || !fmt->can_do_overlay)
                return -EINVAL;
-       if (a->fmt.bytesperline < (a->fmt.width * fmt->depth) / 8)
+       if (a->fmt.bytesperline < (a->fmt.width * fmt->bit_depth[0]) / 8)
                return -EINVAL;
        if (a->fmt.height * a->fmt.bytesperline < a->fmt.sizeimage)
                return -EINVAL;
index 49c9bc6..7a02aef 100644 (file)
@@ -46,139 +46,179 @@ struct vivid_fmt vivid_formats[] = {
        {
                .name     = "4:2:2, packed, YUYV",
                .fourcc   = V4L2_PIX_FMT_YUYV,
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .is_yuv   = true,
                .planes   = 1,
+               .buffers = 1,
                .data_offset = { PLANE0_DATA_OFFSET, 0 },
        },
        {
                .name     = "4:2:2, packed, UYVY",
                .fourcc   = V4L2_PIX_FMT_UYVY,
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .is_yuv   = true,
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "4:2:2, packed, YVYU",
                .fourcc   = V4L2_PIX_FMT_YVYU,
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .is_yuv   = true,
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "4:2:2, packed, VYUY",
                .fourcc   = V4L2_PIX_FMT_VYUY,
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .is_yuv   = true,
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "RGB565 (LE)",
                .fourcc   = V4L2_PIX_FMT_RGB565, /* gggbbbbb rrrrrggg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
        },
        {
                .name     = "RGB565 (BE)",
                .fourcc   = V4L2_PIX_FMT_RGB565X, /* rrrrrggg gggbbbbb */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
        },
        {
                .name     = "RGB555 (LE)",
                .fourcc   = V4L2_PIX_FMT_RGB555, /* gggbbbbb arrrrrgg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
        },
        {
                .name     = "XRGB555 (LE)",
                .fourcc   = V4L2_PIX_FMT_XRGB555, /* gggbbbbb arrrrrgg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
        },
        {
                .name     = "ARGB555 (LE)",
                .fourcc   = V4L2_PIX_FMT_ARGB555, /* gggbbbbb arrrrrgg */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
                .alpha_mask = 0x8000,
        },
        {
                .name     = "RGB555 (BE)",
                .fourcc   = V4L2_PIX_FMT_RGB555X, /* arrrrrgg gggbbbbb */
-               .depth    = 16,
+               .vdownsampling = { 1 },
+               .bit_depth = { 16 },
                .planes   = 1,
+               .buffers = 1,
                .can_do_overlay = true,
        },
        {
                .name     = "RGB24 (LE)",
                .fourcc   = V4L2_PIX_FMT_RGB24, /* rgb */
-               .depth    = 24,
+               .vdownsampling = { 1 },
+               .bit_depth = { 24 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "RGB24 (BE)",
                .fourcc   = V4L2_PIX_FMT_BGR24, /* bgr */
-               .depth    = 24,
+               .vdownsampling = { 1 },
+               .bit_depth = { 24 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "RGB32 (LE)",
                .fourcc   = V4L2_PIX_FMT_RGB32, /* argb */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "RGB32 (BE)",
                .fourcc   = V4L2_PIX_FMT_BGR32, /* bgra */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "XRGB32 (LE)",
                .fourcc   = V4L2_PIX_FMT_XRGB32, /* argb */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "XRGB32 (BE)",
                .fourcc   = V4L2_PIX_FMT_XBGR32, /* bgra */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
        },
        {
                .name     = "ARGB32 (LE)",
                .fourcc   = V4L2_PIX_FMT_ARGB32, /* argb */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
                .alpha_mask = 0x000000ff,
        },
        {
                .name     = "ARGB32 (BE)",
                .fourcc   = V4L2_PIX_FMT_ABGR32, /* bgra */
-               .depth    = 32,
+               .vdownsampling = { 1 },
+               .bit_depth = { 32 },
                .planes   = 1,
+               .buffers = 1,
                .alpha_mask = 0xff000000,
        },
        {
-               .name     = "4:2:2, planar, YUV",
+               .name     = "4:2:2, biplanar, YUV",
                .fourcc   = V4L2_PIX_FMT_NV16M,
-               .depth    = 8,
+               .vdownsampling = { 1, 1 },
+               .bit_depth = { 8, 8 },
                .is_yuv   = true,
                .planes   = 2,
+               .buffers = 2,
                .data_offset = { PLANE0_DATA_OFFSET, 0 },
        },
        {
-               .name     = "4:2:2, planar, YVU",
+               .name     = "4:2:2, biplanar, YVU",
                .fourcc   = V4L2_PIX_FMT_NV61M,
-               .depth    = 8,
+               .vdownsampling = { 1, 1 },
+               .bit_depth = { 8, 8 },
                .is_yuv   = true,
                .planes   = 2,
+               .buffers = 2,
                .data_offset = { 0, PLANE0_DATA_OFFSET },
        },
 };
index 8f081bb..9cf036c 100644 (file)
@@ -269,9 +269,9 @@ void vivid_update_format_out(struct vivid_dev *dev)
        if (V4L2_FIELD_HAS_T_OR_B(dev->field_out))
                dev->crop_out.height /= 2;
        dev->fmt_out_rect = dev->crop_out;
-       dev->bytesperline_out[0] = (dev->sink_rect.width * dev->fmt_out->depth) / 8;
+       dev->bytesperline_out[0] = (dev->sink_rect.width * dev->fmt_out->bit_depth[0]) / 8;
        if (dev->fmt_out->planes == 2)
-               dev->bytesperline_out[1] = (dev->sink_rect.width * dev->fmt_out->depth) / 8;
+               dev->bytesperline_out[1] = (dev->sink_rect.width * dev->fmt_out->bit_depth[0]) / 8;
 }
 
 /* Map the field to something that is valid for the current output */
@@ -388,9 +388,9 @@ int vivid_try_fmt_vid_out(struct file *file, void *priv,
        /* This driver supports custom bytesperline values */
 
        /* Calculate the minimum supported bytesperline value */
-       bytesperline = (mp->width * fmt->depth) >> 3;
+       bytesperline = (mp->width * fmt->bit_depth[0]) >> 3;
        /* Calculate the maximum supported bytesperline value */
-       max_bpl = (MAX_ZOOM * MAX_WIDTH * fmt->depth) >> 3;
+       max_bpl = (MAX_ZOOM * MAX_WIDTH * fmt->bit_depth[0]) >> 3;
        mp->num_planes = fmt->planes;
        for (p = 0; p < mp->num_planes; p++) {
                if (pfmt[p].bytesperline > max_bpl)