(!1714) exa: use PixmapDestroy hook
Wrapping ScreenRec's function pointers is problematic for many reasons, so use the new pixmap destroy notify hook instead. Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									749bf16c09
								
							
						
					
					
						commit
						1e258b6f3d
					
				
							
								
								
									
										16
									
								
								exa/exa.c
								
								
								
								
							
							
						
						
									
										16
									
								
								exa/exa.c
								
								
								
								
							|  | @ -740,6 +740,11 @@ exaCloseScreen(ScreenPtr pScreen) | ||||||
|     ExaScreenPriv(pScreen); |     ExaScreenPriv(pScreen); | ||||||
|     PictureScreenPtr ps = GetPictureScreenIfSet(pScreen); |     PictureScreenPtr ps = GetPictureScreenIfSet(pScreen); | ||||||
| 
 | 
 | ||||||
|  |     /* doesn't matter which one actually was registered */ | ||||||
|  |     dixScreenUnhookPixmapDestroy(pScreen, exaPixmapDestroy_classic, 0); | ||||||
|  |     dixScreenUnhookPixmapDestroy(pScreen, exaPixmapDestroy_driver, 0); | ||||||
|  |     dixScreenUnhookPixmapDestroy(pScreen, exaPixmapDestroy_mixed, 0); | ||||||
|  | 
 | ||||||
|     if (ps->Glyphs == exaGlyphs) |     if (ps->Glyphs == exaGlyphs) | ||||||
|         exaGlyphsFini(pScreen); |         exaGlyphsFini(pScreen); | ||||||
| 
 | 
 | ||||||
|  | @ -753,8 +758,6 @@ exaCloseScreen(ScreenPtr pScreen) | ||||||
|     unwrap(pExaScr, pScreen, GetSpans); |     unwrap(pExaScr, pScreen, GetSpans); | ||||||
|     if (pExaScr->SavedCreatePixmap) |     if (pExaScr->SavedCreatePixmap) | ||||||
|         unwrap(pExaScr, pScreen, CreatePixmap); |         unwrap(pExaScr, pScreen, CreatePixmap); | ||||||
|     if (pExaScr->SavedDestroyPixmap) |  | ||||||
|         unwrap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
|     if (pExaScr->SavedModifyPixmapHeader) |     if (pExaScr->SavedModifyPixmapHeader) | ||||||
|         unwrap(pExaScr, pScreen, ModifyPixmapHeader); |         unwrap(pExaScr, pScreen, ModifyPixmapHeader); | ||||||
|     unwrap(pExaScr, pScreen, CopyWindow); |     unwrap(pExaScr, pScreen, CopyWindow); | ||||||
|  | @ -955,8 +958,9 @@ exaDriverInit(ScreenPtr pScreen, ExaDriverPtr pScreenInfo) | ||||||
|         } |         } | ||||||
|         if (pExaScr->info->flags & EXA_HANDLES_PIXMAPS) { |         if (pExaScr->info->flags & EXA_HANDLES_PIXMAPS) { | ||||||
|             if (pExaScr->info->flags & EXA_MIXED_PIXMAPS) { |             if (pExaScr->info->flags & EXA_MIXED_PIXMAPS) { | ||||||
|  |                 dixScreenHookPixmapDestroy(pScreen, exaPixmapDestroy_mixed, 0); | ||||||
|  | 
 | ||||||
|                 wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_mixed); |                 wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_mixed); | ||||||
|                 wrap(pExaScr, pScreen, DestroyPixmap, exaDestroyPixmap_mixed); |  | ||||||
|                 wrap(pExaScr, pScreen, ModifyPixmapHeader, |                 wrap(pExaScr, pScreen, ModifyPixmapHeader, | ||||||
|                      exaModifyPixmapHeader_mixed); |                      exaModifyPixmapHeader_mixed); | ||||||
|                 wrap(pExaScr, pScreen, SharePixmapBacking, exaSharePixmapBacking_mixed); |                 wrap(pExaScr, pScreen, SharePixmapBacking, exaSharePixmapBacking_mixed); | ||||||
|  | @ -969,8 +973,9 @@ exaDriverInit(ScreenPtr pScreen, ExaDriverPtr pScreenInfo) | ||||||
|                 pExaScr->prepare_access_reg = exaPrepareAccessReg_mixed; |                 pExaScr->prepare_access_reg = exaPrepareAccessReg_mixed; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|  |                 dixScreenHookPixmapDestroy(pScreen, exaPixmapDestroy_driver, 0); | ||||||
|  | 
 | ||||||
|                 wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_driver); |                 wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_driver); | ||||||
|                 wrap(pExaScr, pScreen, DestroyPixmap, exaDestroyPixmap_driver); |  | ||||||
|                 wrap(pExaScr, pScreen, ModifyPixmapHeader, |                 wrap(pExaScr, pScreen, ModifyPixmapHeader, | ||||||
|                      exaModifyPixmapHeader_driver); |                      exaModifyPixmapHeader_driver); | ||||||
|                 pExaScr->do_migration = NULL; |                 pExaScr->do_migration = NULL; | ||||||
|  | @ -981,8 +986,9 @@ exaDriverInit(ScreenPtr pScreen, ExaDriverPtr pScreenInfo) | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|  |             dixScreenHookPixmapDestroy(pScreen, exaPixmapDestroy_classic, 0); | ||||||
|  | 
 | ||||||
