From: Mandeep Singh Baines Date: Tue, 10 Apr 2012 21:48:14 +0000 (-0700) Subject: egl_dri2: fix aux buffer leak in drm platform X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=0695cf68f5afb903f93cc3779444d095b218271d;p=mesa.git egl_dri2: fix aux buffer leak in drm platform Keep a reference to any newly allocated aux buffers to avoid re-allocating for every st_framebuffer_validate() (i.e. leaking). Signed-off-by: Mandeep Singh Baines Signed-off-by: Kristian Høgsberg --- diff --git a/src/egl/drivers/dri2/platform_drm.c b/src/egl/drivers/dri2/platform_drm.c index 18ecd173f4e..54067ff7814 100644 --- a/src/egl/drivers/dri2/platform_drm.c +++ b/src/egl/drivers/dri2/platform_drm.c @@ -220,16 +220,15 @@ get_aux_bo(struct dri2_egl_surface *dri2_surf, { struct dri2_egl_display *dri2_dpy = dri2_egl_display(dri2_surf->base.Resource.Display); - __DRIbuffer *b; + __DRIbuffer *b = dri2_surf->dri_buffers[attachment]; - b = NULL; - if (dri2_surf->dri_buffers[attachment]) - b = dri2_surf->dri_buffers[attachment]; - if (b == NULL) + if (b == NULL) { b = dri2_dpy->dri2->allocateBuffer(dri2_dpy->dri_screen, attachment, format, dri2_surf->base.Width, dri2_surf->base.Height); + dri2_surf->dri_buffers[attachment] = b; + } if (b == NULL) return -1;