[media] exynos4-is: fimc: Roundup imagesize to row size for tiled formats
authorNicolas Dufresne <nicolas.dufresne@collabora.com>
Wed, 26 Mar 2014 22:48:39 +0000 (19:48 -0300)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Wed, 16 Nov 2016 18:24:53 +0000 (16:24 -0200)
For tiled format, we need to allocated a multiple of the row size. A
good example is for 1280x720, wich get adjusted to 1280x736. In tiles,
this mean Y plane is 20x23 and UV plane 20x12. Because of the rounding,
the previous code would only have enough space to fit half of the last
row.

[mchehab@s-opensource.com: fix coding style]
Signed-off-by: Nicolas Dufresne <nicolas.dufresne@collabora.com>
Signed-off-by: Sylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/platform/exynos4-is/fimc-core.c

index 8f89ca21b63193458e9e70d9c4e7ba0b76d20c86..099c735a39b79e67f544f40a4374942417054e5e 100644 (file)
@@ -736,6 +736,7 @@ void fimc_adjust_mplane_format(struct fimc_fmt *fmt, u32 width, u32 height,
        for (i = 0; i < pix->num_planes; ++i) {
                struct v4l2_plane_pix_format *plane_fmt = &pix->plane_fmt[i];
                u32 bpl = plane_fmt->bytesperline;
+               u32 sizeimage;
 
                if (fmt->colplanes > 1 && (bpl == 0 || bpl < pix->width))
                        bpl = pix->width; /* Planar */
@@ -755,8 +756,17 @@ void fimc_adjust_mplane_format(struct fimc_fmt *fmt, u32 width, u32 height,
                        bytesperline /= 2;
 
                plane_fmt->bytesperline = bytesperline;
-               plane_fmt->sizeimage = max((pix->width * pix->height *
-                                  fmt->depth[i]) / 8, plane_fmt->sizeimage);
+               sizeimage = pix->width * pix->height * fmt->depth[i] / 8;
+
+               /* Ensure full last row for tiled formats */
+               if (tiled_fmt(fmt)) {
+                       /* 64 * 32 * plane_fmt->bytesperline / 64 */
+                       u32 row_size = plane_fmt->bytesperline * 32;
+
+                       sizeimage = roundup(sizeimage, row_size);
+               }
+
+               plane_fmt->sizeimage = max(sizeimage, plane_fmt->sizeimage);
        }
 }