|             wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_classic); |             wrap(pExaScr, pScreen, CreatePixmap, exaCreatePixmap_classic); | ||||||
|             wrap(pExaScr, pScreen, DestroyPixmap, exaDestroyPixmap_classic); |  | ||||||
|             wrap(pExaScr, pScreen, ModifyPixmapHeader, |             wrap(pExaScr, pScreen, ModifyPixmapHeader, | ||||||
|                  exaModifyPixmapHeader_classic); |                  exaModifyPixmapHeader_classic); | ||||||
|             pExaScr->do_migration = exaDoMigration_classic; |             pExaScr->do_migration = exaDoMigration_classic; | ||||||
|  |  | ||||||
|  | @ -202,42 +202,26 @@ exaModifyPixmapHeader_classic(PixmapPtr pPixmap, int width, int height, | ||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | void exaPixmapDestroy_classic(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg) | ||||||
| exaDestroyPixmap_classic(PixmapPtr pPixmap) |  | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = pPixmap->drawable.pScreen; |     ExaPixmapPriv(pPixmap); | ||||||
|  |     if (!pExaPixmap) // we're called on an error path
 | ||||||
|  |         return; | ||||||
| 
 | 
 | ||||||
|     ExaScreenPriv(pScreen); |     exaDestroyPixmap(pPixmap); | ||||||
|     Bool ret = TRUE; |  | ||||||
| 
 | 
 | ||||||
|     if (pPixmap->refcnt == 1) { |     if (pExaPixmap->area) { | ||||||
|         ExaPixmapPriv(pPixmap); |         DBG_PIXMAP(("-- 0x%p (0x%x) (%dx%d)\n", | ||||||
|         if (!pExaPixmap) // we're called on an error path
 |                     (void *) pPixmap->drawable.id, | ||||||
|             goto out; |                     ExaGetPixmapPriv(pPixmap)->area->offset, | ||||||
| 
 |                     pPixmap->drawable.width, pPixmap->drawable.height)); | ||||||
|         exaDestroyPixmap(pPixmap); |         /* Free the offscreen area */ | ||||||
| 
 |         exaOffscreenFree(pPixmap->drawable.pScreen, pExaPixmap->area); | ||||||
|         if (pExaPixmap->area) { |         pPixmap->devPrivate.ptr = pExaPixmap->sys_ptr; | ||||||
|             DBG_PIXMAP(("-- 0x%p (0x%x) (%dx%d)\n", |         pPixmap->devKind = pExaPixmap->sys_pitch; | ||||||
|                         (void *) pPixmap->drawable.id, |  | ||||||
|                         ExaGetPixmapPriv(pPixmap)->area->offset, |  | ||||||
|                         pPixmap->drawable.width, pPixmap->drawable.height)); |  | ||||||
|             /* Free the offscreen area */ |  | ||||||
|             exaOffscreenFree(pPixmap->drawable.pScreen, pExaPixmap->area); |  | ||||||
|             pPixmap->devPrivate.ptr = pExaPixmap->sys_ptr; |  | ||||||
|             pPixmap->devKind = pExaPixmap->sys_pitch; |  | ||||||
|         } |  | ||||||
|         RegionUninit(&pExaPixmap->validSys); |  | ||||||
|         RegionUninit(&pExaPixmap->validFB); |  | ||||||
|     } |     } | ||||||
| 
 |     RegionUninit(&pExaPixmap->validSys); | ||||||
| out: |     RegionUninit(&pExaPixmap->validFB); | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
|     if (pScreen->DestroyPixmap) |  | ||||||
|         ret = pScreen->DestroyPixmap(pPixmap); |  | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
| 
 |  | ||||||
|     return ret; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  |  | ||||||
|  | @ -183,33 +183,19 @@ exaModifyPixmapHeader_driver(PixmapPtr pPixmap, int width, int height, | ||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | void exaPixmapDestroy_driver(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg) | ||||||
| exaDestroyPixmap_driver(PixmapPtr pPixmap) |  | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = pPixmap->drawable.pScreen; |  | ||||||
| 
 |  | ||||||
|     ExaScreenPriv(pScreen); |     ExaScreenPriv(pScreen); | ||||||
|     Bool ret = TRUE; |  | ||||||
| 
 | 
 | ||||||
|     if (pPixmap->refcnt == 1) { |     ExaPixmapPriv(pPixmap); | ||||||
|         ExaPixmapPriv(pPixmap); |     if (!pExaPixmap) // we're called on an error path
 | ||||||
|         if (!pExaPixmap) // we're called on an error path
 |         return; | ||||||
|             goto out; |  | ||||||
| 
 | 
 | ||||||
|         exaDestroyPixmap(pPixmap); |     exaDestroyPixmap(pPixmap); | ||||||
| 
 | 
 | ||||||
|         if (pExaPixmap->driverPriv) |     if (pExaPixmap->driverPriv) | ||||||
|             pExaScr->info->DestroyPixmap(pScreen, pExaPixmap->driverPriv); |         pExaScr->info->DestroyPixmap(pScreen, pExaPixmap->driverPriv); | ||||||
|         pExaPixmap->driverPriv = NULL; |     pExaPixmap->driverPriv = NULL; | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| out: |  | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
|     if (pScreen->DestroyPixmap) |  | ||||||
|         ret = pScreen->DestroyPixmap(pPixmap); |  | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
| 
 |  | ||||||
|     return ret; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  |  | ||||||
|  | @ -239,42 +239,28 @@ exaModifyPixmapHeader_mixed(PixmapPtr pPixmap, int width, int height, int depth, | ||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | void exaPixmapDestroy_mixed(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg) | ||||||
| exaDestroyPixmap_mixed(PixmapPtr pPixmap) |  | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = pPixmap->drawable.pScreen; |  | ||||||
| 
 |  | ||||||
|     ExaScreenPriv(pScreen); |     ExaScreenPriv(pScreen); | ||||||
|     Bool ret = TRUE; |  | ||||||
| 
 | 
 | ||||||
|     if (pPixmap->refcnt == 1) { |     ExaPixmapPriv(pPixmap); | ||||||
|         ExaPixmapPriv(pPixmap); |     if (!pExaPixmap) // we're called on an error path
 | ||||||
|         if (!pExaPixmap) |         return; | ||||||
|             goto out; // we're called on an error path
 |  | ||||||
| 
 | 
 | ||||||
|         exaDestroyPixmap(pPixmap); |     exaDestroyPixmap(pPixmap); | ||||||
| 
 | 
 | ||||||
|         if (pExaScr->deferred_mixed_pixmap == pPixmap) |     if (pExaScr->deferred_mixed_pixmap == pPixmap) | ||||||
|             pExaScr->deferred_mixed_pixmap = NULL; |         pExaScr->deferred_mixed_pixmap = NULL; | ||||||
| 
 | 
 | ||||||
|         if (pExaPixmap->driverPriv) |     if (pExaPixmap->driverPriv) | ||||||
|             pExaScr->info->DestroyPixmap(pScreen, pExaPixmap->driverPriv); |         pExaScr->info->DestroyPixmap(pScreen, pExaPixmap->driverPriv); | ||||||
|         pExaPixmap->driverPriv = NULL; |     pExaPixmap->driverPriv = NULL; | ||||||
| 
 | 
 | ||||||
|         if (pExaPixmap->pDamage) { |     if (pExaPixmap->pDamage) { | ||||||
|             free(pExaPixmap->sys_ptr); |         free(pExaPixmap->sys_ptr); | ||||||
|             pExaPixmap->sys_ptr = NULL; |         pExaPixmap->sys_ptr = NULL; | ||||||
|             pExaPixmap->pDamage = NULL; |         pExaPixmap->pDamage = NULL; | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| out: |  | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
|     if (pScreen->DestroyPixmap) |  | ||||||
|         ret = pScreen->DestroyPixmap(pPixmap); |  | ||||||
|     swap(pExaScr, pScreen, DestroyPixmap); |  | ||||||
| 
 |  | ||||||
|     return ret; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  |  | ||||||
|  | @ -156,7 +156,6 @@ typedef struct { | ||||||
|     GetImageProcPtr SavedGetImage; |     GetImageProcPtr SavedGetImage; | ||||||
|     GetSpansProcPtr SavedGetSpans; |     GetSpansProcPtr SavedGetSpans; | ||||||
|     CreatePixmapProcPtr SavedCreatePixmap; |     CreatePixmapProcPtr SavedCreatePixmap; | ||||||
|     DestroyPixmapProcPtr SavedDestroyPixmap; |  | ||||||
|     CopyWindowProcPtr SavedCopyWindow; |     CopyWindowProcPtr SavedCopyWindow; | ||||||
|     ChangeWindowAttributesProcPtr SavedChangeWindowAttributes; |     ChangeWindowAttributesProcPtr SavedChangeWindowAttributes; | ||||||
|     BitmapToRegionProcPtr SavedBitmapToRegion; |     BitmapToRegionProcPtr SavedBitmapToRegion; | ||||||
|  | @ -590,8 +589,7 @@ exaModifyPixmapHeader_classic(PixmapPtr pPixmap, int width, int height, | ||||||
|                               int depth, int bitsPerPixel, int devKind, |                               int depth, int bitsPerPixel, int devKind, | ||||||
|                               void *pPixData); |                               void *pPixData); | ||||||
| 
 | 
 | ||||||
| Bool | void  exaPixmapDestroy_classic(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg); | ||||||
|  exaDestroyPixmap_classic(PixmapPtr pPixmap); |  | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  exaPixmapHasGpuCopy_classic(PixmapPtr pPixmap); |  exaPixmapHasGpuCopy_classic(PixmapPtr pPixmap); | ||||||
|  | @ -608,8 +606,7 @@ exaModifyPixmapHeader_driver(PixmapPtr pPixmap, int width, int height, | ||||||
|                              int depth, int bitsPerPixel, int devKind, |                              int depth, int bitsPerPixel, int devKind, | ||||||
|                              void *pPixData); |                              void *pPixData); | ||||||
| 
 | 
 | ||||||
| Bool | void exaPixmapDestroy_driver(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg); | ||||||
|  exaDestroyPixmap_driver(PixmapPtr pPixmap); |  | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  exaPixmapHasGpuCopy_driver(PixmapPtr pPixmap); |  exaPixmapHasGpuCopy_driver(PixmapPtr pPixmap); | ||||||
|  | @ -625,8 +622,7 @@ Bool | ||||||
| exaModifyPixmapHeader_mixed(PixmapPtr pPixmap, int width, int height, int depth, | exaModifyPixmapHeader_mixed(PixmapPtr pPixmap, int width, int height, int depth, | ||||||
|                             int bitsPerPixel, int devKind, void *pPixData); |                             int bitsPerPixel, int devKind, void *pPixData); | ||||||
| 
 | 
 | ||||||
| Bool | void exaPixmapDestroy_mixed(ScreenPtr pScreen, PixmapPtr pPixmap, void *arg); | ||||||
|  exaDestroyPixmap_mixed(PixmapPtr pPixmap); |  | ||||||
| 
 | 
 | ||||||
| Bool | Bool | ||||||
|  exaPixmapHasGpuCopy_mixed(PixmapPtr pPixmap); |  exaPixmapHasGpuCopy_mixed(PixmapPtr pPixmap); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue