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 commit68a9ee8370
. 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> (cherry picked from commitd75e8146c4
, and conflict fromb618705
fixed up) Signed-off-by: Julien Cristau <jcristau@debian.org>
This commit is contained in:
parent
3fabfc198b
commit
3336e1f7f3
17
glx/glxdri.c
17
glx/glxdri.c
|
@ -863,12 +863,21 @@ static const char dri_driver_path[] = DRI_DRIVER_PATH;
|
|||
static Bool
|
||||
glxDRIEnterVT (int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr scrn = xf86Screens[index];
|
||||
Bool ret;
|
||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||
glxGetScreen(screenInfo.screens[index]);
|
||||
|
||||
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;
|
||||
|
||||
glxResumeClients();
|
||||
|
@ -879,6 +888,7 @@ glxDRIEnterVT (int index, int flags)
|
|||
static void
|
||||
glxDRILeaveVT (int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr scrn = xf86Screens[index];
|
||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||
glxGetScreen(screenInfo.screens[index]);
|
||||
|
||||
|
@ -886,7 +896,10 @@ glxDRILeaveVT (int index, int flags)
|
|||
|
||||
glxSuspendClients();
|
||||
|
||||
return (*screen->leaveVT) (index, flags);
|
||||
scrn->LeaveVT = screen->leaveVT;
|
||||
(*screen->leaveVT) (index, flags);
|
||||
screen->leaveVT = scrn->LeaveVT;
|
||||
scrn->LeaveVT = glxDRILeaveVT;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
|
@ -512,12 +512,21 @@ static const char dri_driver_path[] = DRI_DRIVER_PATH;
|
|||
static Bool
|
||||
glxDRIEnterVT (int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr scrn = xf86Screens[index];
|
||||
Bool ret;
|
||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||
glxGetScreen(screenInfo.screens[index]);
|
||||
|
||||
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;
|
||||
|
||||
glxResumeClients();
|
||||
|
@ -528,6 +537,7 @@ glxDRIEnterVT (int index, int flags)
|
|||
static void
|
||||
glxDRILeaveVT (int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr scrn = xf86Screens[index];
|
||||
__GLXDRIscreen *screen = (__GLXDRIscreen *)
|
||||
glxGetScreen(screenInfo.screens[index]);
|
||||
|
||||
|
@ -535,7 +545,10 @@ glxDRILeaveVT (int index, int flags)
|
|||
|
||||
glxSuspendClients();
|
||||
|
||||
return (*screen->leaveVT) (index, flags);
|
||||
scrn->LeaveVT = screen->leaveVT;
|
||||
(*screen->leaveVT) (index, flags);
|
||||
screen->leaveVT = scrn->LeaveVT;
|
||||
scrn->LeaveVT = glxDRILeaveVT;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
|
@ -530,12 +530,16 @@ static Bool
|
|||
VGAarbiterEnterVT(int index, int flags)
|
||||
{
|
||||
Bool val;
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
||||
&pScreen->devPrivates, VGAarbiterScreenKey);
|
||||
|
||||
VGAGet();
|
||||
val = (*pScreenPriv->EnterVT)(index, flags);
|
||||
pScrn->EnterVT = pScreenPriv->EnterVT;
|
||||
val = (*pScrn->EnterVT)(index, flags);
|
||||
pScreenPriv->EnterVT = pScrn->EnterVT;
|
||||
pScrn->EnterVT = VGAarbiterEnterVT;
|
||||
VGAPut();
|
||||
return val;
|
||||
}
|
||||
|
@ -543,12 +547,16 @@ VGAarbiterEnterVT(int index, int flags)
|
|||
static void
|
||||
VGAarbiterLeaveVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
VGAarbiterScreenPtr pScreenPriv = (VGAarbiterScreenPtr)dixLookupPrivate(
|
||||
&pScreen->devPrivates, VGAarbiterScreenKey);
|
||||
|
||||
VGAGet();
|
||||
pScrn->LeaveVT = pScreenPriv->LeaveVT;
|
||||
(*pScreenPriv->LeaveVT)(index, flags);
|
||||
pScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||
pScrn->LeaveVT = VGAarbiterLeaveVT;
|
||||
VGAPut();
|
||||
}
|
||||
|
||||
|
|
|
@ -456,11 +456,17 @@ CMapInstallColormap(ColormapPtr pmap)
|
|||
static Bool
|
||||
CMapEnterVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
Bool ret;
|
||||
CMapScreenPtr pScreenPriv = (CMapScreenPtr)dixLookupPrivate(
|
||||
&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(miInstalledMaps[index])
|
||||
CMapReinstallMap(miInstalledMaps[index]);
|
||||
return TRUE;
|
||||
|
|
|
@ -1225,11 +1225,15 @@ xf86XVQueryAdaptors(
|
|||
static Bool
|
||||
xf86XVEnterVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
||||
Bool ret;
|
||||
|
||||
pScrn->EnterVT = ScreenPriv->EnterVT;
|
||||
ret = (*ScreenPriv->EnterVT)(index, flags);
|
||||
ScreenPriv->EnterVT = pScrn->EnterVT;
|
||||
pScrn->EnterVT = xf86XVEnterVT;
|
||||
|
||||
if(ret) WalkTree(pScreen, xf86XVReputAllVideo, 0);
|
||||
|
||||
|
@ -1239,6 +1243,7 @@ xf86XVEnterVT(int index, int flags)
|
|||
static void
|
||||
xf86XVLeaveVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
XvScreenPtr pxvs = GET_XV_SCREEN(pScreen);
|
||||
XF86XVScreenPtr ScreenPriv = GET_XF86XV_SCREEN(pScreen);
|
||||
|
@ -1270,7 +1275,10 @@ xf86XVLeaveVT(int index, int flags)
|
|||
}
|
||||
}
|
||||
|
||||
pScrn->LeaveVT = ScreenPriv->LeaveVT;
|
||||
(*ScreenPriv->LeaveVT)(index, flags);
|
||||
ScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||
pScrn->LeaveVT = xf86XVLeaveVT;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
|
@ -223,9 +223,14 @@ static Bool
|
|||
ShadowEnterVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
Bool ret;
|
||||
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;
|
||||
return TRUE;
|
||||
}
|
||||
|
@ -236,11 +241,15 @@ ShadowEnterVT(int index, int flags)
|
|||
static void
|
||||
ShadowLeaveVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ShadowScreenPtr pPriv = GET_SCREEN_PRIVATE(xf86Screens[index]->pScreen);
|
||||
|
||||
pPriv->vtSema = FALSE;
|
||||
|
||||
pScrn->LeaveVT = pPriv->LeaveVT;
|
||||
(*pPriv->LeaveVT)(index, flags);
|
||||
pPriv->LeaveVT = pScrn->LeaveVT;
|
||||
pScrn->LeaveVT = ShadowLeaveVT;
|
||||
}
|
||||
|
||||
/**********************************************************/
|
||||
|
|
|
@ -511,16 +511,23 @@ XAAChangeWindowAttributes (WindowPtr pWin, unsigned long mask)
|
|||
static Bool
|
||||
XAAEnterVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
Bool ret;
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
XAAScreenPtr pScreenPriv =
|
||||
(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
|
||||
XAALeaveVT(int index, int flags)
|
||||
{
|
||||
ScrnInfoPtr pScrn = xf86Screens[index];
|
||||
ScreenPtr pScreen = screenInfo.screens[index];
|
||||
XAAScreenPtr pScreenPriv =
|
||||
(XAAScreenPtr)dixLookupPrivate(&pScreen->devPrivates, XAAScreenKey);
|
||||
|
@ -531,7 +538,10 @@ XAALeaveVT(int index, int flags)
|
|||
infoRec->NeedToSync = FALSE;
|
||||
}
|
||||
|
||||
pScrn->LeaveVT = pScreenPriv->LeaveVT;
|
||||
(*pScreenPriv->LeaveVT)(index, flags);
|
||||
pScreenPriv->LeaveVT = pScrn->LeaveVT;
|
||||
pScrn->LeaveVT = XAALeaveVT;
|
||||
}
|
||||
|
||||
typedef struct {
|
||||
|
|
Loading…
Reference in New Issue