videoparse: Fix framesize calculation
authorNicolas Dufresne <nicolas.dufresne@collabora.com>
Thu, 28 Jan 2016 16:56:36 +0000 (11:56 -0500)
committerNicolas Dufresne <nicolas.dufresne@collabora.com>
Thu, 28 Jan 2016 19:48:11 +0000 (14:48 -0500)
When the framesize is not specified, we try and calculate a size from
the strides and offset information. This was done with the sum of
offsets + the size of the last frame. That is just wrong method. We also
need to account for video meta that may be flipping two planes. An
example is if you convert I420 to YV12 by flipping the two last offsets.

https://bugzilla.gnome.org/show_bug.cgi?id=760270

gst/rawparse/gstvideoparse.c

index 92733c6..717b21a 100644 (file)
@@ -467,10 +467,13 @@ gst_video_parse_update_info (GstVideoParse * vp)
   if (update_size) {
     framesize = 0;
 
-    for (i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++)
-      framesize += info->offset[i];
+    for (i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++) {
+      gint planesize = info->offset[i];
+      planesize += gst_video_parse_get_plane_size (info, i);
 
-    framesize += gst_video_parse_get_plane_size (info, i - 1);
+      if (planesize > framesize)
+        framesize = planesize;
+    }
 
     info->size = framesize;
   }