Fix XDarwin's broken build of libGL and server side GLX. GL library is only
known to build correctly on Mac OS X 10.3.4 and still needs some work
    for earlier versions.
			
			
This commit is contained in:
		
							parent
							
								
									8ef3e7052e
								
							
						
					
					
						commit
						ddd5835612
					
				|  | @ -1,10 +1,14 @@ | ||||||
| /*
 | /*
 | ||||||
|  * GLX implementation that uses Apple's AGL.framework for OpenGL |  * GLX implementation that uses Apple's AGL.framework for OpenGL | ||||||
|  |  * | ||||||
|  |  * FIXME: This file and indirect.c are very similar. The two should be | ||||||
|  |  * merged by introducing suitable abstractions. | ||||||
|  */ |  */ | ||||||
| /*
 | /*
 | ||||||
|  * Copyright (c) 2002 Greg Parker. All Rights Reserved. |  * Copyright (c) 2002 Greg Parker. All Rights Reserved. | ||||||
|  |  * Copyright (c) 2004 Torrey T. Lyons. All Rights Reserved. | ||||||
|  * |  * | ||||||
|  * Portions of this file are copied from xf86glx.c, |  * Large portions of this file are copied from Mesa's xf86glx.c, | ||||||
|  * which contains the following copyright: |  * which contains the following copyright: | ||||||
|  * |  * | ||||||
|  * Copyright 1998-1999 Precision Insight, Inc., Cedar Park, Texas. |  * Copyright 1998-1999 Precision Insight, Inc., Cedar Park, Texas. | ||||||
|  | @ -27,10 +31,6 @@ | ||||||
|  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |  * 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 |  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||||
|  * DEALINGS IN THE SOFTWARE. |  * DEALINGS IN THE SOFTWARE. | ||||||
|  * |  | ||||||
|  * Except as contained in this notice, the name(s) of the above copyright |  | ||||||
|  * holders shall not be used in advertising or otherwise to promote the sale, |  | ||||||
|  * use or other dealings in this Software without prior written authorization. |  | ||||||
|  */ |  */ | ||||||
| /* $XFree86: xc/programs/Xserver/GL/apple/aglGlx.c,v 1.2 2003/09/16 00:36:11 torrey Exp $ */ | /* $XFree86: xc/programs/Xserver/GL/apple/aglGlx.c,v 1.2 2003/09/16 00:36:11 torrey Exp $ */ | ||||||
| 
 | 
 | ||||||
|  | @ -58,6 +58,8 @@ | ||||||
| #include <GL/internal/glcore.h> | #include <GL/internal/glcore.h> | ||||||
| #undef BOOL | #undef BOOL | ||||||
| 
 | 
 | ||||||
|  | #include "glcontextmodes.h" | ||||||
|  | 
 | ||||||
| // Write debugging output, or not
 | // Write debugging output, or not
 | ||||||
| #ifdef GLAQUA_DEBUG | #ifdef GLAQUA_DEBUG | ||||||
| #define GLAQUA_DEBUG_MSG ErrorF | #define GLAQUA_DEBUG_MSG ErrorF | ||||||
|  | @ -102,14 +104,14 @@ static void glAquaResetExtension(void); | ||||||
|  * __glXScreenInit to initialize each of the active screens |  * __glXScreenInit to initialize each of the active screens | ||||||
|  * (__glXActiveScreens[]).  Several of the fields must be initialized by |  * (__glXActiveScreens[]).  Several of the fields must be initialized by | ||||||
|  * the screenProbe routine before they are copied to the active screens |  * the screenProbe routine before they are copied to the active screens | ||||||
|  * struct.  In particular, the contextCreate, pGlxVisual, numVisuals, |  * struct.  In particular, the contextCreate, modes, numVisuals, | ||||||
|  * and numUsableVisuals fields must be initialized. |  * and numUsableVisuals fields must be initialized. | ||||||
|  */ |  */ | ||||||
| __GLXscreenInfo __glDDXScreenInfo = { | static __GLXscreenInfo __glDDXScreenInfo = { | ||||||
|     glAquaScreenProbe,   /* Must be generic and handle all screens */ |     glAquaScreenProbe,   /* Must be generic and handle all screens */ | ||||||
|     glAquaCreateContext, /* Substitute screen's createContext routine */ |     glAquaCreateContext, /* Substitute screen's createContext routine */ | ||||||
|     glAquaCreateBuffer,  /* Substitute screen's createBuffer routine */ |     glAquaCreateBuffer,  /* Substitute screen's createBuffer routine */ | ||||||
|     NULL,                 /* Set up pGlxVisual in probe */ |     NULL,                 /* Set up modes in probe */ | ||||||
|     NULL,                 /* Set up pVisualPriv in probe */ |     NULL,                 /* Set up pVisualPriv in probe */ | ||||||
|     0,                    /* Set up numVisuals in probe */ |     0,                    /* Set up numVisuals in probe */ | ||||||
|     0,                    /* Set up numUsableVisuals in probe */ |     0,                    /* Set up numUsableVisuals in probe */ | ||||||
|  | @ -119,13 +121,20 @@ __GLXscreenInfo __glDDXScreenInfo = { | ||||||
|     NULL                  /* WrappedPositionWindow is overwritten */ |     NULL                  /* WrappedPositionWindow is overwritten */ | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| __GLXextensionInfo __glDDXExtensionInfo = { | void *__glXglDDXScreenInfo(void) { | ||||||
|  |     return &__glDDXScreenInfo; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static __GLXextensionInfo __glDDXExtensionInfo = { | ||||||
|     GL_CORE_APPLE, |     GL_CORE_APPLE, | ||||||
|     glAquaResetExtension, |     glAquaResetExtension, | ||||||
|     glAquaInitVisuals, |     glAquaInitVisuals, | ||||||
|     glAquaSetVisualConfigs |     glAquaSetVisualConfigs | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | void *__glXglDDXExtensionInfo(void) { | ||||||
|  |     return &__glDDXExtensionInfo; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| // prototypes
 | // prototypes
 | ||||||
| 
 | 
 | ||||||
|  | @ -168,7 +177,7 @@ static __GLexports glAquaExports = { | ||||||
| 
 | 
 | ||||||
| typedef struct { | typedef struct { | ||||||
|     int num_vis; |     int num_vis; | ||||||
|     __GLXvisualConfig *glx_vis; |     __GLcontextModes *modes; | ||||||
|     void **priv; |     void **priv; | ||||||
| 
 | 
 | ||||||
|     // wrapped screen functions
 |     // wrapped screen functions
 | ||||||
|  | @ -564,23 +573,21 @@ glAquaUnrealizeWindow(WindowPtr pWin) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * In the case the driver has no GLX visuals we'll use these. |  | ||||||
|  * [0] = RGB, double buffered |  | ||||||
|  * [1] = RGB, double buffered, stencil, accum |  | ||||||
|  */ |  | ||||||
| // Originally copied from Mesa
 | // Originally copied from Mesa
 | ||||||
| 
 | 
 | ||||||
| static int                 numConfigs     = 0; | static int                 numConfigs     = 0; | ||||||
| static __GLXvisualConfig  *visualConfigs  = NULL; | static __GLXvisualConfig  *visualConfigs  = NULL; | ||||||
| static void              **visualPrivates = NULL; | static void              **visualPrivates = NULL; | ||||||
| 
 | 
 | ||||||
| #define NUM_FALLBACK_CONFIGS 2 | /*
 | ||||||
|  |  * In the case the driver defines no GLX visuals we'll use these. | ||||||
|  |  * Note that for TrueColor and DirectColor visuals, bufferSize is the  | ||||||
|  |  * sum of redSize, greenSize, blueSize and alphaSize, which may be larger  | ||||||
|  |  * than the nplanes/rootDepth of the server's X11 visuals | ||||||
|  |  */ | ||||||
|  | #define NUM_FALLBACK_CONFIGS 5 | ||||||
| static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|  |   /* [0] = RGB, double buffered, Z */ | ||||||
|   { |   { | ||||||
|     -1,                 /* vid */ |     -1,                 /* vid */ | ||||||
|     -1,                 /* class */ |     -1,                 /* class */ | ||||||
|  | @ -595,11 +602,12 @@ static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|     0,                  /* stencilSize */ |     0,                  /* stencilSize */ | ||||||
|     0,                  /* auxBuffers */ |     0,                  /* auxBuffers */ | ||||||
|     0,                  /* level */ |     0,                  /* level */ | ||||||
|     GLX_NONE_EXT,       /* visualRating */ |     GLX_NONE,           /* visualRating */ | ||||||
|     0,                  /* transparentPixel */ |     GLX_NONE,           /* transparentPixel */ | ||||||
|     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|     0                   /* transparentIndex */ |     0                   /* transparentIndex */ | ||||||
|   }, |   }, | ||||||
|  |   /* [1] = RGB, double buffered, Z, stencil, accum */ | ||||||
|   { |   { | ||||||
|     -1,                 /* vid */ |     -1,                 /* vid */ | ||||||
|     -1,                 /* class */ |     -1,                 /* class */ | ||||||
|  | @ -614,15 +622,74 @@ static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|     8,                  /* stencilSize */ |     8,                  /* stencilSize */ | ||||||
|     0,                  /* auxBuffers */ |     0,                  /* auxBuffers */ | ||||||
|     0,                  /* level */ |     0,                  /* level */ | ||||||
|     GLX_NONE_EXT,       /* visualRating */ |     GLX_NONE,           /* visualRating */ | ||||||
|     0,                  /* transparentPixel */ |     GLX_NONE,           /* transparentPixel */ | ||||||
|     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|     0                   /* transparentIndex */ |     0                   /* transparentIndex */ | ||||||
|   } |   }, | ||||||
|  |   /* [2] = RGB+Alpha, double buffered, Z, stencil, accum */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     True,               /* rgba */ | ||||||
|  |     -1, -1, -1, 8,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, -1,     /* rgba masks */ | ||||||
|  |     16, 16, 16, 16,     /* rgba accum sizes */ | ||||||
|  |     True,               /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     8,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
|  |   /* [3] = RGB+Alpha, single buffered, Z, stencil, accum */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     True,               /* rgba */ | ||||||
|  |     -1, -1, -1, 8,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, -1,     /* rgba masks */ | ||||||
|  |     16, 16, 16, 16,     /* rgba accum sizes */ | ||||||
|  |     False,              /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     8,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
|  |   /* [4] = CI, double buffered, Z */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     False,              /* rgba? (false = color index) */ | ||||||
|  |     -1, -1, -1, 0,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, 0,      /* rgba masks */ | ||||||
|  |      0,  0,  0, 0,      /* rgba accum sizes */ | ||||||
|  |     True,               /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     0,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| static int count_bits(unsigned int n) | static int count_bits(unsigned int n) | ||||||
| { | { | ||||||
|    int bits = 0; |    int bits = 0; | ||||||
|  | @ -635,7 +702,6 @@ static int count_bits(unsigned int n) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // Mostly copied from Mesa's xf86glx.c
 |  | ||||||
| static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|                          VisualID *defaultVisp, |                          VisualID *defaultVisp, | ||||||
|                          int ndepth, DepthPtr pdepth, |                          int ndepth, DepthPtr pdepth, | ||||||
|  | @ -649,7 +715,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     VisualPtr pVisual = *visualp; |     VisualPtr pVisual = *visualp; | ||||||
|     VisualPtr pVisualNew = NULL; |     VisualPtr pVisualNew = NULL; | ||||||
|     VisualID *orig_vid = NULL; |     VisualID *orig_vid = NULL; | ||||||
|     __GLXvisualConfig *glXVisualPtr = NULL; |     __GLcontextModes *modes; | ||||||
|     __GLXvisualConfig *pNewVisualConfigs = NULL; |     __GLXvisualConfig *pNewVisualConfigs = NULL; | ||||||
|     void **glXVisualPriv; |     void **glXVisualPriv; | ||||||
|     void **pNewVisualPriv; |     void **pNewVisualPriv; | ||||||
|  | @ -725,9 +791,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Alloc space for the list of glXVisuals */ |     /* Alloc space for the list of glXVisuals */ | ||||||
|     glXVisualPtr = (__GLXvisualConfig *)__glXMalloc(numNewVisuals * |     modes = _gl_context_modes_create(numNewVisuals, sizeof(__GLcontextModes)); | ||||||
| 						    sizeof(__GLXvisualConfig)); |     if (modes == NULL) { | ||||||
|     if (!glXVisualPtr) { |  | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -737,7 +802,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     /* Alloc space for the list of glXVisualPrivates */ |     /* Alloc space for the list of glXVisualPrivates */ | ||||||
|     glXVisualPriv = (void **)__glXMalloc(numNewVisuals * sizeof(void *)); |     glXVisualPriv = (void **)__glXMalloc(numNewVisuals * sizeof(void *)); | ||||||
|     if (!glXVisualPriv) { |     if (!glXVisualPriv) { | ||||||
| 	__glXFree(glXVisualPtr); |         _gl_context_modes_destroy( modes ); | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -748,7 +813,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     pVisualNew = (VisualPtr)__glXMalloc(numNewVisuals * sizeof(VisualRec)); |     pVisualNew = (VisualPtr)__glXMalloc(numNewVisuals * sizeof(VisualRec)); | ||||||
|     if (!pVisualNew) { |     if (!pVisualNew) { | ||||||
|         __glXFree(glXVisualPriv); |         __glXFree(glXVisualPriv); | ||||||
| 	__glXFree(glXVisualPtr); |         _gl_context_modes_destroy( modes ); | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -757,6 +822,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
| 
 | 
 | ||||||
|     /* Initialize the new visuals */ |     /* Initialize the new visuals */ | ||||||
|     found_default = FALSE; |     found_default = FALSE; | ||||||
|  |     glAquaScreens[screenInfo.numScreens-1].modes = modes; | ||||||
|     for (i = j = 0; i < numVisuals; i++) { |     for (i = j = 0; i < numVisuals; i++) { | ||||||
|         int is_rgb = (pVisual[i].class == TrueColor || |         int is_rgb = (pVisual[i].class == TrueColor || | ||||||
|                   pVisual[i].class == DirectColor); |                   pVisual[i].class == DirectColor); | ||||||
|  | @ -765,6 +831,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|             if (pNewVisualConfigs[k].rgba != is_rgb) |             if (pNewVisualConfigs[k].rgba != is_rgb) | ||||||
|                 continue; |                 continue; | ||||||
| 
 | 
 | ||||||
|  |             assert( modes != NULL ); | ||||||
|  | 
 | ||||||
|             /* Initialize the new visual */ |             /* Initialize the new visual */ | ||||||
|             pVisualNew[j] = pVisual[i]; |             pVisualNew[j] = pVisual[i]; | ||||||
|             pVisualNew[j].vid = FakeClientID(0); |             pVisualNew[j].vid = FakeClientID(0); | ||||||
|  | @ -779,8 +847,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|             orig_vid[j] = pVisual[i].vid; |             orig_vid[j] = pVisual[i].vid; | ||||||
| 
 | 
 | ||||||
|             /* Initialize the glXVisual */ |             /* Initialize the glXVisual */ | ||||||
| 	    glXVisualPtr[j] = pNewVisualConfigs[k]; |             _gl_copy_visual_to_context_mode( modes, & pNewVisualConfigs[k] ); | ||||||
| 	    glXVisualPtr[j].vid = pVisualNew[j].vid; |             modes->visualID = pVisualNew[j].vid; | ||||||
| 
 | 
 | ||||||
|             /*
 |             /*
 | ||||||
|              * If the class is -1, then assume the X visual information |              * If the class is -1, then assume the X visual information | ||||||
|  | @ -788,23 +856,27 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|              * visual.  NOTE: if class != -1, then all other fields MUST |              * visual.  NOTE: if class != -1, then all other fields MUST | ||||||
|              * be initialized. |              * be initialized. | ||||||
|              */ |              */ | ||||||
| 	    if (glXVisualPtr[j].class == -1) { |             if (modes->visualType == GLX_NONE) { | ||||||
| 		glXVisualPtr[j].class      = pVisual[i].class; |                 modes->visualType = _gl_convert_from_x_visual_type( pVisual[i].class ); | ||||||
| 		glXVisualPtr[j].redSize    = count_bits(pVisual[i].redMask); |                 modes->redBits    = count_bits(pVisual[i].redMask); | ||||||
| 		glXVisualPtr[j].greenSize  = count_bits(pVisual[i].greenMask); |                 modes->greenBits  = count_bits(pVisual[i].greenMask); | ||||||
| 		glXVisualPtr[j].blueSize   = count_bits(pVisual[i].blueMask); |                 modes->blueBits   = count_bits(pVisual[i].blueMask); | ||||||
| 		glXVisualPtr[j].alphaSize  = glXVisualPtr[j].alphaSize; |                 modes->alphaBits  = modes->alphaBits; | ||||||
| 		glXVisualPtr[j].redMask    = pVisual[i].redMask; |                 modes->redMask    = pVisual[i].redMask; | ||||||
| 		glXVisualPtr[j].greenMask  = pVisual[i].greenMask; |                 modes->greenMask  = pVisual[i].greenMask; | ||||||
| 		glXVisualPtr[j].blueMask   = pVisual[i].blueMask; |                 modes->blueMask   = pVisual[i].blueMask; | ||||||
| 		glXVisualPtr[j].alphaMask  = glXVisualPtr[j].alphaMask; |                 modes->alphaMask  = modes->alphaMask; | ||||||
| 		glXVisualPtr[j].bufferSize = rootDepth; |                 modes->rgbBits = (is_rgb) | ||||||
|  |                     ? (modes->redBits + modes->greenBits + | ||||||
|  |                        modes->blueBits + modes->alphaBits) | ||||||
|  |                     : rootDepth; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             /* Save the device-dependent private for this visual */ |             /* Save the device-dependent private for this visual */ | ||||||
|             glXVisualPriv[j] = pNewVisualPriv[k]; |             glXVisualPriv[j] = pNewVisualPriv[k]; | ||||||
| 
 | 
 | ||||||
|             j++; |             j++; | ||||||
|  |             modes = modes->next; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -812,7 +884,6 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
| 
 | 
 | ||||||
|     /* Save the GLX visuals in the screen structure */ |     /* Save the GLX visuals in the screen structure */ | ||||||
|     glAquaScreens[screenInfo.numScreens-1].num_vis = numNewVisuals; |     glAquaScreens[screenInfo.numScreens-1].num_vis = numNewVisuals; | ||||||
|     glAquaScreens[screenInfo.numScreens-1].glx_vis = glXVisualPtr; |  | ||||||
|     glAquaScreens[screenInfo.numScreens-1].priv = glXVisualPriv; |     glAquaScreens[screenInfo.numScreens-1].priv = glXVisualPriv; | ||||||
| 
 | 
 | ||||||
|     /* Set up depth's VisualIDs */ |     /* Set up depth's VisualIDs */ | ||||||
|  | @ -862,7 +933,6 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     return TRUE; |     return TRUE; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Copied from Mesa
 |  | ||||||
| static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | ||||||
|                                    void **privates) |                                    void **privates) | ||||||
| { | { | ||||||
|  | @ -873,7 +943,6 @@ static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | ||||||
|     visualPrivates = privates; |     visualPrivates = privates; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Copied from Mesa
 |  | ||||||
| static Bool glAquaInitVisuals(VisualPtr *visualp, DepthPtr *depthp, | static Bool glAquaInitVisuals(VisualPtr *visualp, DepthPtr *depthp, | ||||||
|                               int *nvisualp, int *ndepthp, |                               int *nvisualp, int *ndepthp, | ||||||
|                               int *rootDepthp, VisualID *defaultVisp, |                               int *rootDepthp, VisualID *defaultVisp, | ||||||
|  | @ -893,29 +962,30 @@ static void fixup_visuals(int screen) | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = screenInfo.screens[screen]; |     ScreenPtr pScreen = screenInfo.screens[screen]; | ||||||
|     glAquaScreenRec *pScr = &glAquaScreens[screen]; |     glAquaScreenRec *pScr = &glAquaScreens[screen]; | ||||||
|     __GLXvisualConfig *pGLXVis  = pScr->glx_vis; |     int j; | ||||||
|     VisualPtr pVis; |     __GLcontextModes *modes; | ||||||
|     int i, j; |  | ||||||
| 
 | 
 | ||||||
|     GLAQUA_DEBUG_MSG("fixup_visuals\n"); |     GLAQUA_DEBUG_MSG("fixup_visuals\n"); | ||||||
| 
 | 
 | ||||||
|     for (i = 0; i < pScr->num_vis; i++, pGLXVis++) { |     for ( modes = pScr->modes ; modes != NULL ; modes = modes->next ) { | ||||||
| 	pVis = pScreen->visuals; |         const int vis_class = _gl_convert_to_x_visual_type( modes->visualType ); | ||||||
|  |         const int nplanes = (modes->rgbBits - modes->alphaBits); | ||||||
|  |         const VisualPtr pVis = pScreen->visuals; | ||||||
| 
 | 
 | ||||||
|         /* Find a visual that matches the GLX visual's class and size */ |         /* Find a visual that matches the GLX visual's class and size */ | ||||||
| 	for (j = 0; j < pScreen->numVisuals; j++, pVis++) { |         for (j = 0; j < pScreen->numVisuals; j++) { | ||||||
| 	    if (pVis->class == pGLXVis->class && |             if (pVis[j].class == vis_class && | ||||||
| 		pVis->nplanes == pGLXVis->bufferSize) { |             pVis[j].nplanes == nplanes) { | ||||||
| 
 | 
 | ||||||
|             /* Fixup the masks */ |             /* Fixup the masks */ | ||||||
| 		pGLXVis->redMask   = pVis->redMask; |             modes->redMask   = pVis[j].redMask; | ||||||
| 		pGLXVis->greenMask = pVis->greenMask; |             modes->greenMask = pVis[j].greenMask; | ||||||
| 		pGLXVis->blueMask  = pVis->blueMask; |             modes->blueMask  = pVis[j].blueMask; | ||||||
| 
 | 
 | ||||||
|             /* Recalc the sizes */ |             /* Recalc the sizes */ | ||||||
| 		pGLXVis->redSize   = count_bits(pGLXVis->redMask); |             modes->redBits   = count_bits(modes->redMask); | ||||||
| 		pGLXVis->greenSize = count_bits(pGLXVis->greenMask); |             modes->greenBits = count_bits(modes->greenMask); | ||||||
| 		pGLXVis->blueSize  = count_bits(pGLXVis->blueMask); |             modes->blueBits  = count_bits(modes->blueMask); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -924,69 +994,60 @@ static void fixup_visuals(int screen) | ||||||
| static void init_screen_visuals(int screen) | static void init_screen_visuals(int screen) | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = screenInfo.screens[screen]; |     ScreenPtr pScreen = screenInfo.screens[screen]; | ||||||
|     __GLXvisualConfig *pGLXVis = glAquaScreens[screen].glx_vis; |     __GLcontextModes *modes; | ||||||
|     // XMesaVisual *pXMesaVisual;
 |  | ||||||
|     VisualPtr pVis; |  | ||||||
|     int *used; |     int *used; | ||||||
|     int i, j; |     int i, j; | ||||||
| 
 | 
 | ||||||
|     GLAQUA_DEBUG_MSG("init_screen_visuals\n"); |     GLAQUA_DEBUG_MSG("init_screen_visuals\n"); | ||||||
| 
 | 
 | ||||||
|     /* Alloc space for the list of XMesa visuals */ |     /* FIXME: Change 'used' to be a array of bits (rather than of ints),
 | ||||||
|     // pXMesaVisual = (XMesaVisual *)__glXMalloc(MESAScreens[screen].num_vis *
 |      * FIXME: create a stack array of 8 or 16 bytes.  If 'numVisuals' is less | ||||||
|     //					      sizeof(XMesaVisual));
 |      * FIXME: than 64 or 128 the stack array can be used instead of calling | ||||||
|     // __glXMemset(pXMesaVisual, 0,
 |      * FIXME: __glXMalloc / __glXFree.  If nothing else, convert 'used' to | ||||||
|     //		MESAScreens[screen].num_vis * sizeof(XMesaVisual));
 |      * FIXME: array of bytes instead of ints! | ||||||
| 
 |      */ | ||||||
|     used = (int *)__glXMalloc(pScreen->numVisuals * sizeof(int)); |     used = (int *)__glXMalloc(pScreen->numVisuals * sizeof(int)); | ||||||
|     __glXMemset(used, 0, pScreen->numVisuals * sizeof(int)); |     __glXMemset(used, 0, pScreen->numVisuals * sizeof(int)); | ||||||
| 
 | 
 | ||||||
|     for (i = 0; i < glAquaScreens[screen].num_vis; i++, pGLXVis++) { |     i = 0; | ||||||
| 	pVis = pScreen->visuals; |     for ( modes = glAquaScreens[screen].modes  | ||||||
| 	for (j = 0; j < pScreen->numVisuals; j++, pVis++) { |           ; modes != NULL | ||||||
|  |           ; modes = modes->next ) { | ||||||
|  |         const int vis_class = _gl_convert_to_x_visual_type( modes->visualType ); | ||||||
|  |         const int nplanes = (modes->rgbBits - modes->alphaBits); | ||||||
|  |         const VisualPtr pVis = pScreen->visuals; | ||||||
| 
 | 
 | ||||||
| 	    if (pVis->class == pGLXVis->class && |         for (j = 0; j < pScreen->numVisuals; j++) { | ||||||
| 		pVis->nplanes == pGLXVis->bufferSize && |             if (pVis[j].class     == vis_class && | ||||||
|  |                 pVis[j].nplanes   == nplanes && | ||||||
|  |                 pVis[j].redMask   == modes->redMask && | ||||||
|  |                 pVis[j].greenMask == modes->greenMask && | ||||||
|  |                 pVis[j].blueMask  == modes->blueMask && | ||||||
|                 !used[j]) { |                 !used[j]) { | ||||||
| 
 | 
 | ||||||
| 		if (pVis->redMask   == pGLXVis->redMask && |  | ||||||
| 		    pVis->greenMask == pGLXVis->greenMask && |  | ||||||
| 		    pVis->blueMask  == pGLXVis->blueMask) { |  | ||||||
| 
 |  | ||||||
| 		    /* Create the XMesa visual */ |  | ||||||
| 		    /*
 |  | ||||||
| 		    pXMesaVisual[i] = |  | ||||||
|                          XMesaCreateVisual(pScreen, |  | ||||||
| 					   pVis, |  | ||||||
| 					   pGLXVis->rgba, |  | ||||||
| 					   (pGLXVis->alphaSize > 0), |  | ||||||
| 					   pGLXVis->doubleBuffer, |  | ||||||
| 					   pGLXVis->stereo, |  | ||||||
| 					   GL_TRUE, // ximage_flag
 |  | ||||||
| 					   pGLXVis->depthSize, |  | ||||||
| 					   pGLXVis->stencilSize, |  | ||||||
| 					   pGLXVis->accumRedSize, |  | ||||||
| 					   pGLXVis->accumGreenSize, |  | ||||||
| 					   pGLXVis->accumBlueSize, |  | ||||||
| 					   pGLXVis->accumAlphaSize, |  | ||||||
|                                            0,  // numSamples
 |  | ||||||
| 					   pGLXVis->level, |  | ||||||
|                                            pGLXVis->visualRating ); |  | ||||||
| 		    */ |  | ||||||
|                     /* Set the VisualID */ |                     /* Set the VisualID */ | ||||||
| 		    pGLXVis->vid = pVis->vid; |                     modes->visualID = pVis[j].vid; | ||||||
| 
 | 
 | ||||||
|                     /* Mark this visual used */ |                     /* Mark this visual used */ | ||||||
|                     used[j] = 1; |                     used[j] = 1; | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         if ( j == pScreen->numVisuals ) { | ||||||
|  |             ErrorF("No matching visual for __GLcontextMode with " | ||||||
|  |                    "visual class = %d (%d), nplanes = %u\n", | ||||||
|  |                    vis_class,  | ||||||
|  |                    (int)modes->visualType, | ||||||
|  |                    (unsigned int)(modes->rgbBits - modes->alphaBits) ); | ||||||
|         } |         } | ||||||
|  |         else if ( modes->visualID == -1 ) { | ||||||
|  |             FatalError( "Matching visual found, but visualID still -1!\n" ); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         i++; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     __glXFree(used); |     __glXFree(used); | ||||||
| 
 |  | ||||||
|     // glAquaScreens[screen].xm_vis = pXMesaVisual;
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static Bool glAquaScreenProbe(int screen) | static Bool glAquaScreenProbe(int screen) | ||||||
|  | @ -999,7 +1060,7 @@ static Bool glAquaScreenProbe(int screen) | ||||||
|     /*
 |     /*
 | ||||||
|      * Set up the current screen's visuals. |      * Set up the current screen's visuals. | ||||||
|      */ |      */ | ||||||
|     __glDDXScreenInfo.pGlxVisual = glAquaScreens[screen].glx_vis; |     __glDDXScreenInfo.modes = glAquaScreens[screen].modes; | ||||||
|     __glDDXScreenInfo.pVisualPriv = glAquaScreens[screen].priv; |     __glDDXScreenInfo.pVisualPriv = glAquaScreens[screen].priv; | ||||||
|     __glDDXScreenInfo.numVisuals = |     __glDDXScreenInfo.numVisuals = | ||||||
|         __glDDXScreenInfo.numUsableVisuals = glAquaScreens[screen].num_vis; |         __glDDXScreenInfo.numUsableVisuals = glAquaScreens[screen].num_vis; | ||||||
|  | @ -1022,7 +1083,9 @@ static Bool glAquaScreenProbe(int screen) | ||||||
|      */ |      */ | ||||||
|     init_screen_visuals(screen); |     init_screen_visuals(screen); | ||||||
| 
 | 
 | ||||||
|     // Wrap RealizeWindow and UnrealizeWindow on this screen
 |     /*
 | ||||||
|  |      * Wrap RealizeWindow and UnrealizeWindow on this screen | ||||||
|  |      */ | ||||||
|     pScreen = screenInfo.screens[screen]; |     pScreen = screenInfo.screens[screen]; | ||||||
|     screenPriv = &glAquaScreens[screen]; |     screenPriv = &glAquaScreens[screen]; | ||||||
|     screenPriv->RealizeWindow = pScreen->RealizeWindow; |     screenPriv->RealizeWindow = pScreen->RealizeWindow; | ||||||
|  |  | ||||||
|  | @ -5,8 +5,9 @@ | ||||||
| /*
 | /*
 | ||||||
|  * Copyright (c) 2002 Greg Parker. All Rights Reserved. |  * Copyright (c) 2002 Greg Parker. All Rights Reserved. | ||||||
|  * Copyright (c) 2002 Apple Computer, Inc. |  * Copyright (c) 2002 Apple Computer, Inc. | ||||||
|  |  * Copyright (c) 2004 Torrey T. Lyons. All Rights Reserved. | ||||||
|  * |  * | ||||||
|  * Portions of this file are copied from xf86glx.c, |  * Portions of this file are copied from Mesa's xf86glx.c, | ||||||
|  * which contains the following copyright: |  * which contains the following copyright: | ||||||
|  * |  * | ||||||
|  * Copyright 1998-1999 Precision Insight, Inc., Cedar Park, Texas. |  * Copyright 1998-1999 Precision Insight, Inc., Cedar Park, Texas. | ||||||
|  | @ -29,10 +30,6 @@ | ||||||
|  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |  * 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 |  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||||
|  * DEALINGS IN THE SOFTWARE. |  * DEALINGS IN THE SOFTWARE. | ||||||
|  * |  | ||||||
|  * Except as contained in this notice, the name(s) of the above copyright |  | ||||||
|  * holders shall not be used in advertising or otherwise to promote the sale, |  | ||||||
|  * use or other dealings in this Software without prior written authorization. |  | ||||||
|  */ |  */ | ||||||
| /* $XFree86: xc/programs/Xserver/GL/apple/indirect.c,v 1.2 2003/09/16 00:36:11 torrey Exp $ */ | /* $XFree86: xc/programs/Xserver/GL/apple/indirect.c,v 1.2 2003/09/16 00:36:11 torrey Exp $ */ | ||||||
| 
 | 
 | ||||||
|  | @ -61,6 +58,8 @@ | ||||||
| #include "x-hash.h" | #include "x-hash.h" | ||||||
| #include "x-list.h" | #include "x-list.h" | ||||||
| 
 | 
 | ||||||
|  | #include "glcontextmodes.h" | ||||||
|  | 
 | ||||||
| // ggs: needed to call back to glx with visual configs
 | // ggs: needed to call back to glx with visual configs
 | ||||||
| extern void GlxSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, void **configprivs); | extern void GlxSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, void **configprivs); | ||||||
| 
 | 
 | ||||||
|  | @ -106,14 +105,14 @@ static void glAquaResetExtension(void); | ||||||
|  * __glXScreenInit to initialize each of the active screens |  * __glXScreenInit to initialize each of the active screens | ||||||
|  * (__glXActiveScreens[]).  Several of the fields must be initialized by |  * (__glXActiveScreens[]).  Several of the fields must be initialized by | ||||||
|  * the screenProbe routine before they are copied to the active screens |  * the screenProbe routine before they are copied to the active screens | ||||||
|  * struct.  In particular, the contextCreate, pGlxVisual, numVisuals, |  * struct.  In particular, the contextCreate, modes, numVisuals, | ||||||
|  * and numUsableVisuals fields must be initialized. |  * and numUsableVisuals fields must be initialized. | ||||||
|  */ |  */ | ||||||
| static __GLXscreenInfo __glDDXScreenInfo = { | static __GLXscreenInfo __glDDXScreenInfo = { | ||||||
|     glAquaScreenProbe,   /* Must be generic and handle all screens */ |     glAquaScreenProbe,   /* Must be generic and handle all screens */ | ||||||
|     glAquaCreateContext, /* Substitute screen's createContext routine */ |     glAquaCreateContext, /* Substitute screen's createContext routine */ | ||||||
|     glAquaCreateBuffer,  /* Substitute screen's createBuffer routine */ |     glAquaCreateBuffer,  /* Substitute screen's createBuffer routine */ | ||||||
|     NULL,                 /* Set up pGlxVisual in probe */ |     NULL,                 /* Set up modes in probe */ | ||||||
|     NULL,                 /* Set up pVisualPriv in probe */ |     NULL,                 /* Set up pVisualPriv in probe */ | ||||||
|     0,                    /* Set up numVisuals in probe */ |     0,                    /* Set up numVisuals in probe */ | ||||||
|     0,                    /* Set up numUsableVisuals in probe */ |     0,                    /* Set up numUsableVisuals in probe */ | ||||||
|  | @ -177,7 +176,7 @@ static __GLexports glAquaExports = { | ||||||
| 
 | 
 | ||||||
| typedef struct { | typedef struct { | ||||||
|     int num_vis; |     int num_vis; | ||||||
|     __GLXvisualConfig *glx_vis; |     __GLcontextModes *modes; | ||||||
|     void **priv; |     void **priv; | ||||||
| 
 | 
 | ||||||
|     // wrapped screen functions
 |     // wrapped screen functions
 | ||||||
|  | @ -646,19 +645,22 @@ glAquaUnrealizeWindow(WindowPtr pWin) | ||||||
|     return result; |     return result; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /*
 | 
 | ||||||
|  * In the case the driver has no GLX visuals we'll use these. |  | ||||||
|  * [0] = RGB, double buffered |  | ||||||
|  * [1] = RGB, double buffered, stencil, accum |  | ||||||
|  */ |  | ||||||
| // Originally copied from Mesa
 | // Originally copied from Mesa
 | ||||||
| 
 | 
 | ||||||
| static int                 numConfigs     = 0; | static int                 numConfigs     = 0; | ||||||
| static __GLXvisualConfig  *visualConfigs  = NULL; | static __GLXvisualConfig  *visualConfigs  = NULL; | ||||||
| static void              **visualPrivates = NULL; | static void              **visualPrivates = NULL; | ||||||
| 
 | 
 | ||||||
| #define NUM_FALLBACK_CONFIGS 2 | /*
 | ||||||
|  |  * In the case the driver defines no GLX visuals we'll use these. | ||||||
|  |  * Note that for TrueColor and DirectColor visuals, bufferSize is the  | ||||||
|  |  * sum of redSize, greenSize, blueSize and alphaSize, which may be larger  | ||||||
|  |  * than the nplanes/rootDepth of the server's X11 visuals | ||||||
|  |  */ | ||||||
|  | #define NUM_FALLBACK_CONFIGS 5 | ||||||
| static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|  |   /* [0] = RGB, double buffered, Z */ | ||||||
|   { |   { | ||||||
|     -1,                 /* vid */ |     -1,                 /* vid */ | ||||||
|     -1,                 /* class */ |     -1,                 /* class */ | ||||||
|  | @ -673,11 +675,12 @@ static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|     0,                  /* stencilSize */ |     0,                  /* stencilSize */ | ||||||
|     0,                  /* auxBuffers */ |     0,                  /* auxBuffers */ | ||||||
|     0,                  /* level */ |     0,                  /* level */ | ||||||
|     GLX_NONE_EXT,       /* visualRating */ |     GLX_NONE,           /* visualRating */ | ||||||
|     0,                  /* transparentPixel */ |     GLX_NONE,           /* transparentPixel */ | ||||||
|     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|     0                   /* transparentIndex */ |     0                   /* transparentIndex */ | ||||||
|   }, |   }, | ||||||
|  |   /* [1] = RGB, double buffered, Z, stencil, accum */ | ||||||
|   { |   { | ||||||
|     -1,                 /* vid */ |     -1,                 /* vid */ | ||||||
|     -1,                 /* class */ |     -1,                 /* class */ | ||||||
|  | @ -692,11 +695,71 @@ static __GLXvisualConfig FallbackConfigs[NUM_FALLBACK_CONFIGS] = { | ||||||
|     8,                  /* stencilSize */ |     8,                  /* stencilSize */ | ||||||
|     0,                  /* auxBuffers */ |     0,                  /* auxBuffers */ | ||||||
|     0,                  /* level */ |     0,                  /* level */ | ||||||
|     GLX_NONE_EXT,       /* visualRating */ |     GLX_NONE,           /* visualRating */ | ||||||
|     0,                  /* transparentPixel */ |     GLX_NONE,           /* transparentPixel */ | ||||||
|     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|     0                   /* transparentIndex */ |     0                   /* transparentIndex */ | ||||||
|   } |   }, | ||||||
|  |   /* [2] = RGB+Alpha, double buffered, Z, stencil, accum */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     True,               /* rgba */ | ||||||
|  |     -1, -1, -1, 8,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, -1,     /* rgba masks */ | ||||||
|  |     16, 16, 16, 16,     /* rgba accum sizes */ | ||||||
|  |     True,               /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     8,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
|  |   /* [3] = RGB+Alpha, single buffered, Z, stencil, accum */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     True,               /* rgba */ | ||||||
|  |     -1, -1, -1, 8,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, -1,     /* rgba masks */ | ||||||
|  |     16, 16, 16, 16,     /* rgba accum sizes */ | ||||||
|  |     False,              /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     8,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
|  |   /* [4] = CI, double buffered, Z */ | ||||||
|  |   { | ||||||
|  |     -1,                 /* vid */ | ||||||
|  |     -1,                 /* class */ | ||||||
|  |     False,              /* rgba? (false = color index) */ | ||||||
|  |     -1, -1, -1, 0,      /* rgba sizes */ | ||||||
|  |     -1, -1, -1, 0,      /* rgba masks */ | ||||||
|  |      0,  0,  0, 0,      /* rgba accum sizes */ | ||||||
|  |     True,               /* doubleBuffer */ | ||||||
|  |     False,              /* stereo */ | ||||||
|  |     -1,                 /* bufferSize */ | ||||||
|  |     16,                 /* depthSize */ | ||||||
|  |     0,                  /* stencilSize */ | ||||||
|  |     0,                  /* auxBuffers */ | ||||||
|  |     0,                  /* level */ | ||||||
|  |     GLX_NONE,           /* visualRating */ | ||||||
|  |     GLX_NONE,           /* transparentPixel */ | ||||||
|  |     0, 0, 0, 0,         /* transparent rgba color (floats scaled to ints) */ | ||||||
|  |     0                   /* transparentIndex */ | ||||||
|  |   }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static __GLXvisualConfig NullConfig = { | static __GLXvisualConfig NullConfig = { | ||||||
|  | @ -729,7 +792,7 @@ static inline int count_bits(uint32_t x) | ||||||
|     return x & 63; |     return x & 63; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Mostly copied from Mesa's xf86glx.c
 | 
 | ||||||
| static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|                          VisualID *defaultVisp, |                          VisualID *defaultVisp, | ||||||
|                          int ndepth, DepthPtr pdepth, |                          int ndepth, DepthPtr pdepth, | ||||||
|  | @ -743,7 +806,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     VisualPtr pVisual = *visualp; |     VisualPtr pVisual = *visualp; | ||||||
|     VisualPtr pVisualNew = NULL; |     VisualPtr pVisualNew = NULL; | ||||||
|     VisualID *orig_vid = NULL; |     VisualID *orig_vid = NULL; | ||||||
|     __GLXvisualConfig *glXVisualPtr = NULL; |     __GLcontextModes *modes; | ||||||
|     __GLXvisualConfig *pNewVisualConfigs = NULL; |     __GLXvisualConfig *pNewVisualConfigs = NULL; | ||||||
|     void **glXVisualPriv; |     void **glXVisualPriv; | ||||||
|     void **pNewVisualPriv; |     void **pNewVisualPriv; | ||||||
|  | @ -825,9 +888,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Alloc space for the list of glXVisuals */ |     /* Alloc space for the list of glXVisuals */ | ||||||
|     glXVisualPtr = (__GLXvisualConfig *)__glXMalloc(numNewVisuals * |     modes = _gl_context_modes_create(numNewVisuals, sizeof(__GLcontextModes)); | ||||||
| 						    sizeof(__GLXvisualConfig)); |     if (modes == NULL) { | ||||||
|     if (!glXVisualPtr) { |  | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -837,7 +899,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     /* Alloc space for the list of glXVisualPrivates */ |     /* Alloc space for the list of glXVisualPrivates */ | ||||||
|     glXVisualPriv = (void **)__glXMalloc(numNewVisuals * sizeof(void *)); |     glXVisualPriv = (void **)__glXMalloc(numNewVisuals * sizeof(void *)); | ||||||
|     if (!glXVisualPriv) { |     if (!glXVisualPriv) { | ||||||
| 	__glXFree(glXVisualPtr); |         _gl_context_modes_destroy( modes ); | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -848,7 +910,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|     pVisualNew = (VisualPtr)__glXMalloc(numNewVisuals * sizeof(VisualRec)); |     pVisualNew = (VisualPtr)__glXMalloc(numNewVisuals * sizeof(VisualRec)); | ||||||
|     if (!pVisualNew) { |     if (!pVisualNew) { | ||||||
|         __glXFree(glXVisualPriv); |         __glXFree(glXVisualPriv); | ||||||
| 	__glXFree(glXVisualPtr); |         _gl_context_modes_destroy( modes ); | ||||||
|         __glXFree(orig_vid); |         __glXFree(orig_vid); | ||||||
|         __glXFree(pNewVisualPriv); |         __glXFree(pNewVisualPriv); | ||||||
|         __glXFree(pNewVisualConfigs); |         __glXFree(pNewVisualConfigs); | ||||||
|  | @ -857,6 +919,7 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
| 
 | 
 | ||||||
|     /* Initialize the new visuals */ |     /* Initialize the new visuals */ | ||||||
|     found_default = FALSE; |     found_default = FALSE; | ||||||
|  |     glAquaScreens[screenInfo.numScreens-1].modes = modes; | ||||||
|     for (i = j = 0; i < numVisuals; i++) { |     for (i = j = 0; i < numVisuals; i++) { | ||||||
|         int is_rgb = (pVisual[i].class == TrueColor || |         int is_rgb = (pVisual[i].class == TrueColor || | ||||||
|                       pVisual[i].class == DirectColor); |                       pVisual[i].class == DirectColor); | ||||||
|  | @ -880,8 +943,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|             orig_vid[j] = pVisual[i].vid; |             orig_vid[j] = pVisual[i].vid; | ||||||
| 
 | 
 | ||||||
|             /* Initialize the glXVisual */ |             /* Initialize the glXVisual */ | ||||||
| 	    glXVisualPtr[j] = NullConfig; |             _gl_copy_visual_to_context_mode( modes, & NullConfig ); | ||||||
| 	    glXVisualPriv[j] = NULL; |             modes->visualID = pVisualNew[j].vid; | ||||||
| 
 | 
 | ||||||
|             j++; |             j++; | ||||||
| 
 | 
 | ||||||
|  | @ -892,6 +955,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|             if (pNewVisualConfigs[k].rgba != is_rgb) |             if (pNewVisualConfigs[k].rgba != is_rgb) | ||||||
|                 continue; |                 continue; | ||||||
| 
 | 
 | ||||||
|  |             assert( modes != NULL ); | ||||||
|  | 
 | ||||||
|             /* Initialize the new visual */ |             /* Initialize the new visual */ | ||||||
|             pVisualNew[j] = pVisual[i]; |             pVisualNew[j] = pVisual[i]; | ||||||
|             pVisualNew[j].vid = FakeClientID(0); |             pVisualNew[j].vid = FakeClientID(0); | ||||||
|  | @ -906,8 +971,8 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|             orig_vid[j] = pVisual[i].vid; |             orig_vid[j] = pVisual[i].vid; | ||||||
| 
 | 
 | ||||||
|             /* Initialize the glXVisual */ |             /* Initialize the glXVisual */ | ||||||
| 	    glXVisualPtr[j] = pNewVisualConfigs[k]; |             _gl_copy_visual_to_context_mode( modes, & pNewVisualConfigs[k] ); | ||||||
| 	    glXVisualPtr[j].vid = pVisualNew[j].vid; |             modes->visualID = pVisualNew[j].vid; | ||||||
| 
 | 
 | ||||||
|             /*
 |             /*
 | ||||||
|              * If the class is -1, then assume the X visual information |              * If the class is -1, then assume the X visual information | ||||||
|  | @ -915,23 +980,27 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
|              * visual.  NOTE: if class != -1, then all other fields MUST |              * visual.  NOTE: if class != -1, then all other fields MUST | ||||||
|              * be initialized. |              * be initialized. | ||||||
|              */ |              */ | ||||||
| 	    if (glXVisualPtr[j].class == -1) { |             if (modes->visualType == GLX_NONE) { | ||||||
| 		glXVisualPtr[j].class      = pVisual[i].class; |                 modes->visualType = _gl_convert_from_x_visual_type( pVisual[i].class ); | ||||||
| 		glXVisualPtr[j].redSize    = count_bits(pVisual[i].redMask); |                 modes->redBits    = count_bits(pVisual[i].redMask); | ||||||
| 		glXVisualPtr[j].greenSize  = count_bits(pVisual[i].greenMask); |                 modes->greenBits  = count_bits(pVisual[i].greenMask); | ||||||
| 		glXVisualPtr[j].blueSize   = count_bits(pVisual[i].blueMask); |                 modes->blueBits   = count_bits(pVisual[i].blueMask); | ||||||
| 		glXVisualPtr[j].alphaSize  = glXVisualPtr[j].alphaSize; |                 modes->alphaBits  = modes->alphaBits; | ||||||
| 		glXVisualPtr[j].redMask    = pVisual[i].redMask; |                 modes->redMask    = pVisual[i].redMask; | ||||||
| 		glXVisualPtr[j].greenMask  = pVisual[i].greenMask; |                 modes->greenMask  = pVisual[i].greenMask; | ||||||
| 		glXVisualPtr[j].blueMask   = pVisual[i].blueMask; |                 modes->blueMask   = pVisual[i].blueMask; | ||||||
| 		glXVisualPtr[j].alphaMask  = glXVisualPtr[j].alphaMask; |                 modes->alphaMask  = modes->alphaMask; | ||||||
| 		glXVisualPtr[j].bufferSize = rootDepth; |                 modes->rgbBits = (is_rgb) | ||||||
|  |                     ? (modes->redBits + modes->greenBits + | ||||||
|  |                        modes->blueBits + modes->alphaBits) | ||||||
|  |                     : rootDepth; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             /* Save the device-dependent private for this visual */ |             /* Save the device-dependent private for this visual */ | ||||||
|             glXVisualPriv[j] = pNewVisualPriv[k]; |             glXVisualPriv[j] = pNewVisualPriv[k]; | ||||||
| 
 | 
 | ||||||
|             j++; |             j++; | ||||||
|  |             modes = modes->next; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -939,7 +1008,6 @@ static Bool init_visuals(int *nvisualp, VisualPtr *visualp, | ||||||
| 
 | 
 | ||||||
|     /* Save the GLX visuals in the screen structure */ |     /* Save the GLX visuals in the screen structure */ | ||||||
|     glAquaScreens[screenInfo.numScreens-1].num_vis = numNewVisuals; |     glAquaScreens[screenInfo.numScreens-1].num_vis = numNewVisuals; | ||||||
|     glAquaScreens[screenInfo.numScreens-1].glx_vis = glXVisualPtr; |  | ||||||
|     glAquaScreens[screenInfo.numScreens-1].priv = glXVisualPriv; |     glAquaScreens[screenInfo.numScreens-1].priv = glXVisualPriv; | ||||||
| 
 | 
 | ||||||
|     /* Set up depth's VisualIDs */ |     /* Set up depth's VisualIDs */ | ||||||
|  | @ -1077,7 +1145,6 @@ glAquaInitVisualConfigs(void) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // Copied from Mesa
 |  | ||||||
| static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | ||||||
|                                    void **privates) |                                    void **privates) | ||||||
| { | { | ||||||
|  | @ -1088,7 +1155,6 @@ static void glAquaSetVisualConfigs(int nconfigs, __GLXvisualConfig *configs, | ||||||
|     visualPrivates = privates; |     visualPrivates = privates; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Copied from Mesa
 |  | ||||||
| static Bool glAquaInitVisuals(VisualPtr *visualp, DepthPtr *depthp, | static Bool glAquaInitVisuals(VisualPtr *visualp, DepthPtr *depthp, | ||||||
|                               int *nvisualp, int *ndepthp, |                               int *nvisualp, int *ndepthp, | ||||||
|                               int *rootDepthp, VisualID *defaultVisp, |                               int *rootDepthp, VisualID *defaultVisp, | ||||||
|  | @ -1106,33 +1172,35 @@ static Bool glAquaInitVisuals(VisualPtr *visualp, DepthPtr *depthp, | ||||||
|                         *ndepthp, *depthp, *rootDepthp); |                         *ndepthp, *depthp, *rootDepthp); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| static void fixup_visuals(int screen) | static void fixup_visuals(int screen) | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = screenInfo.screens[screen]; |     ScreenPtr pScreen = screenInfo.screens[screen]; | ||||||
|     glAquaScreenRec *pScr = &glAquaScreens[screen]; |     glAquaScreenRec *pScr = &glAquaScreens[screen]; | ||||||
|     __GLXvisualConfig *pGLXVis  = pScr->glx_vis; |     int j; | ||||||
|     VisualPtr pVis; |     __GLcontextModes *modes; | ||||||
|     int i, j; |  | ||||||
| 
 | 
 | ||||||
|     GLAQUA_DEBUG_MSG("fixup_visuals\n"); |     GLAQUA_DEBUG_MSG("fixup_visuals\n"); | ||||||
| 
 | 
 | ||||||
|     for (i = 0; i < pScr->num_vis; i++, pGLXVis++) { |     for ( modes = pScr->modes ; modes != NULL ; modes = modes->next ) { | ||||||
| 	pVis = pScreen->visuals; |         const int vis_class = _gl_convert_to_x_visual_type( modes->visualType ); | ||||||
|  |         const int nplanes = (modes->rgbBits - modes->alphaBits); | ||||||
|  |         const VisualPtr pVis = pScreen->visuals; | ||||||
| 
 | 
 | ||||||
|         /* Find a visual that matches the GLX visual's class and size */ |         /* Find a visual that matches the GLX visual's class and size */ | ||||||
| 	for (j = 0; j < pScreen->numVisuals; j++, pVis++) { |         for (j = 0; j < pScreen->numVisuals; j++) { | ||||||
| 	    if (pVis->class == pGLXVis->class && |             if (pVis[j].class == vis_class && | ||||||
| 		pVis->nplanes == pGLXVis->bufferSize) { |             pVis[j].nplanes == nplanes) { | ||||||
| 
 | 
 | ||||||
|             /* Fixup the masks */ |             /* Fixup the masks */ | ||||||
| 		pGLXVis->redMask   = pVis->redMask; |             modes->redMask   = pVis[j].redMask; | ||||||
| 		pGLXVis->greenMask = pVis->greenMask; |             modes->greenMask = pVis[j].greenMask; | ||||||
| 		pGLXVis->blueMask  = pVis->blueMask; |             modes->blueMask  = pVis[j].blueMask; | ||||||
| 
 | 
 | ||||||
|             /* Recalc the sizes */ |             /* Recalc the sizes */ | ||||||
| 		pGLXVis->redSize   = count_bits(pGLXVis->redMask); |             modes->redBits   = count_bits(modes->redMask); | ||||||
| 		pGLXVis->greenSize = count_bits(pGLXVis->greenMask); |             modes->greenBits = count_bits(modes->greenMask); | ||||||
| 		pGLXVis->blueSize  = count_bits(pGLXVis->blueMask); |             modes->blueBits  = count_bits(modes->blueMask); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | @ -1141,69 +1209,60 @@ static void fixup_visuals(int screen) | ||||||
| static void init_screen_visuals(int screen) | static void init_screen_visuals(int screen) | ||||||
| { | { | ||||||
|     ScreenPtr pScreen = screenInfo.screens[screen]; |     ScreenPtr pScreen = screenInfo.screens[screen]; | ||||||
|     __GLXvisualConfig *pGLXVis = glAquaScreens[screen].glx_vis; |     __GLcontextModes *modes; | ||||||
|     // XMesaVisual *pXMesaVisual;
 |  | ||||||
|     VisualPtr pVis; |  | ||||||
|     int *used; |     int *used; | ||||||
|     int i, j; |     int i, j; | ||||||
| 
 | 
 | ||||||
|     GLAQUA_DEBUG_MSG("init_screen_visuals\n"); |     GLAQUA_DEBUG_MSG("init_screen_visuals\n"); | ||||||
| 
 | 
 | ||||||
|     /* Alloc space for the list of XMesa visuals */ |     /* FIXME: Change 'used' to be a array of bits (rather than of ints),
 | ||||||
|     // pXMesaVisual = (XMesaVisual *)__glXMalloc(MESAScreens[screen].num_vis *
 |      * FIXME: create a stack array of 8 or 16 bytes.  If 'numVisuals' is less | ||||||
|     //					      sizeof(XMesaVisual));
 |      * FIXME: than 64 or 128 the stack array can be used instead of calling | ||||||
|     // __glXMemset(pXMesaVisual, 0,
 |      * FIXME: __glXMalloc / __glXFree.  If nothing else, convert 'used' to | ||||||
|     //		MESAScreens[screen].num_vis * sizeof(XMesaVisual));
 |      * FIXME: array of bytes instead of ints! | ||||||
| 
 |      */ | ||||||
|     used = (int *)__glXMalloc(pScreen->numVisuals * sizeof(int)); |     used = (int *)__glXMalloc(pScreen->numVisuals * sizeof(int)); | ||||||
|     __glXMemset(used, 0, pScreen->numVisuals * sizeof(int)); |     __glXMemset(used, 0, pScreen->numVisuals * sizeof(int)); | ||||||
| 
 | 
 | ||||||
|     for (i = 0; i < glAquaScreens[screen].num_vis; i++, pGLXVis++) { |     i = 0; | ||||||
| 	pVis = pScreen->visuals; |     for ( modes = glAquaScreens[screen].modes  | ||||||
| 	for (j = 0; j < pScreen->numVisuals; j++, pVis++) { |           ; modes != NULL | ||||||
|  |           ; modes = modes->next ) { | ||||||
|  |         const int vis_class = _gl_convert_to_x_visual_type( modes->visualType ); | ||||||
|  |         const int nplanes = (modes->rgbBits - modes->alphaBits); | ||||||
|  |         const VisualPtr pVis = pScreen->visuals; | ||||||
| 
 | 
 | ||||||
| 	    if (pVis->class == pGLXVis->class && |         for (j = 0; j < pScreen->numVisuals; j++) { | ||||||
| 		pVis->nplanes == pGLXVis->bufferSize && |             if (pVis[j].class     == vis_class && | ||||||
|  |                 pVis[j].nplanes   == nplanes && | ||||||
|  |                 pVis[j].redMask   == modes->redMask && | ||||||
|  |                 pVis[j].greenMask == modes->greenMask && | ||||||
|  |                 pVis[j].blueMask  == modes->blueMask && | ||||||
|                 !used[j]) { |                 !used[j]) { | ||||||
| 
 | 
 | ||||||
| 		if (pVis->redMask   == pGLXVis->redMask && |  | ||||||
| 		    pVis->greenMask == pGLXVis->greenMask && |  | ||||||
| 		    pVis->blueMask  == pGLXVis->blueMask) { |  | ||||||
| 
 |  | ||||||
| 		    /* Create the XMesa visual */ |  | ||||||
| 		    /*
 |  | ||||||
| 		    pXMesaVisual[i] = |  | ||||||
|                          XMesaCreateVisual(pScreen, |  | ||||||
| 					   pVis, |  | ||||||
| 					   pGLXVis->rgba, |  | ||||||
| 					   (pGLXVis->alphaSize > 0), |  | ||||||
| 					   pGLXVis->doubleBuffer, |  | ||||||
| 					   pGLXVis->stereo, |  | ||||||
| 					   GL_TRUE, // ximage_flag
 |  | ||||||
| 					   pGLXVis->depthSize, |  | ||||||
| 					   pGLXVis->stencilSize, |  | ||||||
| 					   pGLXVis->accumRedSize, |  | ||||||
| 					   pGLXVis->accumGreenSize, |  | ||||||
| 					   pGLXVis->accumBlueSize, |  | ||||||
| 					   pGLXVis->accumAlphaSize, |  | ||||||
|                                            0,  // numSamples
 |  | ||||||
| 					   pGLXVis->level, |  | ||||||
|                                            pGLXVis->visualRating ); |  | ||||||
| 		    */ |  | ||||||
|                     /* Set the VisualID */ |                     /* Set the VisualID */ | ||||||
| 		    pGLXVis->vid = pVis->vid; |                     modes->visualID = pVis[j].vid; | ||||||
| 
 | 
 | ||||||
|                     /* Mark this visual used */ |                     /* Mark this visual used */ | ||||||
|                     used[j] = 1; |                     used[j] = 1; | ||||||
|                     break; |                     break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         if ( j == pScreen->numVisuals ) { | ||||||
|  |             ErrorF("No matching visual for __GLcontextMode with " | ||||||
|  |                    "visual class = %d (%d), nplanes = %u\n", | ||||||
|  |                    vis_class,  | ||||||
|  |                    (int)modes->visualType, | ||||||
|  |                    (unsigned int)(modes->rgbBits - modes->alphaBits) ); | ||||||
|         } |         } | ||||||
|  |         else if ( modes->visualID == -1 ) { | ||||||
|  |             FatalError( "Matching visual found, but visualID still -1!\n" ); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         i++; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     __glXFree(used); |     __glXFree(used); | ||||||
| 
 |  | ||||||
|     // glAquaScreens[screen].xm_vis = pXMesaVisual;
 |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static Bool glAquaScreenProbe(int screen) | static Bool glAquaScreenProbe(int screen) | ||||||
|  | @ -1216,7 +1275,7 @@ static Bool glAquaScreenProbe(int screen) | ||||||
|     /*
 |     /*
 | ||||||
|      * Set up the current screen's visuals. |      * Set up the current screen's visuals. | ||||||
|      */ |      */ | ||||||
|     __glDDXScreenInfo.pGlxVisual = glAquaScreens[screen].glx_vis; |     __glDDXScreenInfo.modes = glAquaScreens[screen].modes; | ||||||
|     __glDDXScreenInfo.pVisualPriv = glAquaScreens[screen].priv; |     __glDDXScreenInfo.pVisualPriv = glAquaScreens[screen].priv; | ||||||
|     __glDDXScreenInfo.numVisuals = |     __glDDXScreenInfo.numVisuals = | ||||||
|         __glDDXScreenInfo.numUsableVisuals = glAquaScreens[screen].num_vis; |         __glDDXScreenInfo.numUsableVisuals = glAquaScreens[screen].num_vis; | ||||||
|  | @ -1239,7 +1298,9 @@ static Bool glAquaScreenProbe(int screen) | ||||||
|      */ |      */ | ||||||
|     init_screen_visuals(screen); |     init_screen_visuals(screen); | ||||||
| 
 | 
 | ||||||
|     // Wrap RealizeWindow and UnrealizeWindow on this screen
 |     /*
 | ||||||
|  |      * Wrap RealizeWindow and UnrealizeWindow on this screen | ||||||
|  |      */ | ||||||
|     pScreen = screenInfo.screens[screen]; |     pScreen = screenInfo.screens[screen]; | ||||||
|     screenPriv = &glAquaScreens[screen]; |     screenPriv = &glAquaScreens[screen]; | ||||||
|     screenPriv->RealizeWindow = pScreen->RealizeWindow; |     screenPriv->RealizeWindow = pScreen->RealizeWindow; | ||||||
|  |  | ||||||
|  | @ -42,7 +42,7 @@ | ||||||
| #include "g_disptab.h" | #include "g_disptab.h" | ||||||
| #include "GL/glx_ansic.h" | #include "GL/glx_ansic.h" | ||||||
| 
 | 
 | ||||||
| #ifdef __CYGWIN__ /* should be XFree86Server */ | #if defined(__CYGWIN__) || defined(__DARWIN__) /* should be XFree86Server */ | ||||||
| #define xf86atof atof | #define xf86atof atof | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue