xv: use window destructor hook
Wrapping ScreenRec's function pointers is problematic for many reasons, so use the new window destructor hook instead. Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
		
							parent
							
								
									c335d5a92e
								
							
						
					
					
						commit
						f208c7a971
					
				|  | @ -173,7 +173,6 @@ typedef struct { | ||||||
|     int version, revision; |     int version, revision; | ||||||
|     int nAdaptors; |     int nAdaptors; | ||||||
|     XvAdaptorPtr pAdaptors; |     XvAdaptorPtr pAdaptors; | ||||||
|     DestroyWindowProcPtr DestroyWindow; |  | ||||||
|     DestroyPixmapProcPtr DestroyPixmap; |     DestroyPixmapProcPtr DestroyPixmap; | ||||||
|     CloseScreenProcPtr CloseScreen; |     CloseScreenProcPtr CloseScreen; | ||||||
| } XvScreenRec, *XvScreenPtr; | } XvScreenRec, *XvScreenPtr; | ||||||
|  |  | ||||||
|  | @ -81,6 +81,7 @@ SOFTWARE. | ||||||
| #include <X11/extensions/Xv.h> | #include <X11/extensions/Xv.h> | ||||||
| #include <X11/extensions/Xvproto.h> | #include <X11/extensions/Xvproto.h> | ||||||
| 
 | 
 | ||||||
|  | #include "dix/screen_hooks_priv.h" | ||||||
| #include "Xext/xvdix_priv.h" | #include "Xext/xvdix_priv.h" | ||||||
| 
 | 
 | ||||||
| #include "misc.h" | #include "misc.h" | ||||||
|  | @ -143,7 +144,6 @@ static Bool CreateResourceTypes(void); | ||||||
| 
 | 
 | ||||||
| static Bool XvCloseScreen(ScreenPtr); | static Bool XvCloseScreen(ScreenPtr); | ||||||
| static Bool XvDestroyPixmap(PixmapPtr); | static Bool XvDestroyPixmap(PixmapPtr); | ||||||
| static Bool XvDestroyWindow(WindowPtr); |  | ||||||
| static void XvResetProc(ExtensionEntry *); | static void XvResetProc(ExtensionEntry *); | ||||||
| static int XvdiDestroyGrab(void *, XID); | static int XvdiDestroyGrab(void *, XID); | ||||||
| static int XvdiDestroyEncoding(void *, XID); | static int XvdiDestroyEncoding(void *, XID); | ||||||
|  | @ -152,6 +152,7 @@ static int XvdiDestroyPortNotify(void *, XID); | ||||||
| static int XvdiDestroyVideoNotifyList(void *, XID); | static int XvdiDestroyVideoNotifyList(void *, XID); | ||||||
| static int XvdiDestroyPort(void *, XID); | static int XvdiDestroyPort(void *, XID); | ||||||
| static int XvdiSendVideoNotify(XvPortPtr, DrawablePtr, int); | static int XvdiSendVideoNotify(XvPortPtr, DrawablePtr, int); | ||||||
|  | static void XvStopAdaptors(DrawablePtr pDrawable); | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
| ** XvExtensionInit | ** XvExtensionInit | ||||||
|  | @ -257,6 +258,11 @@ CreateResourceTypes(void) | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static void XvWindowDestroy(CallbackListPtr *pcbl, ScreenPtr pScreen, WindowPtr pWin) | ||||||
|  | { | ||||||
|  |     XvStopAdaptors(&pWin->drawable); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| int | int | ||||||
| XvScreenInit(ScreenPtr pScreen) | XvScreenInit(ScreenPtr pScreen) | ||||||
| { | { | ||||||
|  | @ -291,11 +297,11 @@ XvScreenInit(ScreenPtr pScreen) | ||||||
|     dixSetPrivate(&pScreen->devPrivates, XvScreenKey, pxvs); |     dixSetPrivate(&pScreen->devPrivates, XvScreenKey, pxvs); | ||||||
| 
 | 
 | ||||||
|     pxvs->DestroyPixmap = pScreen->DestroyPixmap; |     pxvs->DestroyPixmap = pScreen->DestroyPixmap; | ||||||
|     pxvs->DestroyWindow = pScreen->DestroyWindow; |  | ||||||
|     pxvs->CloseScreen = pScreen->CloseScreen; |     pxvs->CloseScreen = pScreen->CloseScreen; | ||||||
| 
 | 
 | ||||||
|  |     dixScreenHookWindowDestroy(pScreen, XvWindowDestroy); | ||||||
|  | 
 | ||||||
|     pScreen->DestroyPixmap = XvDestroyPixmap; |     pScreen->DestroyPixmap = XvDestroyPixmap; | ||||||
|     pScreen->DestroyWindow = XvDestroyWindow; |  | ||||||
|     pScreen->CloseScreen = XvCloseScreen; |     pScreen->CloseScreen = XvCloseScreen; | ||||||
| 
 | 
 | ||||||
|     return Success; |     return Success; | ||||||
|  | @ -304,13 +310,13 @@ XvScreenInit(ScreenPtr pScreen) | ||||||
| static Bool | static Bool | ||||||
| XvCloseScreen(ScreenPtr pScreen) | XvCloseScreen(ScreenPtr pScreen) | ||||||
| { | { | ||||||
| 
 |  | ||||||
|     XvScreenPtr pxvs; |     XvScreenPtr pxvs; | ||||||
| 
 | 
 | ||||||
|     pxvs = (XvScreenPtr) dixLookupPrivate(&pScreen->devPrivates, XvScreenKey); |     pxvs = (XvScreenPtr) dixLookupPrivate(&pScreen->devPrivates, XvScreenKey); | ||||||
| 
 | 
 | ||||||
|  |     dixScreenUnhookWindowDestroy(pScreen, XvWindowDestroy); | ||||||
|  | 
 | ||||||
|     pScreen->DestroyPixmap = pxvs->DestroyPixmap; |     pScreen->DestroyPixmap = pxvs->DestroyPixmap; | ||||||
|     pScreen->DestroyWindow = pxvs->DestroyWindow; |  | ||||||
|     pScreen->CloseScreen = pxvs->CloseScreen; |     pScreen->CloseScreen = pxvs->CloseScreen; | ||||||
| 
 | 
 | ||||||
|     free(pxvs); |     free(pxvs); | ||||||
|  | @ -385,21 +391,6 @@ XvDestroyPixmap(PixmapPtr pPix) | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static Bool |  | ||||||
| XvDestroyWindow(WindowPtr pWin) |  | ||||||
| { |  | ||||||
|     ScreenPtr pScreen = pWin->drawable.pScreen; |  | ||||||
|     Bool status; |  | ||||||
| 
 |  | ||||||
|     XvStopAdaptors(&pWin->drawable); |  | ||||||
| 
 |  | ||||||
|     SCREEN_PROLOGUE(pScreen, DestroyWindow); |  | ||||||
|     status = (*pScreen->DestroyWindow) (pWin); |  | ||||||
|     SCREEN_EPILOGUE(pScreen, DestroyWindow, XvDestroyWindow); |  | ||||||
| 
 |  | ||||||
|     return status; |  | ||||||
| 
 |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| static int | static int | ||||||
| XvdiDestroyPort(void *pPort, XID id) | XvdiDestroyPort(void *pPort, XID id) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue