videopool: improve alignment
authorWim Taymans <wim.taymans@collabora.co.uk>
Mon, 20 Aug 2012 08:16:59 +0000 (10:16 +0200)
committerWim Taymans <wim.taymans@collabora.co.uk>
Mon, 20 Aug 2012 08:25:39 +0000 (10:25 +0200)
Check the alignment of the strides in gst_video_info_align and increase the
padding on the frame until the strides are aligned.

gst-libs/gst/video/gstvideopool.c

index a2310655bd736a0fab8dc46b0227f3cc00a59dcb..45d6fa61692c2f39742aaf16846988f3a7d3c73c 100644 (file)
@@ -102,6 +102,7 @@ gst_video_info_align (GstVideoInfo * info, GstVideoAlignment * align)
   gint width, height;
   gint padded_width, padded_height;
   gint i, n_planes;
+  gboolean aligned;
 
   width = GST_VIDEO_INFO_WIDTH (info);
   height = GST_VIDEO_INFO_HEIGHT (info);
@@ -113,13 +114,31 @@ gst_video_info_align (GstVideoInfo * info, GstVideoAlignment * align)
   padded_width = width + align->padding_left + align->padding_right;
   padded_height = height + align->padding_top + align->padding_bottom;
 
-  gst_video_info_set_format (info, GST_VIDEO_INFO_FORMAT (info),
-      padded_width, padded_height);
+  n_planes = GST_VIDEO_INFO_N_PLANES (info);
+  do {
+    GST_LOG ("padded dimension %u-%u", padded_width, padded_height);
+
+    gst_video_info_set_format (info, GST_VIDEO_INFO_FORMAT (info),
+        padded_width, padded_height);
+
+    /* check alignment */
+    aligned = TRUE;
+    for (i = 0; i < n_planes; i++) {
+      GST_LOG ("plane %d, stride %d, alignment %u", i, info->stride[i],
+          align->stride_align[i]);
+      aligned &= (info->stride[i] & align->stride_align[i]) == 0;
+    }
+    if (aligned)
+      break;
+
+    GST_LOG ("unaligned strides, increasing dimension");
+    /* increase padded_width */
+    padded_width += padded_width & ~(padded_width - 1);
+  } while (!aligned);
 
   info->width = width;
   info->height = height;
 
-  n_planes = GST_VIDEO_INFO_N_PLANES (info);
   if (GST_VIDEO_FORMAT_INFO_HAS_PALETTE (vinfo))
     n_planes--;