2013-12-17 15:17:41 +00:00
|
|
|
|
From bd6c61de441087b808a45ff3fea4fe5a31455c5c Mon Sep 17 00:00:00 2001
|
2013-09-23 18:10:24 +00:00
|
|
|
|
From: Robert Bragg <robert@linux.intel.com>
|
|
|
|
|
Date: Thu, 12 Jan 2012 18:16:08 +0000
|
2013-11-18 22:42:46 +00:00
|
|
|
|
Subject: [PATCH 01/38] dbe: Cleanup in CloseScreen hook not ext CloseDown
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|
|
|
|
|
Instead of registering an extension CloseDownProc when adding the dbe
|
|
|
|
|
extension this patch hooks into pScreen->CloseScreen so that the chain
|
|
|
|
|
of pScreen->DestroyWindow hooks remains valid until all windows have
|
|
|
|
|
been destroyed. Previously it was possible for DbeResetProc to be called
|
|
|
|
|
before the root window had been destroyed and the unwrapping of
|
|
|
|
|
pScreen->DestroyWindow would clobber the chain of callbacks.
|
|
|
|
|
|
|
|
|
|
This is needed for xwayland to be able to know when the root window is
|
|
|
|
|
destroyed so it can unredirect root sub-windows.
|
|
|
|
|
---
|
2013-10-25 17:54:10 +00:00
|
|
|
|
dbe/dbe.c | 41 +++++++++++++++++++++--------------------
|
2013-09-23 18:10:24 +00:00
|
|
|
|
dbe/dbestruct.h | 1 +
|
2013-10-25 17:54:10 +00:00
|
|
|
|
2 files changed, 22 insertions(+), 20 deletions(-)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|
|
|
|
|
diff --git a/dbe/dbe.c b/dbe/dbe.c
|
2013-10-25 17:54:10 +00:00
|
|
|
|
index 5524615..8d8bfb9 100644
|
2013-09-23 18:10:24 +00:00
|
|
|
|
--- a/dbe/dbe.c
|
|
|
|
|
+++ b/dbe/dbe.c
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -288,8 +288,8 @@ ProcDbeAllocateBackBufferName(ClientPtr client)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|
|
|
|
|
/* malloc/realloc a new array and initialize all elements to 0. */
|
|
|
|
|
pDbeWindowPriv->IDs = (XID *) realloc(pIDs,
|
|
|
|
|
- (pDbeWindowPriv->
|
|
|
|
|
- maxAvailableIDs +
|
|
|
|
|
+ (pDbeWindowPriv->maxAvailableIDs
|
|
|
|
|
+ +
|
|
|
|
|
DBE_INCR_MAX_IDS) *
|
|
|
|
|
sizeof(XID));
|
|
|
|
|
if (!pDbeWindowPriv->IDs) {
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -464,7 +464,7 @@ ProcDbeSwapBuffers(ClientPtr client)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
return BadAlloc;
|
|
|
|
|
|
|
|
|
|
/* Get to the swap info appended to the end of the request. */
|
|
|
|
|
- dbeSwapInfo = (xDbeSwapInfo *) &stuff[1];
|
|
|
|
|
+ dbeSwapInfo = (xDbeSwapInfo *) & stuff[1];
|
|
|
|
|
|
|
|
|
|
/* Allocate array to record swap information. */
|
|
|
|
|
swapInfo = (DbeSwapInfoPtr) malloc(nStuff * sizeof(DbeSwapInfoRec));
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -1230,7 +1230,7 @@ DbeWindowPrivDelete(pointer pDbeWinPriv, XID id)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
|
*
|
|
|
|
|
- * DBE DIX Procedure: DbeResetProc
|
|
|
|
|
+ * DBE DIX Procedure: DbeCloseScreen
|
|
|
|
|
*
|
|
|
|
|
* Description:
|
|
|
|
|
*
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -1239,25 +1239,23 @@ DbeWindowPrivDelete(pointer pDbeWinPriv, XID id)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
* other tasks related to shutting down the extension.
|
|
|
|
|
*
|
|
|
|
|
*****************************************************************************/
|
|
|
|
|
-static void
|
|
|
|
|
-DbeResetProc(ExtensionEntry * extEntry)
|
|
|
|
|
+static Bool
|
|
|
|
|
+DbeCloseScreen(ScreenPtr pScreen)
|
|
|
|
|
{
|
|
|
|
|
- int i;
|
|
|
|
|
- ScreenPtr pScreen;
|
|
|
|
|
- DbeScreenPrivPtr pDbeScreenPriv;
|
|
|
|
|
+ DbeScreenPrivPtr pDbeScreenPriv = DBE_SCREEN_PRIV(pScreen);
|
|
|
|
|
|
|
|
|
|
- for (i = 0; i < screenInfo.numScreens; i++) {
|
|
|
|
|
- pScreen = screenInfo.screens[i];
|
|
|
|
|
- pDbeScreenPriv = DBE_SCREEN_PRIV(pScreen);
|
|
|
|
|
+ if (pDbeScreenPriv) {
|
|
|
|
|
+ /* Unwrap DestroyWindow, which was wrapped in DbeExtensionInit(). */
|
|
|
|
|
+ pScreen->DestroyWindow = pDbeScreenPriv->DestroyWindow;
|
|
|
|
|
|
|
|
|
|
- if (pDbeScreenPriv) {
|
|
|
|
|
- /* Unwrap DestroyWindow, which was wrapped in DbeExtensionInit(). */
|
|
|
|
|
- pScreen->DestroyWindow = pDbeScreenPriv->DestroyWindow;
|
2013-10-25 17:54:10 +00:00
|
|
|
|
- pScreen->PositionWindow = pDbeScreenPriv->PositionWindow;
|
2013-09-23 18:10:24 +00:00
|
|
|
|
- free(pDbeScreenPriv);
|
|
|
|
|
- }
|
2013-10-25 17:54:10 +00:00
|
|
|
|
+ /* Unwrap CloseScreen, which was wrapped in DbeExtensionInit(). */
|
|
|
|
|
+ pScreen->CloseScreen = pDbeScreenPriv->CloseScreen;
|
|
|
|
|
+
|
2013-09-23 18:10:24 +00:00
|
|
|
|
+ free(pDbeScreenPriv);
|
|
|
|
|
}
|
|
|
|
|
-} /* DbeResetProc() */
|
|
|
|
|
+
|
|
|
|
|
+ return (*pScreen->CloseScreen) (pScreen);
|
|
|
|
|
+} /* DbeCloseScreen */
|
|
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
|
|
|
*
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -1427,6 +1425,9 @@ DbeExtensionInit(void)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|
|
|
|
|
pDbeScreenPriv->DestroyWindow = pScreen->DestroyWindow;
|
|
|
|
|
pScreen->DestroyWindow = DbeDestroyWindow;
|
|
|
|
|
+
|
|
|
|
|
+ pDbeScreenPriv->CloseScreen = pScreen->CloseScreen;
|
|
|
|
|
+ pScreen->CloseScreen = DbeCloseScreen;
|
|
|
|
|
}
|
|
|
|
|
else {
|
|
|
|
|
/* DDX initialization failed. Stub the screen. */
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -1454,7 +1455,7 @@ DbeExtensionInit(void)
|
2013-09-23 18:10:24 +00:00
|
|
|
|
/* Now add the extension. */
|
|
|
|
|
extEntry = AddExtension(DBE_PROTOCOL_NAME, DbeNumberEvents,
|
|
|
|
|
DbeNumberErrors, ProcDbeDispatch, SProcDbeDispatch,
|
|
|
|
|
- DbeResetProc, StandardMinorOpcode);
|
|
|
|
|
+ NULL, StandardMinorOpcode);
|
|
|
|
|
|
|
|
|
|
dbeErrorBase = extEntry->errorBase;
|
|
|
|
|
SetResourceTypeErrorValue(dbeWindowPrivResType,
|
|
|
|
|
diff --git a/dbe/dbestruct.h b/dbe/dbestruct.h
|
2013-10-25 17:54:10 +00:00
|
|
|
|
index 2002066..7733d0e 100644
|
2013-09-23 18:10:24 +00:00
|
|
|
|
--- a/dbe/dbestruct.h
|
|
|
|
|
+++ b/dbe/dbestruct.h
|
2013-10-25 17:54:10 +00:00
|
|
|
|
@@ -176,6 +176,7 @@ typedef struct _DbeScreenPrivRec {
|
2013-09-23 18:10:24 +00:00
|
|
|
|
*/
|
|
|
|
|
PositionWindowProcPtr PositionWindow;
|
|
|
|
|
DestroyWindowProcPtr DestroyWindow;
|
|
|
|
|
+ CloseScreenProcPtr CloseScreen;
|
|
|
|
|
|
|
|
|
|
/* Per-screen DIX routines */
|
|
|
|
|
Bool (*SetupBackgroundPainter) (WindowPtr /*pWin */ ,
|
|
|
|
|
--
|
2013-12-17 15:17:41 +00:00
|
|
|
|
1.8.4.2
|
2013-09-23 18:10:24 +00:00
|
|
|
|
|