vaapiupload: fix illegal write in ensure_image().
authorHolger Kaelberer <hk@getslash.de>
Mon, 25 Feb 2013 23:38:24 +0000 (00:38 +0100)
committerGwenole Beauchesne <gwenole.beauchesne@intel.com>
Tue, 26 Feb 2013 10:27:07 +0000 (11:27 +0100)
Fix ensure_image() to only zero-initialize the first line of each plane.
Properly initializing each plane to their full vertical resolution would
require to actually compute it based on the image format.

In particular, for NV12 images, the UV plane has half vertical resolution
vs. the Y plane. So using the full image height to initialize the UV plane
will obviously lead to a buffer overflow. Likewise for other YUV format.

Since ensure_image() is only a helper function to initialize something,
and not necessarily the whole thing, it is fine to initializ the first
line only. Besides, the target surface is not rendered either.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
gst/vaapi/gstvaapiuploader.c

index 460435e54a6e67760cbb88e68a6ed893f90ec88a..437f6af489d4b043d3af7ca1c7e052a96398845d 100644 (file)
@@ -108,7 +108,7 @@ ensure_image(GstVaapiImage *image)
     for (i = 0; i < num_planes; i++) {
         guchar * const plane = gst_vaapi_image_get_plane(image, i);
         if (plane)
-            memset(plane, 0, height * gst_vaapi_image_get_pitch(image, i));
+            memset(plane, 0, gst_vaapi_image_get_pitch(image, i));
     }
 
     if (!gst_vaapi_image_unmap(image))