Mesa (master): st/va: avoid dereference after free in vlVaDestroyImage

Julien Isorce cap at kemper.freedesktop.org
Fri Apr 8 05:59:04 UTC 2016


Module: Mesa
Branch: master
Commit: b9855dcdf7c94605305d6372d1f9883f76d10b6a
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=b9855dcdf7c94605305d6372d1f9883f76d10b6a

Author: Thomas Hindoe Paaboel Andersen <phomes at gmail.com>
Date:   Sat Mar  5 13:07:07 2016 +0100

st/va: avoid dereference after free in vlVaDestroyImage

Cc: "11.1 11.2" <mesa-stable at lists.freedesktop.org>
Reviewed-by: Emil Velikov <emil.l.velikov at gmail.com>
Tested-by: Julien Isorce <j.isorce at samsung.com>

---

 src/gallium/state_trackers/va/image.c | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/src/gallium/state_trackers/va/image.c b/src/gallium/state_trackers/va/image.c
index 2c42a98..92d014c 100644
--- a/src/gallium/state_trackers/va/image.c
+++ b/src/gallium/state_trackers/va/image.c
@@ -280,6 +280,7 @@ vlVaDestroyImage(VADriverContextP ctx, VAImageID image)
 {
    vlVaDriver *drv;
    VAImage  *vaimage;
+   VAStatus status;
 
    if (!ctx)
       return VA_STATUS_ERROR_INVALID_CONTEXT;
@@ -294,8 +295,9 @@ vlVaDestroyImage(VADriverContextP ctx, VAImageID image)
 
    handle_table_remove(VL_VA_DRIVER(ctx)->htab, image);
    pipe_mutex_unlock(drv->mutex);
+   status = vlVaDestroyBuffer(ctx, vaimage->buf);
    FREE(vaimage);
-   return vlVaDestroyBuffer(ctx, vaimage->buf);
+   return status;
 }
 
 VAStatus




More information about the mesa-commit mailing list