From ce82ae1964b2115a780786676c614546297a79c9 Mon Sep 17 00:00:00 2001 From: Adam Jackson Date: Tue, 2 Feb 2016 14:10:49 -0500 Subject: [PATCH] res: Account for GLXPixmap references too MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit GLX_EXT_tetxure_from_pixmap operates on a GLXPixmap, which takes a reference on the backing pixmap; that GLXPixmap might be long-lived, so we should account for it in ResQueryClientPixmapBytes. Acked-by: Michel Dänzer Signed-off-by: Adam Jackson --- glx/glxext.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/glx/glxext.c b/glx/glxext.c index 0de910936..d595a05cb 100644 --- a/glx/glxext.c +++ b/glx/glxext.c @@ -336,6 +336,23 @@ checkScreenVisuals(void) return False; } +static void +GetGLXDrawableBytes(void *value, XID id, ResourceSizePtr size) +{ + __GLXdrawable *draw = value; + + size->resourceSize = 0; + size->pixmapRefSize = 0; + size->refCnt = 1; + + if (draw->type == GLX_DRAWABLE_PIXMAP) { + SizeType pixmapSizeFunc = GetResourceTypeSizeFunc(RT_PIXMAP); + ResourceSizeRec pixmapSize = { 0, }; + pixmapSizeFunc((PixmapPtr)draw->pDraw, draw->pDraw->id, &pixmapSize); + size->pixmapRefSize += pixmapSize.pixmapRefSize; + } +} + /* ** Initialize the GLX extension. */ @@ -365,6 +382,8 @@ GlxExtensionInit(void) if (!__glXContextRes || !__glXDrawableRes) return; + SetResourceTypeSizeFunc(__glXDrawableRes, GetGLXDrawableBytes); + if (!dixRegisterPrivateKey (&glxClientPrivateKeyRec, PRIVATE_CLIENT, sizeof(__GLXclientState))) return;