xfree86: xvmc: use CloseScreen hook
Wrapping ScreenRec's function pointers is problematic for many reasons, so use the new screen close notify hook instead. Signed-off-by: Enrico Weigelt, metux IT consult <info@metux.net>
This commit is contained in:
parent
743c35c562
commit
0bfea99672
|
@ -36,6 +36,9 @@
|
||||||
|
|
||||||
#include <X11/X.h>
|
#include <X11/X.h>
|
||||||
#include <X11/Xproto.h>
|
#include <X11/Xproto.h>
|
||||||
|
|
||||||
|
#include "dix/screen_hooks_priv.h"
|
||||||
|
|
||||||
#include "scrnintstr.h"
|
#include "scrnintstr.h"
|
||||||
#include "resource.h"
|
#include "resource.h"
|
||||||
#include "dixstruct.h"
|
#include "dixstruct.h"
|
||||||
|
@ -44,7 +47,6 @@
|
||||||
#include "xf86xvmc.h"
|
#include "xf86xvmc.h"
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
CloseScreenProcPtr CloseScreen;
|
|
||||||
int num_adaptors;
|
int num_adaptors;
|
||||||
XF86MCAdaptorPtr *adaptors;
|
XF86MCAdaptorPtr *adaptors;
|
||||||
XvMCAdaptorPtr dixinfo;
|
XvMCAdaptorPtr dixinfo;
|
||||||
|
@ -129,17 +131,18 @@ xf86XvMCDestroySubpicture(XvMCSubpicturePtr pSubpicture)
|
||||||
pSubpicture);
|
pSubpicture);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Bool
|
static void xf86XvMCCloseScreen(CallbackListPtr *pcbl,
|
||||||
xf86XvMCCloseScreen(ScreenPtr pScreen)
|
ScreenPtr pScreen, void *unused)
|
||||||
{
|
{
|
||||||
xf86XvMCScreenPtr pScreenPriv = XF86XVMC_GET_PRIVATE(pScreen);
|
dixScreenUnhookClose(pScreen, xf86XvMCCloseScreen);
|
||||||
|
|
||||||
pScreen->CloseScreen = pScreenPriv->CloseScreen;
|
xf86XvMCScreenPtr pScreenPriv = XF86XVMC_GET_PRIVATE(pScreen);
|
||||||
|
if (!pScreenPriv)
|
||||||
|
return;
|
||||||
|
|
||||||
free(pScreenPriv->dixinfo);
|
free(pScreenPriv->dixinfo);
|
||||||
free(pScreenPriv);
|
free(pScreenPriv);
|
||||||
|
dixSetPrivate(&pScreen->devPrivates, XF86XvMCScreenKey, NULL);
|
||||||
return (*pScreen->CloseScreen) (pScreen);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Bool
|
Bool
|
||||||
|
@ -169,9 +172,7 @@ xf86XvMCScreenInit(ScreenPtr pScreen,
|
||||||
}
|
}
|
||||||
|
|
||||||
dixSetPrivate(&pScreen->devPrivates, XF86XvMCScreenKey, pScreenPriv);
|
dixSetPrivate(&pScreen->devPrivates, XF86XvMCScreenKey, pScreenPriv);
|
||||||
|
dixScreenHookClose(pScreen, xf86XvMCCloseScreen);
|
||||||
pScreenPriv->CloseScreen = pScreen->CloseScreen;
|
|
||||||
pScreen->CloseScreen = xf86XvMCCloseScreen;
|
|
||||||
|
|
||||||
pScreenPriv->num_adaptors = num_adaptors;
|
pScreenPriv->num_adaptors = num_adaptors;
|
||||||
pScreenPriv->adaptors = adaptors;
|
pScreenPriv->adaptors = adaptors;
|
||||||
|
|
|
@ -43,7 +43,6 @@ typedef struct {
|
||||||
Bool (*EnterVT) (ScrnInfoPtr);
|
Bool (*EnterVT) (ScrnInfoPtr);
|
||||||
void (*LeaveVT) (ScrnInfoPtr);
|
void (*LeaveVT) (ScrnInfoPtr);
|
||||||
xf86ModeSetProc *ModeSet;
|
xf86ModeSetProc *ModeSet;
|
||||||
CloseScreenProcPtr CloseScreen;
|
|
||||||
} XF86XVScreenRec, *XF86XVScreenPtr;
|
} XF86XVScreenRec, *XF86XVScreenPtr;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
Loading…
Reference in New Issue