Unwrap/rewrap EnterVT/LeaveVT completely, Fixes 28998
Because some EnterVT code needs to remove it self from the
call chain, we need to fix all of the wrappers to correctly
unwrap/rewrap during the call chain. This is a follow-on to the fix
for bug 27114 in commit 68a9ee8370
.
Signed-off-by: Keith Packard <keithp@keithp.com>
Tested-by: Jesse Barnes <jesse.barnes@intel.com>
Reviewed-by: Daniel Stone <daniel@fooishbar.org>
Reviewed-by: Tiago Vignatti <tiago.vignatti@nokia.com>
This commit is contained in:
parent
3209b094a3
commit
d75e8146c4
17
glx/glxdri.c
17
glx/glxdri.c
|
@ -866,12 +866,21 @@ static const char dri_driver_path[] = DRI_DRIVER_PATH;
|
||||||
static Bool
|
static Bool
|
||||||
glxDRIEnterVT (int index, int flags)
|
glxDRIEnterVT (int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr scrn = xf86Screens[index];
|
||||||
|
Bool ret;
|
||||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||||
glxGetScreen(screenInfo.screens[index]);
|
glxGetScreen(screenInfo.screens[index]);
|
||||||
|
|
||||||
LogMessage(X_INFO, "AIGLX: Resuming AIGLX clients after VT switch\n");
|
LogMessage(X_INFO, "AIGLX: Resuming AIGLX clients after VT switch\n");
|
||||||
|
|
||||||
if (!(*screen->enterVT) (index, flags))
|
scrn->EnterVT = screen->enterVT;
|
||||||
|
|
||||||
|
ret = scrn->EnterVT (index, flags);
|
||||||
|
|
||||||
|
screen->enterVT = scrn->EnterVT;
|
||||||
|
scrn->EnterVT = glxDRIEnterVT;
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
glxResumeClients();
|
glxResumeClients();
|
||||||
|
@ -882,6 +891,7 @@ glxDRIEnterVT (int index, int flags)
|
||||||
static void
|
static void
|
||||||
glxDRILeaveVT (int index, int flags)
|
glxDRILeaveVT (int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr scrn = xf86Screens[index];
|
||||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||||
glxGetScreen(screenInfo.screens[index]);
|
glxGetScreen(screenInfo.screens[index]);
|
||||||
|
|
||||||
|
@ -889,7 +899,10 @@ glxDRILeaveVT (int index, int flags)
|
||||||
|
|
||||||
glxSuspendClients();
|
glxSuspendClients();
|
||||||
|
|
||||||
return (*screen->leaveVT) (index, flags);
|
scrn->LeaveVT = screen->leaveVT;
|
||||||
|
(*screen->leaveVT) (index, flags);
|
||||||
|
screen->leaveVT = scrn->LeaveVT;
|
||||||
|
scrn->LeaveVT = glxDRILeaveVT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -605,12 +605,21 @@ static const char dri_driver_path[] = DRI_DRIVER_PATH;
|
||||||
static Bool
|
static Bool
|
||||||
glxDRIEnterVT (int index, int flags)
|
glxDRIEnterVT (int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr scrn = xf86Screens[index];
|
||||||
|
Bool ret;
|
||||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||||
glxGetScreen(screenInfo.screens[index]);
|
glxGetScreen(screenInfo.screens[index]);
|
||||||
|
|
||||||
LogMessage(X_INFO, "AIGLX: Resuming AIGLX clients after VT switch\n");
|
LogMessage(X_INFO, "AIGLX: Resuming AIGLX clients after VT switch\n");
|
||||||
|
|
||||||
if (!(*screen->enterVT) (index, flags))
|
scrn->EnterVT = screen->enterVT;
|
||||||
|
|
||||||
|
ret = scrn->EnterVT (index, flags);
|
||||||
|
|
||||||
|
screen->enterVT = scrn->EnterVT;
|
||||||
|
scrn->EnterVT = glxDRIEnterVT;
|
||||||
|
|
||||||
|
if (!ret)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
glxResumeClients();
|
glxResumeClients();
|
||||||
|
@ -621,6 +630,7 @@ glxDRIEnterVT (int index, int flags)
|
||||||
static void
|
static void
|
||||||
glxDRILeaveVT (int index, int flags)
|
glxDRILeaveVT (int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr scrn = xf86Screens[index];
|
||||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||||
glxGetScreen(screenInfo.screens[index]);
|
glxGetScreen(screenInfo.screens[index]);
|
||||||
|
|
||||||
|
@ -628,7 +638,10 @@ glxDRILeaveVT (int index, int flags)
|
||||||
|
|
||||||
glxSuspendClients();
|
glxSuspendClients();
|
||||||
|
|
||||||
return (*screen->leaveVT) (index, flags);
|
scrn->LeaveVT = screen->leaveVT;
|
||||||
|
(*screen->leaveVT) (index, flags);
|
||||||
|
screen->leaveVT = scrn->LeaveVT;
|
||||||
|
scrn->LeaveVT = glxDRILeaveVT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -523,12 +523,16 @@ static Bool
|
||||||
VGAarbiterEnterVT(int index, int flags)
|
VGAarbiterEnterVT(int index, int flags)
|
||||||
{
|
{
|
||||||
Bool val;
|
Bool val;
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
||||||
&pScreen->devPrivates, VGAarbiterScreenKey);
|
&pScreen->devPrivates, VGAarbiterScreenKey);
|
||||||
|
|
||||||
VGAGet();
|
VGAGet();
|
||||||
val = (*pScreenPriv->EnterVT)(index, flags);
|
pScrn->EnterVT = pScreenPriv->EnterVT;
|
||||||
|
val = (*pScrn->EnterVT)(index, flags);
|
||||||
|
pScreenPriv->EnterVT = pScrn->EnterVT;
|
||||||
|
pScrn->EnterVT = VGAarbiterEnterVT;
|
||||||
VGAPut();
|
VGAPut();
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
@ -536,12 +540,16 @@ VGAarbiterEnterVT(int index, int flags)
|
||||||
static void
|
static void
|
||||||
VGAarbiterLeaveVT(int index, int flags)
|
VGAarbiterLeaveVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
||||||
&pScreen->devPrivates, VGAarbiterScreenKey);
|
&pScreen->devPrivates, VGAarbiterScreenKey);
|
||||||
|
|
||||||
VGAGet();
|
VGAGet();
|
||||||
|
pScrn->LeaveVT = pScreenPriv->LeaveVT;
|
||||||
(*pScreenPriv->LeaveVT)(index, flags);
|
(*pScreenPriv->LeaveVT)(index, flags);
|
||||||
|
pScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||||
|
pScrn->LeaveVT = VGAarbiterLeaveVT;
|
||||||
VGAPut();
|
VGAPut();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -466,11 +466,17 @@ CMapInstallColormap(ColormapPtr pmap)
|
||||||
static Bool
|
static Bool
|
||||||
CMapEnterVT(int index, int flags)
|
CMapEnterVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
|
Bool ret;
|
||||||
CMapScreenPtr pScreenPriv = (CMapScreenPtr)dixLookupPrivate(
|
CMapScreenPtr pScreenPriv = (CMapScreenPtr)dixLookupPrivate(
|
||||||
&pScreen->devPrivates, CMapScreenKey);
|
&pScreen->devPrivates, CMapScreenKey);
|
||||||
|
|
||||||
if((*pScreenPriv->EnterVT)(index, flags)) {
|
pScrn->EnterVT = pScreenPriv->EnterVT;
|
||||||
|
ret = (*pScreenPriv->EnterVT)(index, flags);
|
||||||
|
pScreenPriv->EnterVT = pScrn->EnterVT;
|
||||||
|
pScrn->EnterVT = CMapEnterVT;
|
||||||
|
if(ret) {
|
||||||
if(GetInstalledmiColormap(pScreen))
|
if(GetInstalledmiColormap(pScreen))
|
||||||
CMapReinstallMap(GetInstalledmiColormap(pScreen));
|
CMapReinstallMap(GetInstalledmiColormap(pScreen));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
|
@ -1229,11 +1229,15 @@ xf86XVQueryAdaptors(
|
||||||
static Bool
|
static Bool
|
||||||
xf86XVEnterVT(int index, int flags)
|
xf86XVEnterVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
||||||
Bool ret;
|
Bool ret;
|
||||||
|
|
||||||
|
pScrn->EnterVT = ScreenPriv->EnterVT;
|
||||||
ret = (*ScreenPriv->EnterVT)(index, flags);
|
ret = (*ScreenPriv->EnterVT)(index, flags);
|
||||||
|
ScreenPriv->EnterVT = pScrn->EnterVT;
|
||||||
|
pScrn->EnterVT = xf86XVEnterVT;
|
||||||
|
|
||||||
if(ret) WalkTree(pScreen, xf86XVReputAllVideo, 0);
|
if(ret) WalkTree(pScreen, xf86XVReputAllVideo, 0);
|
||||||
|
|
||||||
|
@ -1243,6 +1247,7 @@ xf86XVEnterVT(int index, int flags)
|
||||||
static void
|
static void
|
||||||
xf86XVLeaveVT(int index, int flags)
|
xf86XVLeaveVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
|
XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
|
||||||
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
||||||
|
@ -1274,7 +1279,10 @@ xf86XVLeaveVT(int index, int flags)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pScrn->LeaveVT = ScreenPriv->LeaveVT;
|
||||||
(*ScreenPriv->LeaveVT)(index, flags);
|
(*ScreenPriv->LeaveVT)(index, flags);
|
||||||
|
ScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||||
|
pScrn->LeaveVT = xf86XVLeaveVT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -216,9 +216,14 @@ static Bool
|
||||||
ShadowEnterVT(int index, int flags)
|
ShadowEnterVT(int index, int flags)
|
||||||
{
|
{
|
||||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
|
Bool ret;
|
||||||
ShadowScreenPtr pPriv = GET_SCREEN_PRIVATE(pScrn->pScreen);
|
ShadowScreenPtr pPriv = GET_SCREEN_PRIVATE(pScrn->pScreen);
|
||||||
|
|
||||||
if((*pPriv->EnterVT)(index, flags)) {
|
pScrn->EnterVT = pPriv->EnterVT;
|
||||||
|
ret = (*pPriv->EnterVT)(index, flags);
|
||||||
|
pPriv->EnterVT = pScrn->EnterVT;
|
||||||
|
pScrn->EnterVT = ShadowEnterVT;
|
||||||
|
if(ret) {
|
||||||
pPriv->vtSema = TRUE;
|
pPriv->vtSema = TRUE;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -229,11 +234,15 @@ ShadowEnterVT(int index, int flags)
|
||||||
static void
|
static void
|
||||||
ShadowLeaveVT(int index, int flags)
|
ShadowLeaveVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ShadowScreenPtr pPriv = GET_SCREEN_PRIVATE(xf86Screens[index]->pScreen);
|
ShadowScreenPtr pPriv = GET_SCREEN_PRIVATE(xf86Screens[index]->pScreen);
|
||||||
|
|
||||||
pPriv->vtSema = FALSE;
|
pPriv->vtSema = FALSE;
|
||||||
|
|
||||||
|
pScrn->LeaveVT = pPriv->LeaveVT;
|
||||||
(*pPriv->LeaveVT)(index, flags);
|
(*pPriv->LeaveVT)(index, flags);
|
||||||
|
pPriv->LeaveVT = pScrn->LeaveVT;
|
||||||
|
pScrn->LeaveVT = ShadowLeaveVT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**********************************************************/
|
/**********************************************************/
|
||||||
|
|
|
@ -508,16 +508,23 @@ XAAChangeWindowAttributes (WindowPtr pWin, unsigned long mask)
|
||||||
static Bool
|
static Bool
|
||||||
XAAEnterVT(int index, int flags)
|
XAAEnterVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
|
Bool ret;
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
XAAScreenPtr pScreenPriv =
|
XAAScreenPtr pScreenPriv =
|
||||||
(XAAScreenPtr)dixLookupPrivate(&pScreen->devPrivates, XAAScreenKey);
|
(XAAScreenPtr)dixLookupPrivate(&pScreen->devPrivates, XAAScreenKey);
|
||||||
|
|
||||||
return((*pScreenPriv->EnterVT)(index, flags));
|
pScrn->EnterVT = pScreenPriv->EnterVT;
|
||||||
|
ret = ((*pScreenPriv->EnterVT)(index, flags));
|
||||||
|
pScreenPriv->EnterVT = pScrn->EnterVT;
|
||||||
|
pScrn->EnterVT = XAAEnterVT;
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
XAALeaveVT(int index, int flags)
|
XAALeaveVT(int index, int flags)
|
||||||
{
|
{
|
||||||
|
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||||
ScreenPtr pScreen = screenInfo.screens[index];
|
ScreenPtr pScreen = screenInfo.screens[index];
|
||||||
XAAScreenPtr pScreenPriv =
|
XAAScreenPtr pScreenPriv =
|
||||||
(XAAScreenPtr)dixLookupPrivate(&pScreen->devPrivates, XAAScreenKey);
|
(XAAScreenPtr)dixLookupPrivate(&pScreen->devPrivates, XAAScreenKey);
|
||||||
|
@ -528,7 +535,10 @@ XAALeaveVT(int index, int flags)
|
||||||
infoRec->NeedToSync = FALSE;
|
infoRec->NeedToSync = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pScrn->LeaveVT = pScreenPriv->LeaveVT;
|
||||||
(*pScreenPriv->LeaveVT)(index, flags);
|
(*pScreenPriv->LeaveVT)(index, flags);
|
||||||
|
pScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||||
|
pScrn->LeaveVT = XAALeaveVT;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
|
Loading…
Reference in New Issue