2006-11-26 11:13:41 -07:00
|
|
|
/*
|
|
|
|
*Copyright (C) 1994-2000 The XFree86 Project, Inc. All Rights Reserved.
|
|
|
|
*
|
|
|
|
*Permission is hereby granted, free of charge, to any person obtaining
|
|
|
|
* a copy of this software and associated documentation files (the
|
|
|
|
*"Software"), to deal in the Software without restriction, including
|
|
|
|
*without limitation the rights to use, copy, modify, merge, publish,
|
|
|
|
*distribute, sublicense, and/or sell copies of the Software, and to
|
|
|
|
*permit persons to whom the Software is furnished to do so, subject to
|
|
|
|
*the following conditions:
|
|
|
|
*
|
|
|
|
*The above copyright notice and this permission notice shall be
|
|
|
|
*included in all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
*THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
|
|
*EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
|
|
*MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
|
|
*NONINFRINGEMENT. IN NO EVENT SHALL THE XFREE86 PROJECT BE LIABLE FOR
|
|
|
|
*ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
|
|
|
|
*CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
|
|
*WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*
|
|
|
|
*Except as contained in this notice, the name of the XFree86 Project
|
|
|
|
*shall not be used in advertising or otherwise to promote the sale, use
|
|
|
|
*or other dealings in this Software without prior written authorization
|
|
|
|
*from the XFree86 Project.
|
|
|
|
*
|
|
|
|
* Authors: Dakshinamurthy Karra
|
|
|
|
* Suhaib M Siddiqi
|
|
|
|
* Peter Busch
|
|
|
|
* Harold L Hunt II
|
|
|
|
* Kensuke Matsuzaki
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_XWIN_CONFIG_H
|
|
|
|
#include <xwin-config.h>
|
|
|
|
#endif
|
|
|
|
#include "win.h"
|
|
|
|
#include "winmsg.h"
|
|
|
|
|
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
static RootlessFrameProcsRec winMWExtWMProcs = {
|
|
|
|
winMWExtWMCreateFrame,
|
|
|
|
winMWExtWMDestroyFrame,
|
|
|
|
|
|
|
|
winMWExtWMMoveFrame,
|
|
|
|
winMWExtWMResizeFrame,
|
|
|
|
winMWExtWMRestackFrame,
|
|
|
|
winMWExtWMReshapeFrame,
|
|
|
|
winMWExtWMUnmapFrame,
|
|
|
|
|
|
|
|
winMWExtWMStartDrawing,
|
|
|
|
winMWExtWMStopDrawing,
|
|
|
|
winMWExtWMUpdateRegion,
|
|
|
|
winMWExtWMDamageRects,
|
|
|
|
winMWExtWMRootlessSwitchWindow,
|
|
|
|
NULL, //winMWExtWMDoReorderWindow,
|
|
|
|
NULL, //winMWExtWMHideWindow,
|
|
|
|
NULL, //winMWExtWMUpdateColorMap,
|
|
|
|
|
|
|
|
NULL, //winMWExtWMCopyBytes,
|
|
|
|
winMWExtWMCopyWindow
|
2006-11-26 11:13:41 -07:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Prototypes
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local functions
|
|
|
|
*/
|
|
|
|
|
|
|
|
static Bool
|
2012-06-10 07:21:05 -06:00
|
|
|
winSaveScreen(ScreenPtr pScreen, int on);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Determine what type of screen we are initializing
|
|
|
|
* and call the appropriate procedure to intiailize
|
|
|
|
* that type of screen.
|
|
|
|
*/
|
|
|
|
|
|
|
|
Bool
|
2012-06-10 07:21:05 -06:00
|
|
|
winScreenInit(int index, ScreenPtr pScreen, int argc, char **argv)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
winScreenInfoPtr pScreenInfo = &g_ScreenInfo[index];
|
|
|
|
winPrivScreenPtr pScreenPriv;
|
|
|
|
HDC hdc;
|
|
|
|
DWORD dwInitialBPP;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
#if CYGDEBUG || YES
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winScreenInit - dwWidth: %ld dwHeight: %ld\n",
|
|
|
|
pScreenInfo->dwWidth, pScreenInfo->dwHeight);
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Allocate privates for this screen */
|
|
|
|
if (!winAllocatePrivates(pScreen)) {
|
|
|
|
ErrorF("winScreenInit - Couldn't allocate screen privates\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Get a pointer to the privates structure that was allocated */
|
|
|
|
pScreenPriv = winGetScreenPriv(pScreen);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Save a pointer to this screen in the screen info structure */
|
|
|
|
pScreenInfo->pScreen = pScreen;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Save a pointer to the screen info in the screen privates structure */
|
|
|
|
/* This allows us to get back to the screen info from a screen pointer */
|
|
|
|
pScreenPriv->pScreenInfo = pScreenInfo;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/*
|
|
|
|
* Determine which engine to use.
|
|
|
|
*
|
|
|
|
* NOTE: This is done once per screen because each screen possibly has
|
|
|
|
* a preferred engine specified on the command line.
|
|
|
|
*/
|
|
|
|
if (!winSetEngine(pScreen)) {
|
|
|
|
ErrorF("winScreenInit - winSetEngine () failed\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Horribly misnamed function: Allow engine to adjust BPP for screen */
|
|
|
|
dwInitialBPP = pScreenInfo->dwBPP;
|
2011-11-05 07:32:40 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
if (!(*pScreenPriv->pwinAdjustVideoMode) (pScreen)) {
|
|
|
|
ErrorF("winScreenInit - winAdjustVideoMode () failed\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
if (dwInitialBPP == WIN_DEFAULT_BPP) {
|
|
|
|
/* No -depth parameter was passed, let the user know the depth being used */
|
|
|
|
ErrorF
|
|
|
|
("winScreenInit - Using Windows display depth of %d bits per pixel\n",
|
|
|
|
(int) pScreenInfo->dwBPP);
|
2011-11-05 07:32:40 -06:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
else if (dwInitialBPP != pScreenInfo->dwBPP) {
|
|
|
|
/* Warn user if engine forced a depth different to -depth parameter */
|
|
|
|
ErrorF
|
|
|
|
("winScreenInit - Command line depth of %d bpp overidden by engine, using %d bpp\n",
|
|
|
|
(int) dwInitialBPP, (int) pScreenInfo->dwBPP);
|
2011-11-05 07:32:40 -06:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
else {
|
|
|
|
ErrorF("winScreenInit - Using command line depth of %d bpp\n",
|
|
|
|
(int) pScreenInfo->dwBPP);
|
2011-11-05 07:32:40 -06:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Check for supported display depth */
|
|
|
|
if (!(WIN_SUPPORTED_BPPS & (1 << (pScreenInfo->dwBPP - 1)))) {
|
|
|
|
ErrorF("winScreenInit - Unsupported display depth: %d\n"
|
|
|
|
"Change your Windows display depth to 15, 16, 24, or 32 bits "
|
|
|
|
"per pixel.\n", (int) pScreenInfo->dwBPP);
|
|
|
|
ErrorF("winScreenInit - Supported depths: %08x\n", WIN_SUPPORTED_BPPS);
|
2006-11-26 11:13:41 -07:00
|
|
|
#if WIN_CHECK_DEPTH
|
2012-06-10 07:21:05 -06:00
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/*
|
|
|
|
* Check that all monitors have the same display depth if we are using
|
|
|
|
* multiple monitors
|
|
|
|
*/
|
|
|
|
if (pScreenInfo->fMultipleMonitors
|
|
|
|
&& !GetSystemMetrics(SM_SAMEDISPLAYFORMAT)) {
|
|
|
|
ErrorF("winScreenInit - Monitors do not all have same pixel format / "
|
|
|
|
"display depth.\n");
|
|
|
|
if (pScreenInfo->dwEngine == WIN_SERVER_SHADOW_GDI) {
|
|
|
|
ErrorF
|
|
|
|
("winScreenInit - Performance may suffer off primary display.\n");
|
2011-11-05 07:32:40 -06:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
else {
|
|
|
|
ErrorF("winScreenInit - Using primary display only.\n");
|
|
|
|
pScreenInfo->fMultipleMonitors = FALSE;
|
2011-11-05 07:32:40 -06:00
|
|
|
}
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Create display window */
|
|
|
|
if (!(*pScreenPriv->pwinCreateBoundingWindow) (pScreen)) {
|
|
|
|
ErrorF("winScreenInit - pwinCreateBoundingWindow () " "failed\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Get a device context */
|
|
|
|
hdc = GetDC(pScreenPriv->hwndScreen);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Are we using multiple monitors? */
|
|
|
|
if (pScreenInfo->fMultipleMonitors) {
|
|
|
|
/*
|
|
|
|
* In this case, some of the defaults set in
|
|
|
|
* winInitializeScreenDefaults() are not correct ...
|
|
|
|
*/
|
|
|
|
if (!pScreenInfo->fUserGaveHeightAndWidth) {
|
|
|
|
pScreenInfo->dwWidth = GetSystemMetrics(SM_CXVIRTUALSCREEN);
|
|
|
|
pScreenInfo->dwHeight = GetSystemMetrics(SM_CYVIRTUALSCREEN);
|
|
|
|
}
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Release the device context */
|
|
|
|
ReleaseDC(pScreenPriv->hwndScreen, hdc);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Clear the visuals list */
|
|
|
|
miClearVisualTypes();
|
2011-11-05 07:32:40 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Call the engine dependent screen initialization procedure */
|
|
|
|
if (!((*pScreenPriv->pwinFinishScreenInit) (index, pScreen, argc, argv))) {
|
|
|
|
ErrorF("winScreenInit - winFinishScreenInit () failed\n");
|
2011-11-05 07:32:40 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* call the engine dependent screen close procedure to clean up from a failure */
|
|
|
|
pScreenPriv->pwinCloseScreen(index, pScreen);
|
|
|
|
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
if (!g_fSoftwareCursor)
|
|
|
|
winInitCursor(pScreen);
|
|
|
|
else
|
|
|
|
winErrorFVerb(2, "winScreenInit - Using software cursor\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/*
|
|
|
|
Note the screen origin in a normalized coordinate space where (0,0) is at the top left
|
|
|
|
of the native virtual desktop area
|
|
|
|
*/
|
|
|
|
pScreen->x = pScreenInfo->dwInitialX - GetSystemMetrics(SM_XVIRTUALSCREEN);
|
|
|
|
pScreen->y = pScreenInfo->dwInitialY - GetSystemMetrics(SM_YVIRTUALSCREEN);
|
2010-07-27 13:02:24 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
ErrorF("Screen %d added at virtual desktop coordinate (%d,%d).\n",
|
|
|
|
index, pScreen->x, pScreen->y);
|
2010-07-27 13:02:24 -06:00
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
#if CYGDEBUG || YES
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winScreenInit - returning\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2010-07-27 13:02:24 -06:00
|
|
|
static Bool
|
|
|
|
winCreateScreenResources(ScreenPtr pScreen)
|
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
winScreenPriv(pScreen);
|
|
|
|
Bool result;
|
2010-07-27 13:02:24 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
result = pScreenPriv->pwinCreateScreenResources(pScreen);
|
2010-07-27 13:02:24 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Now the screen bitmap has been wrapped in a pixmap,
|
|
|
|
add that to the Shadow framebuffer */
|
|
|
|
if (!shadowAdd(pScreen, pScreen->devPrivate,
|
|
|
|
pScreenPriv->pwinShadowUpdate, NULL, 0, 0)) {
|
|
|
|
ErrorF("winCreateScreenResources - shadowAdd () failed\n");
|
|
|
|
return FALSE;
|
2010-07-27 13:02:24 -06:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return result;
|
2010-07-27 13:02:24 -06:00
|
|
|
}
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
/* See Porting Layer Definition - p. 20 */
|
|
|
|
Bool
|
2012-06-10 07:21:05 -06:00
|
|
|
winFinishScreenInitFB(int index, ScreenPtr pScreen, int argc, char **argv)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
winScreenPriv(pScreen);
|
|
|
|
winScreenInfo *pScreenInfo = pScreenPriv->pScreenInfo;
|
|
|
|
VisualPtr pVisual = NULL;
|
|
|
|
char *pbits = NULL;
|
|
|
|
|
2006-11-26 11:13:41 -07:00
|
|
|
#if defined(XWIN_CLIPBOARD) || defined(XWIN_MULTIWINDOW)
|
2012-06-10 07:21:05 -06:00
|
|
|
int iReturn;
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Create framebuffer */
|
|
|
|
if (!(*pScreenPriv->pwinInitScreen) (pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - Could not allocate framebuffer\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Calculate the number of bits that are used to represent color in each pixel,
|
|
|
|
* the color depth for the screen
|
|
|
|
*/
|
|
|
|
if (pScreenInfo->dwBPP == 8)
|
|
|
|
pScreenInfo->dwDepth = 8;
|
|
|
|
else
|
|
|
|
pScreenInfo->dwDepth = winCountBits(pScreenPriv->dwRedMask)
|
|
|
|
+ winCountBits(pScreenPriv->dwGreenMask)
|
|
|
|
+ winCountBits(pScreenPriv->dwBlueMask);
|
|
|
|
|
|
|
|
winErrorFVerb(2, "winFinishScreenInitFB - Masks: %08x %08x %08x\n",
|
|
|
|
(unsigned int) pScreenPriv->dwRedMask,
|
|
|
|
(unsigned int) pScreenPriv->dwGreenMask,
|
|
|
|
(unsigned int) pScreenPriv->dwBlueMask);
|
|
|
|
|
|
|
|
/* Init visuals */
|
|
|
|
if (!(*pScreenPriv->pwinInitVisuals) (pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - winInitVisuals failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Setup a local variable to point to the framebuffer */
|
|
|
|
pbits = pScreenInfo->pfb;
|
|
|
|
|
|
|
|
/* Apparently we need this for the render extension */
|
|
|
|
miSetPixmapDepths();
|
|
|
|
|
|
|
|
/* Start fb initialization */
|
|
|
|
if (!fbSetupScreen(pScreen,
|
|
|
|
pScreenInfo->pfb,
|
|
|
|
pScreenInfo->dwWidth, pScreenInfo->dwHeight,
|
|
|
|
monitorResolution, monitorResolution,
|
|
|
|
pScreenInfo->dwStride, pScreenInfo->dwBPP)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - fbSetupScreen failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Override default colormap routines if visual class is dynamic */
|
|
|
|
if (pScreenInfo->dwDepth == 8
|
|
|
|
&& (pScreenInfo->dwEngine == WIN_SERVER_SHADOW_GDI
|
|
|
|
|| (pScreenInfo->dwEngine == WIN_SERVER_SHADOW_DDNL
|
|
|
|
&& pScreenInfo->fFullScreen)
|
|
|
|
|| (pScreenInfo->dwEngine == WIN_SERVER_SHADOW_DD
|
|
|
|
&& pScreenInfo->fFullScreen))) {
|
|
|
|
winSetColormapFunctions(pScreen);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* NOTE: Setting whitePixel to 255 causes Magic 7.1 to allocate its
|
|
|
|
* own colormap, as it cannot allocate 7 planes in the default
|
|
|
|
* colormap. Setting whitePixel to 1 allows Magic to get 7
|
|
|
|
* planes in the default colormap, so it doesn't create its
|
|
|
|
* own colormap. This latter situation is highly desireable,
|
|
|
|
* as it keeps the Magic window viewable when switching to
|
|
|
|
* other X clients that use the default colormap.
|
|
|
|
*/
|
|
|
|
pScreen->blackPixel = 0;
|
|
|
|
pScreen->whitePixel = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Place our save screen function */
|
|
|
|
pScreen->SaveScreen = winSaveScreen;
|
|
|
|
|
|
|
|
/* Finish fb initialization */
|
|
|
|
if (!fbFinishScreenInit(pScreen,
|
|
|
|
pScreenInfo->pfb,
|
|
|
|
pScreenInfo->dwWidth, pScreenInfo->dwHeight,
|
|
|
|
monitorResolution, monitorResolution,
|
|
|
|
pScreenInfo->dwStride, pScreenInfo->dwBPP)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - fbFinishScreenInit failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Save a pointer to the root visual */
|
|
|
|
for (pVisual = pScreen->visuals;
|
|
|
|
pVisual->vid != pScreen->rootVisual; pVisual++);
|
|
|
|
pScreenPriv->pRootVisual = pVisual;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Setup points to the block and wakeup handlers. Pass a pointer
|
|
|
|
* to the current screen as pWakeupdata.
|
|
|
|
*/
|
|
|
|
pScreen->BlockHandler = winBlockHandler;
|
|
|
|
pScreen->WakeupHandler = winWakeupHandler;
|
|
|
|
pScreen->blockData = pScreen;
|
|
|
|
pScreen->wakeupData = pScreen;
|
|
|
|
|
|
|
|
/* Render extension initialization, calls miPictureInit */
|
|
|
|
if (!fbPictureInit(pScreen, NULL, 0)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - fbPictureInit () failed\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef RANDR
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Initialize resize and rotate support */
|
|
|
|
if (!winRandRInit(pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - winRandRInit () failed\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Setup the cursor routines */
|
2006-11-26 11:13:41 -07:00
|
|
|
#if CYGDEBUG
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winFinishScreenInitFB - Calling miDCInitialize ()\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
miDCInitialize(pScreen, &g_winPointerCursorFuncs);
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* KDrive does winCreateDefColormap right after miDCInitialize */
|
|
|
|
/* Create a default colormap */
|
2006-11-26 11:13:41 -07:00
|
|
|
#if CYGDEBUG
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winFinishScreenInitFB - Calling winCreateDefColormap ()\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
if (!winCreateDefColormap(pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - Could not create colormap\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Initialize the shadow framebuffer layer */
|
|
|
|
if ((pScreenInfo->dwEngine == WIN_SERVER_SHADOW_GDI
|
|
|
|
|| pScreenInfo->dwEngine == WIN_SERVER_SHADOW_DD
|
|
|
|
|| pScreenInfo->dwEngine == WIN_SERVER_SHADOW_DDNL)
|
2006-11-26 11:13:41 -07:00
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
&& !pScreenInfo->fMWExtWM
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
) {
|
2006-11-26 11:13:41 -07:00
|
|
|
#if CYGDEBUG
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winFinishScreenInitFB - Calling shadowSetup ()\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
if (!shadowSetup(pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - shadowSetup () failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
2010-07-27 13:02:24 -06:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Wrap CreateScreenResources so we can add the screen pixmap
|
|
|
|
to the Shadow framebuffer after it's been created */
|
|
|
|
pScreenPriv->pwinCreateScreenResources = pScreen->CreateScreenResources;
|
|
|
|
pScreen->CreateScreenResources = winCreateScreenResources;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Handle multi-window external window manager mode */
|
|
|
|
if (pScreenInfo->fMWExtWM) {
|
|
|
|
winDebug("winScreenInit - MultiWindowExtWM - Calling RootlessInit\n");
|
|
|
|
|
|
|
|
RootlessInit(pScreen, &winMWExtWMProcs);
|
|
|
|
|
|
|
|
winDebug("winScreenInit - MultiWindowExtWM - RootlessInit returned\n");
|
|
|
|
|
|
|
|
rootless_CopyBytes_threshold = 0;
|
|
|
|
/* FIXME: How many? Profiling needed? */
|
|
|
|
rootless_CopyWindow_threshold = 1;
|
|
|
|
|
|
|
|
winWindowsWMExtensionInit();
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Handle rootless mode */
|
|
|
|
if (pScreenInfo->fRootless) {
|
|
|
|
/* Define the WRAP macro temporarily for local use */
|
2006-11-26 11:13:41 -07:00
|
|
|
#define WRAP(a) \
|
|
|
|
if (pScreen->a) { \
|
|
|
|
pScreenPriv->a = pScreen->a; \
|
|
|
|
} else { \
|
|
|
|
ErrorF("null screen fn " #a "\n"); \
|
|
|
|
pScreenPriv->a = NULL; \
|
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Save a pointer to each lower-level window procedure */
|
|
|
|
WRAP(CreateWindow);
|
|
|
|
WRAP(DestroyWindow);
|
|
|
|
WRAP(RealizeWindow);
|
|
|
|
WRAP(UnrealizeWindow);
|
|
|
|
WRAP(PositionWindow);
|
|
|
|
WRAP(ChangeWindowAttributes);
|
|
|
|
WRAP(SetShape);
|
|
|
|
|
|
|
|
/* Assign rootless window procedures to be top level procedures */
|
|
|
|
pScreen->CreateWindow = winCreateWindowRootless;
|
|
|
|
pScreen->DestroyWindow = winDestroyWindowRootless;
|
|
|
|
pScreen->PositionWindow = winPositionWindowRootless;
|
|
|
|
/*pScreen->ChangeWindowAttributes = winChangeWindowAttributesRootless; */
|
|
|
|
pScreen->RealizeWindow = winMapWindowRootless;
|
|
|
|
pScreen->UnrealizeWindow = winUnmapWindowRootless;
|
|
|
|
pScreen->SetShape = winSetShapeRootless;
|
|
|
|
|
|
|
|
/* Undefine the WRAP macro, as it is not needed elsewhere */
|
2006-11-26 11:13:41 -07:00
|
|
|
#undef WRAP
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XWIN_MULTIWINDOW
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Handle multi window mode */
|
|
|
|
else if (pScreenInfo->fMultiWindow) {
|
|
|
|
/* Define the WRAP macro temporarily for local use */
|
2006-11-26 11:13:41 -07:00
|
|
|
#define WRAP(a) \
|
|
|
|
if (pScreen->a) { \
|
|
|
|
pScreenPriv->a = pScreen->a; \
|
|
|
|
} else { \
|
|
|
|
ErrorF("null screen fn " #a "\n"); \
|
|
|
|
pScreenPriv->a = NULL; \
|
|
|
|
}
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Save a pointer to each lower-level window procedure */
|
|
|
|
WRAP(CreateWindow);
|
|
|
|
WRAP(DestroyWindow);
|
|
|
|
WRAP(RealizeWindow);
|
|
|
|
WRAP(UnrealizeWindow);
|
|
|
|
WRAP(PositionWindow);
|
|
|
|
WRAP(ChangeWindowAttributes);
|
|
|
|
WRAP(ReparentWindow);
|
|
|
|
WRAP(RestackWindow);
|
|
|
|
WRAP(ResizeWindow);
|
|
|
|
WRAP(MoveWindow);
|
|
|
|
WRAP(CopyWindow);
|
|
|
|
WRAP(SetShape);
|
|
|
|
|
|
|
|
/* Assign multi-window window procedures to be top level procedures */
|
|
|
|
pScreen->CreateWindow = winCreateWindowMultiWindow;
|
|
|
|
pScreen->DestroyWindow = winDestroyWindowMultiWindow;
|
|
|
|
pScreen->PositionWindow = winPositionWindowMultiWindow;
|
|
|
|
/*pScreen->ChangeWindowAttributes = winChangeWindowAttributesMultiWindow; */
|
|
|
|
pScreen->RealizeWindow = winMapWindowMultiWindow;
|
|
|
|
pScreen->UnrealizeWindow = winUnmapWindowMultiWindow;
|
|
|
|
pScreen->ReparentWindow = winReparentWindowMultiWindow;
|
|
|
|
pScreen->RestackWindow = winRestackWindowMultiWindow;
|
|
|
|
pScreen->ResizeWindow = winResizeWindowMultiWindow;
|
|
|
|
pScreen->MoveWindow = winMoveWindowMultiWindow;
|
|
|
|
pScreen->CopyWindow = winCopyWindowMultiWindow;
|
|
|
|
pScreen->SetShape = winSetShapeMultiWindow;
|
|
|
|
|
|
|
|
/* Undefine the WRAP macro, as it is not needed elsewhere */
|
2006-11-26 11:13:41 -07:00
|
|
|
#undef WRAP
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Wrap either fb's or shadow's CloseScreen with our CloseScreen */
|
|
|
|
pScreenPriv->CloseScreen = pScreen->CloseScreen;
|
|
|
|
pScreen->CloseScreen = pScreenPriv->pwinCloseScreen;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
#if defined(XWIN_CLIPBOARD) || defined(XWIN_MULTIWINDOW)
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Create a mutex for modules in separate threads to wait for */
|
|
|
|
iReturn = pthread_mutex_init(&pScreenPriv->pmServerStarted, NULL);
|
|
|
|
if (iReturn != 0) {
|
|
|
|
ErrorF("winFinishScreenInitFB - pthread_mutex_init () failed: %d\n",
|
|
|
|
iReturn);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Own the mutex for modules in separate threads */
|
|
|
|
iReturn = pthread_mutex_lock(&pScreenPriv->pmServerStarted);
|
|
|
|
if (iReturn != 0) {
|
|
|
|
ErrorF("winFinishScreenInitFB - pthread_mutex_lock () failed: %d\n",
|
|
|
|
iReturn);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Set the ServerStarted flag to false */
|
|
|
|
pScreenPriv->fServerStarted = FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
pScreenPriv->fRestacking = FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(XWIN_MULTIWINDOW) || defined(XWIN_MULTIWINDOWEXTWM)
|
2012-06-10 07:21:05 -06:00
|
|
|
if (FALSE
|
2006-11-26 11:13:41 -07:00
|
|
|
#ifdef XWIN_MULTIWINDOW
|
2012-06-10 07:21:05 -06:00
|
|
|
|| pScreenInfo->fMultiWindow
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
|| pScreenInfo->fInternalWM
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
) {
|
2006-11-26 11:13:41 -07:00
|
|
|
#if CYGDEBUG || YES
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winFinishScreenInitFB - Calling winInitWM.\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Initialize multi window mode */
|
|
|
|
if (!winInitWM(&pScreenPriv->pWMInfo,
|
|
|
|
&pScreenPriv->ptWMProc,
|
|
|
|
&pScreenPriv->ptXMsgProc,
|
|
|
|
&pScreenPriv->pmServerStarted,
|
|
|
|
pScreenInfo->dwScreen, (HWND) & pScreenPriv->hwndScreen,
|
2006-11-26 11:13:41 -07:00
|
|
|
#ifdef XWIN_MULTIWINDOWEXTWM
|
2012-06-10 07:21:05 -06:00
|
|
|
pScreenInfo->fInternalWM ||
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
2012-06-10 07:21:05 -06:00
|
|
|
FALSE)) {
|
|
|
|
ErrorF("winFinishScreenInitFB - winInitWM () failed.\n");
|
|
|
|
return FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
2012-06-10 07:21:05 -06:00
|
|
|
}
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Tell the server that we are enabled */
|
|
|
|
pScreenPriv->fEnabled = TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
/* Tell the server that we have a valid depth */
|
|
|
|
pScreenPriv->fBadDepth = FALSE;
|
2006-11-26 11:13:41 -07:00
|
|
|
|
|
|
|
#if CYGDEBUG || YES
|
2012-06-10 07:21:05 -06:00
|
|
|
winDebug("winFinishScreenInitFB - returning\n");
|
2006-11-26 11:13:41 -07:00
|
|
|
#endif
|
|
|
|
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef XWIN_NATIVEGDI
|
|
|
|
/* See Porting Layer Definition - p. 20 */
|
|
|
|
|
|
|
|
Bool
|
2012-06-10 07:21:05 -06:00
|
|
|
winFinishScreenInitNativeGDI(int index,
|
|
|
|
ScreenPtr pScreen, int argc, char **argv)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
winScreenPriv(pScreen);
|
|
|
|
winScreenInfoPtr pScreenInfo = &g_ScreenInfo[index];
|
|
|
|
VisualPtr pVisuals = NULL;
|
|
|
|
DepthPtr pDepths = NULL;
|
|
|
|
VisualID rootVisual = 0;
|
|
|
|
int nVisuals = 0, nDepths = 0, nRootDepth = 0;
|
|
|
|
|
|
|
|
/* Ignore user input (mouse, keyboard) */
|
|
|
|
pScreenInfo->fIgnoreInput = FALSE;
|
|
|
|
|
|
|
|
/* Get device contexts for the screen and shadow bitmap */
|
|
|
|
pScreenPriv->hdcScreen = GetDC(pScreenPriv->hwndScreen);
|
|
|
|
if (pScreenPriv->hdcScreen == NULL)
|
|
|
|
FatalError("winFinishScreenInitNativeGDI - Couldn't get a DC\n");
|
|
|
|
|
|
|
|
/* Init visuals */
|
|
|
|
if (!(*pScreenPriv->pwinInitVisuals) (pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - pwinInitVisuals failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialize the mi visuals */
|
|
|
|
if (!miInitVisuals(&pVisuals, &pDepths, &nVisuals, &nDepths, &nRootDepth,
|
|
|
|
&rootVisual,
|
|
|
|
((unsigned long) 1 << (pScreenInfo->dwDepth - 1)), 8,
|
|
|
|
TrueColor)) {
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - miInitVisuals () failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialize the CloseScreen procedure pointer */
|
|
|
|
pScreen->CloseScreen = NULL;
|
|
|
|
|
|
|
|
/* Initialize the mi code */
|
|
|
|
if (!miScreenInit(pScreen, NULL, /* No framebuffer */
|
|
|
|
pScreenInfo->dwWidth, pScreenInfo->dwHeight,
|
|
|
|
monitorResolution, monitorResolution,
|
|
|
|
pScreenInfo->dwStride,
|
|
|
|
nRootDepth, nDepths, pDepths, rootVisual,
|
|
|
|
nVisuals, pVisuals)) {
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - miScreenInit failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
pScreen->defColormap = FakeClientID(0);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Register our block and wakeup handlers; these procedures
|
|
|
|
* process messages in our Windows message queue; specifically,
|
|
|
|
* they process mouse and keyboard input.
|
|
|
|
*/
|
|
|
|
pScreen->BlockHandler = winBlockHandler;
|
|
|
|
pScreen->WakeupHandler = winWakeupHandler;
|
|
|
|
pScreen->blockData = pScreen;
|
|
|
|
pScreen->wakeupData = pScreen;
|
|
|
|
|
|
|
|
/* Place our save screen function */
|
|
|
|
pScreen->SaveScreen = winSaveScreen;
|
|
|
|
|
|
|
|
/* Pixmaps */
|
|
|
|
pScreen->CreatePixmap = winCreatePixmapNativeGDI;
|
|
|
|
pScreen->DestroyPixmap = winDestroyPixmapNativeGDI;
|
|
|
|
|
|
|
|
/* Other Screen Routines */
|
|
|
|
pScreen->QueryBestSize = winQueryBestSizeNativeGDI;
|
|
|
|
pScreen->SaveScreen = winSaveScreen;
|
|
|
|
pScreen->GetImage = miGetImage;
|
|
|
|
pScreen->GetSpans = winGetSpansNativeGDI;
|
|
|
|
|
|
|
|
/* Window Procedures */
|
|
|
|
pScreen->CreateWindow = winCreateWindowNativeGDI;
|
|
|
|
pScreen->DestroyWindow = winDestroyWindowNativeGDI;
|
|
|
|
pScreen->PositionWindow = winPositionWindowNativeGDI;
|
|
|
|
/*pScreen->ChangeWindowAttributes = winChangeWindowAttributesNativeGDI; */
|
|
|
|
pScreen->RealizeWindow = winMapWindowNativeGDI;
|
|
|
|
pScreen->UnrealizeWindow = winUnmapWindowNativeGDI;
|
|
|
|
|
|
|
|
/* Paint window */
|
|
|
|
pScreen->CopyWindow = winCopyWindowNativeGDI;
|
|
|
|
|
|
|
|
/* Fonts */
|
|
|
|
pScreen->RealizeFont = winRealizeFontNativeGDI;
|
|
|
|
pScreen->UnrealizeFont = winUnrealizeFontNativeGDI;
|
|
|
|
|
|
|
|
/* GC */
|
|
|
|
pScreen->CreateGC = winCreateGCNativeGDI;
|
|
|
|
|
|
|
|
/* Colormap Routines */
|
|
|
|
pScreen->CreateColormap = miInitializeColormap;
|
|
|
|
pScreen->DestroyColormap =
|
|
|
|
(DestroyColormapProcPtr) (void (*)(void)) NoopDDA;
|
|
|
|
pScreen->InstallColormap = miInstallColormap;
|
|
|
|
pScreen->UninstallColormap = miUninstallColormap;
|
|
|
|
pScreen->ListInstalledColormaps = miListInstalledColormaps;
|
|
|
|
pScreen->StoreColors = (StoreColorsProcPtr) (void (*)(void)) NoopDDA;
|
|
|
|
pScreen->ResolveColor = miResolveColor;
|
|
|
|
|
|
|
|
/* Bitmap */
|
|
|
|
pScreen->BitmapToRegion = winPixmapToRegionNativeGDI;
|
|
|
|
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - calling miDCInitialize\n");
|
|
|
|
|
|
|
|
/* Set the default white and black pixel positions */
|
|
|
|
pScreen->whitePixel = pScreen->blackPixel = (Pixel) 0;
|
|
|
|
|
|
|
|
/* Initialize the cursor */
|
|
|
|
if (!miDCInitialize(pScreen, &g_winPointerCursorFuncs)) {
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - miDCInitialize failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Create a default colormap */
|
|
|
|
if (!miCreateDefColormap(pScreen)) {
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - miCreateDefColormap () "
|
|
|
|
"failed\n");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - miCreateDefColormap () "
|
|
|
|
"returned\n");
|
|
|
|
|
|
|
|
/* mi doesn't use a CloseScreen procedure, so no need to wrap */
|
|
|
|
pScreen->CloseScreen = pScreenPriv->pwinCloseScreen;
|
|
|
|
|
|
|
|
/* Tell the server that we are enabled */
|
|
|
|
pScreenPriv->fEnabled = TRUE;
|
|
|
|
|
|
|
|
ErrorF("winFinishScreenInitNativeGDI - Successful addition of "
|
|
|
|
"screen %08x\n", (unsigned int) pScreen);
|
|
|
|
|
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* See Porting Layer Definition - p. 33 */
|
|
|
|
static Bool
|
2012-06-10 07:21:05 -06:00
|
|
|
winSaveScreen(ScreenPtr pScreen, int on)
|
2006-11-26 11:13:41 -07:00
|
|
|
{
|
2012-06-10 07:21:05 -06:00
|
|
|
return TRUE;
|
2006-11-26 11:13:41 -07:00
|
|
|
}
|