glxclient.h revision cb3610e37c4c0a40520441b8515d044dabcc8854
1cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
2cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** License Applicability. Except to the extent portions of this file are
3cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** made subject to an alternative license as permitted in the SGI Free
4cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Software License B, Version 1.1 (the "License"), the contents of this
5cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** file are subject only to the provisions of the License. You may not use
6cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** this file except in compliance with the License. You may obtain a copy
7cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600
8cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at:
9cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson**
10cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** http://oss.sgi.com/projects/FreeB
11cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson**
12cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Note that, as provided in the License, the Software is distributed on an
13cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS
14cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND
15cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A
16cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** PARTICULAR PURPOSE, AND NON-INFRINGEMENT.
17cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson**
18cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Original Code. The Original Code is: OpenGL Sample Implementation,
19cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics,
20cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.
21cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Copyright in any portions created by third parties is as indicated
22cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** elsewhere herein. All Rights Reserved.
23cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson**
24cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Additional Notice Provisions: The application programming interfaces
25cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** established by SGI in conjunction with the Original Code are The
26cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** OpenGL(R) Graphics System: A Specification (Version 1.2.1), released
27cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** April 1, 1999; The OpenGL(R) Graphics System Utility Library (Version
28cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** 1.3), released November 4, 1998; and OpenGL(R) Graphics with the X
29cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Window System(R) (Version 1.3), released October 19, 1998. This software
30cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** was created using the OpenGL(R) version 1.2.1 Sample Implementation
31cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** published by SGI, but has not been independently verified as being
32cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** compliant with the OpenGL(R) version 1.2.1 Specification.
33cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
34cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* $XFree86: xc/lib/GL/glx/glxclient.h,v 1.21 2004/02/09 23:46:31 alanh Exp $ */
35cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
36cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
37cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * \file glxclient.h
38cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * Direct rendering support added by Precision Insight, Inc.
39cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson *
40cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * \author Kevin E. Martin <kevin@precisioninsight.com>
41cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
42cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
43cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifndef _GLX_client_h_
44cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define _GLX_client_h_
45cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define NEED_REPLIES
46cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define NEED_EVENTS
47cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <X11/Xproto.h>
48cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <X11/Xlibint.h>
49cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define GLX_GLXEXT_PROTOTYPES
50cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <GL/glx.h>
51cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <GL/glxext.h>
52cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <string.h>
53cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <stdlib.h>
54cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <stdio.h>
55cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "GL/glxint.h"
56cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "GL/glxproto.h"
57cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "GL/internal/glcore.h"
58cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "glapitable.h"
59cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef NEED_GL_FUNCS_WRAPPED
60cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "indirect.h"
61cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
62cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef XTHREADS
63cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "Xthreads.h"
64cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
65cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_BUILT_IN_XMESA
66cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include "realglx.h"  /* just silences prototype warnings */
67cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
68cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
69cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define GLX_MAJOR_VERSION	1	/* current version numbers */
70cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define GLX_MINOR_VERSION	4
71cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
72cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __GLX_MAX_TEXTURE_UNITS 32
73cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
74cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXcontextRec __GLXcontext;
75cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXdisplayPrivateRec __GLXdisplayPrivate;
76cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct _glapi_table __GLapi;
77cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
78cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
79cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
80cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_DIRECT_RENDERING
81cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
82cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#include <GL/internal/dri_interface.h>
83cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
84cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef void *(*CreateScreenFunc)(Display *dpy, int scrn, __DRIscreen *psc,
85cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson                                  int numConfigs, __GLXvisualConfig *config);
86cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
87cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef void *(*CreateNewScreenFunc)(Display *dpy, int scrn, __DRIscreen *psc,
88cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const __GLcontextModes * modes, const __DRIversion * ddx_version,
89cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const __DRIversion * dri_version, const __DRIversion * drm_version,
90cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const __DRIframebuffer * frame_buffer, void * pSAREA,
91cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    int fd, int internal_api_version, __GLcontextModes ** driver_modes);
92cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
93cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
94cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
95cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * Display dependent methods.  This structure is initialized during the
96cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * \c driCreateDisplay call.
97cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
98cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonstruct __DRIdisplayRec {
99cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
100cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Method to destroy the private DRI display data.
101cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
102cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    void (*destroyDisplay)(Display *dpy, void *displayPrivate);
103cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
104cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
105cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Methods to create the private DRI screen data and initialize the
106cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * screen dependent methods.
107cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * This is an array [indexed by screen number] of function pointers.
108cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
109cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \deprecated  This array of function pointers has been replaced by
110cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *              \c __DRIdisplayRec::createNewScreen.
111cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \sa __DRIdisplayRec::createNewScreen
112cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
113cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    CreateScreenFunc * createScreen;
114cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
115cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
116cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Opaque pointer to private per display direct rendering data.
117cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c NULL if direct rendering is not supported on this display.
118cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
119cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    struct __DRIdisplayPrivateRec *private;
120cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
121cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
122cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Array of pointers to methods to create and initialize the private DRI
123cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * screen data.
124cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
125cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \sa __DRIdisplayRec::createScreen
126cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
127cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    CreateNewScreenFunc * createNewScreen;
128cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson};
129cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
130cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
131cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
132cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** We keep a linked list of these structures, one per DRI device driver.
133cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
134cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonstruct __DRIdriverRec {
135cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   const char *name;
136cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   void *handle;
137cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   CreateScreenFunc createScreenFunc;
138cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   CreateNewScreenFunc createNewScreenFunc;
139cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   struct __DRIdriverRec *next;
140cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson};
141cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
142cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
143cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Function to create and DRI display data and initialize the display
144cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** dependent methods.
145cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
146cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void *driCreateDisplay(Display *dpy, __DRIdisplay *pdisp);
147cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
148cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern  __DRIdriver *driGetDriver(Display *dpy, int scrNum);
149cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
150cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void DRI_glXUseXFont( Font font, int first, int count, int listbase );
151cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
152cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
153cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Functions to obtain driver configuration information from a direct
154cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** rendering client application
155cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
156cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern const char *glXGetScreenDriver (Display *dpy, int scrNum);
157cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
158cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern const char *glXGetDriverConfig (const char *driverName);
159cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
160cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
161cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
162cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
163cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
164cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __GL_CLIENT_ATTRIB_STACK_DEPTH 16
165cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
166cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXpixelStoreModeRec {
167cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean swapEndian;
168cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean lsbFirst;
169cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint rowLength;
170cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint imageHeight;
171cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint imageDepth;
172cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint skipRows;
173cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint skipPixels;
174cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint skipImages;
175cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint alignment;
176cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXpixelStoreMode;
177cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
178cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* The next 3 structures are deprecated.  Client state is no longer tracked
179cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * using them.  They only remain to maintain the layout / structure offset of
180cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * __GLXcontextRec.  In XFree86 5.0 they will be removed altogether.
181cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
182cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
183cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXvertexArrayPointerStateRecDEPRECATED {
184cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean enable;
185cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    void (*proc)(const void *);
186cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const GLubyte *ptr;
187cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLsizei skip;
188cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint size;
189cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLenum type;
190cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLsizei stride;
191cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXvertexArrayPointerStateDEPRECATED;
192cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
193cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXvertArrayStateRecDEPRECATED {
194cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED vertex;
195cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED normal;
196cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED color;
197cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED index;
198cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED texCoord[__GLX_MAX_TEXTURE_UNITS];
199cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerStateDEPRECATED edgeFlag;
200cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint maxElementsVertices;
201cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint maxElementsIndices;
202cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint activeTexture;
203cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXvertArrayStateDEPRECATED;
204cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
205cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXattributeRecDEPRECATED {
206cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	GLuint mask;
207cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
208cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	/*
209cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** Pixel storage state.  Most of the pixel store mode state is kept
210cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** here and used by the client code to manage the packing and
211cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** unpacking of data sent to/received from the server.
212cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	*/
213cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXpixelStoreMode storePack, storeUnpack;
214cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
215cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	/*
216cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** Vertex Array storage state.  The vertex array component
217cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** state is stored here and is used to manage the packing of
218cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** DrawArrays data sent to the server.
219cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	*/
220cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXvertArrayStateDEPRECATED vertArray;
221cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXattributeDEPRECATED;
222cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
223cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXvertexArrayPointerStateRec {
224cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    void (*proc)(const void *);
225cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    void (*mtex_proc)(GLenum, const void *);
226cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const GLubyte *ptr;
227cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLsizei skip;
228cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint size;
229cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLenum type;
230cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLsizei stride;
231cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXvertexArrayPointerState;
232cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
233cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
234cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * Define which entries of \c __GLXvertArrayState::arrays match which
235cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * vertex arrays in the client-state vector.  These are only the one-of
236cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * arrays.  See the \c __GLXvertArrayState::arrays documentation for more
237cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * details.
238cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson *
239cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * \sa __GLXvertArrayState
240cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
241cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonenum {
242cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    edgeFlag_ARRAY,       /**< \c GL_EDGE_FLAG_ARRAY */
243cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    index_ARRAY,          /**< \c GL_INDEX_ARRAY */
244cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    fogCoord_ARRAY,       /**< \c GL_FOG_COORD_ARRAY */
245cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    secondaryColor_ARRAY, /**< \c GL_SECONDARY_COLOR_ARRAY */
246cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    color_ARRAY,          /**< \c GL_COLOR_ARRAY */
247cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    normal_ARRAY,         /**< \c GL_NORMAL_ARRAY */
248cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
249cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
250cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c GL_VERTEX_ARRAY \b must be last!  All of the code for emitting arrays
251cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * and array elements is written based on the assumption that the vertex
252cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * array is last.
253cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
254cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    vertex_ARRAY,
255cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
256cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLX_MAX_ARRAYS      /**< Place holder entry. */
257cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson};
258cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
259cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define ENABLE_ARRAY(state,a) \
260cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    do { (state)->vertArray.enables |=  (1U << (a ## _ARRAY)); } while( 0 )
261cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define DISABLE_ARRAY(state,a) \
262cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    do { (state)->vertArray.enables &= ~(1U << (a ## _ARRAY)); } while( 0 )
263cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define IS_ARRAY_ENABLED_BY_INDEX(state, i) \
264cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    (((state)->vertArray.enables & (1U << (i))) != 0)
265cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define IS_ARRAY_ENABLED(state, a) \
266cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    IS_ARRAY_ENABLED_BY_INDEX(state, a ## _ARRAY)
267cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
268cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define ENABLE_TEXARRAY(state,a) \
269cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    do { (state)->vertArray.texture_enables |=  (1U << a); } while( 0 )
270cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define DISABLE_TEXARRAY(state,a) \
271cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    do { (state)->vertArray.texture_enables &= ~(1U << a); } while( 0 )
272cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define IS_TEXARRAY_ENABLED(state, a) \
273cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    (((state)->vertArray.texture_enables & (1U << a)) != 0)
274cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
275cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
276cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * Client-side vertex array state.
277cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
278cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXvertArrayStateRec {
279cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
280cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Which client-side arrays are enabled?  These are the flag bits for
281cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * all of the non-texture coordinate arrays.
282cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
283cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint enables;
284cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
285cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
286cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Which of the texture coordinate arrays are enabled?
287cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
288cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint texture_enables;
289cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
290cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
291cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * State for "one-of" arrays.  These are the arrays, such as
292cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GL_COLOR_ARRAY or GL_FOG_COORD_ARRAY for which there is only one
293cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * array.  There are also "many-of" arrays, such as
294cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GL_TEXTURE_COORD_ARRAY.
295cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
296cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerState arrays[__GLX_MAX_ARRAYS];
297cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
298cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvertexArrayPointerState texCoord[__GLX_MAX_TEXTURE_UNITS];
299cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
300cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint maxElementsVertices;
301cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint maxElementsIndices;
302cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint activeTexture;
303cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXvertArrayState;
304cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
305cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXattributeRec {
306cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	GLuint mask;
307cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
308cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	/*
309cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** Pixel storage state.  Most of the pixel store mode state is kept
310cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** here and used by the client code to manage the packing and
311cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** unpacking of data sent to/received from the server.
312cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	*/
313cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXpixelStoreMode storePack, storeUnpack;
314cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
315cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	/*
316cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** Vertex Array storage state.  The vertex array component
317cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** state is stored here and is used to manage the packing of
318cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	** DrawArrays data sent to the server.
319cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	*/
320cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXvertArrayState vertArray;
321cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
322cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	/**
323cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	 * Is EXT_vertex_array / GL 1.1 DrawArrays protocol specifically
324cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	 * disabled?
325cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	 */
326cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	GLboolean NoDrawArraysProtocol;
327cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXattribute;
328cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
329cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXattributeMachineRec {
330cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXattribute *stack[__GL_CLIENT_ATTRIB_STACK_DEPTH];
331cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	__GLXattribute **stackPointer;
332cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXattributeMachine;
333cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
334cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
335cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * GLX state that needs to be kept on the client.  One of these records
336cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * exist for each context that has been made current by this client.
337cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
338cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonstruct __GLXcontextRec {
339cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
340cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name Drawing command buffer.
341cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
342cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Drawing commands are packed into this buffer before being sent as a
343cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * single GLX protocol request.  The buffer is sent when it overflows or
344cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * is flushed by \c __glXFlushRenderBuffer.  \c pc is the next location
345cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * in the buffer to be filled.  \c limit is described above in the buffer
346cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * slop discussion.
347cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
348cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Commands that require large amounts of data to be transfered will
349cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * also use this buffer to hold a header that describes the large
350cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * command.
351cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
352cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * These must be the first 6 fields since they are static initialized
353cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * in the dummy context in glxext.c
354cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
355cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
356cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *buf;
357cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *pc;
358cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *limit;
359cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *bufEnd;
360cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint bufSize;
361cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
362cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
363cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
364cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The XID of this rendering context.  When the context is created a
365cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * new XID is allocated.  This is set to None when the context is
366cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * destroyed but is still current to some thread. In this case the
367cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * context will be freed on next MakeCurrent.
368cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
369cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    XID xid;
370cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
371cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
372cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The XID of the \c shareList context.
373cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
374cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    XID share_xid;
375cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
376cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
377cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Visual id.
378cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
379cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \deprecated
380cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * This filed has been largely been replaced by the \c mode field, but
381cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * the work is not quite done.
382cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
383cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    VisualID vid;
384cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
385cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
386cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Screen number.
387cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
388cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint screen;
389cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
390cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
391cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c GL_TRUE if the context was created with ImportContext, which
392cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * means the server-side context was created by another X client.
393cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
394cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean imported;
395cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
396cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
397cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The context tag returned by MakeCurrent when this context is made
398cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * current. This tag is used to identify the context that a thread has
399cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * current so that proper server context management can be done.  It is
400cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * used for all context specific commands (i.e., \c Render, \c RenderLarge,
401cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c WaitX, \c WaitGL, \c UseXFont, and \c MakeCurrent (for the old
402cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * context)).
403cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
404cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLXContextTag currentContextTag;
405cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
406cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
407cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name Rendering mode
408cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
409cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The rendering mode is kept on the client as well as the server.
410cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * When \c glRenderMode is called, the buffer associated with the
411cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * previous rendering mode (feedback or select) is filled.
412cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
413cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
414cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLenum renderMode;
415cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLfloat *feedbackBuf;
416cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLuint *selectBuf;
417cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
418cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
419cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
420cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * This is \c GL_TRUE if the pixel unpack modes are such that an image
421cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * can be unpacked from the clients memory by just copying.  It may
422cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * still be true that the server will have to do some work.  This
423cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * just promises that a straight copy will fetch the correct bytes.
424cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
425cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean fastImageUnpack;
426cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
427cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
428cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Fill newImage with the unpacked form of \c oldImage getting it
429cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * ready for transport to the server.
430cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
431cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    void (*fillImage)(__GLXcontext*, GLint, GLint, GLint, GLint, GLenum,
432cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson		      GLenum, const GLvoid*, GLubyte*, GLubyte*);
433cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
434cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
435cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name Client side attribs.
436cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
437cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
438cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXattributeDEPRECATED stateDEPRECATED;
439cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXattributeMachine attributes;
440cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
441cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
442cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
443cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Client side error code.  This is set when client side gl API
444cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * routines need to set an error because of a bad enumerant or
445cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * running out of memory, etc.
446cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
447cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLenum error;
448cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
449cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
450cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Whether this context does direct rendering.
451cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
452cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    Bool isDirect;
453cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
454cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
455cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c dpy of current display for this context.  Will be \c NULL if not
456cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * current to any display, or if this is the "dummy context".
457cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
458cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    Display *currentDpy;
459cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
460cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
461cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The current drawable for this context.  Will be None if this
462cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * context is not current to any drawable.  currentReadable is below.
463cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
464cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLXDrawable currentDrawable;
465cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
466cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
467cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name GL Constant Strings
468cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
469cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Constant strings that describe the server implementation
470cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * These pertain to GL attributes, not to be confused with
471cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GLX versioning attributes.
472cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
473cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
474cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *vendor;
475cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *renderer;
476cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *version;
477cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLubyte *extensions;
478cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
479cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
480cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
481cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Record the dpy this context was created on for later freeing
482cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
483cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    Display *createDpy;
484cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
485cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
486cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Maximum small render command size.  This is the smaller of 64k and
487cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * the size of the above buffer.
488cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
489cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint maxSmallRenderCommandSize;
490cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
491cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
492cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Major opcode for the extension.  Copied here so a lookup isn't
493cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * needed.
494cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
495cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLint majorOpcode;
496cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
497cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_DIRECT_RENDERING
498cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
499cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Per context direct rendering interface functions and data.
500cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
501cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __DRIcontext driContext;
502cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
503cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
504cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
505cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \c GLXFBConfigID used to create this context.  May be \c None.  This
506cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * field has been replaced by the \c mode field.
507cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
508cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \since Internal API version 20030317.
509cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
510cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \deprecated
511cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * This filed has been largely been replaced by the \c mode field, but
512cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * the work is not quite done.
513cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
514cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLXFBConfigID  fbconfigID;
515cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
516cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
517cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The current read-drawable for this context.  Will be None if this
518cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * context is not current to any drawable.
519cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
520cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \since Internal API version 20030606.
521cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
522cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLXDrawable currentReadable;
523cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
524cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   /**
525cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * Pointer to client-state data that is private to libGL.  This is only
526cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * used for indirect rendering contexts.
527cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    *
528cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * No internal API version change was made for this change.  Client-side
529cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * drivers should NEVER use this data or even care that it exists.
530cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    */
531cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   void * client_state_private;
532cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
533cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   /**
534cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * Stored value for \c glXQueryContext attribute \c GLX_RENDER_TYPE.
535cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    */
536cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   int renderType;
537cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
538cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   /**
539cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * \name Raw server GL version
540cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    *
541cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * True core GL version supported by the server.  This is the raw value
542cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * returned by the server, and it may not reflect what is actually
543cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    * supported (or reported) by the client-side library.
544cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    */
545cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
546cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   int server_major;        /**< Major version number. */
547cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson   int server_minor;        /**< Minor version number. */
548cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
549cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson};
550cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
551cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXSetError(gc,code) \
552cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    if (!(gc)->error) {	       \
553cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson	(gc)->error = code;    \
554cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    }
555cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
556cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFreeAttributeState(__GLXcontext *);
557cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
558cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
559cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
560cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
561cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * The size of the largest drawing command known to the implementation
562cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * that will use the GLXRender GLX command.  In this case it is
563cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * \c glPolygonStipple.
564cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
565cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __GLX_MAX_SMALL_RENDER_CMD_SIZE	156
566cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
567cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
568cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * To keep the implementation fast, the code uses a "limit" pointer
569cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * to determine when the drawing command buffer is too full to hold
570cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * another fixed size command.  This constant defines the amount of
571cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * space that must always be available in the drawing command buffer
572cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * at all times for the implementation to work.  It is important that
573cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * the number be just large enough, but not so large as to reduce the
574cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * efficacy of the buffer.  The "+32" is just to keep the code working
575cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * in case somebody counts wrong.
576cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
577cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __GLX_BUFFER_LIMIT_SIZE	(__GLX_MAX_SMALL_RENDER_CMD_SIZE + 32)
578cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
579cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
580cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * This implementation uses a smaller threshold for switching
581cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * to the RenderLarge protocol than the protcol requires so that
582cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * large copies don't occur.
583cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
584cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __GLX_RENDER_CMD_SIZE_LIMIT	4096
585cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
586cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
587cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * One of these records exists per screen of the display.  It contains
588cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * a pointer to the config data for that screen (if the screen supports GL).
589cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
590cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksontypedef struct __GLXscreenConfigsRec {
591cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
592cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GLX visuals formated as \c __GLXvisualConfig structures.
593cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
594cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
595cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXvisualConfig * old_configs;
596cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    int numOldConfigs;
597cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
598cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
599cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
600cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GLX extension string reported by the X-server.
601cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
602cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const char *serverGLXexts;
603cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
604cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
605cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * GLX extension string to be reported to applications.  This is the
606cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * set of extensions that the application can actually use.
607cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
608cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    char *effectiveGLXexts;
609cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
610cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_DIRECT_RENDERING
611cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
612cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Per screen direct rendering interface functions and data.
613cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
614cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __DRIscreen driScreen;
615cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
616cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
617cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
618cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Linked list of configurations for this screen.  This is intended to
619cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * be a superset of \c old_configs.
620cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
621cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLcontextModes *configs;
622cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
623cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Per-screen dynamic GLX extension tracking.  The \c direct_support
624cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * field only contains enough bits for 64 extensions.  Should libGL
625cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * ever need to track more than 64 GLX extensions, we can safely grow
626cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * this field.  The \c __GLXscreenConfigs structure is not used outside
627cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * libGL.
628cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
629cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
630cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    unsigned char direct_support[8];
631cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    GLboolean ext_list_first_time;
632cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
633cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
634cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson} __GLXscreenConfigs;
635cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
636cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/**
637cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * Per display private data.  One of these records exists for each display
638cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson * that is using the OpenGL (GLX) extension.
639cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson */
640cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonstruct __GLXdisplayPrivateRec {
641cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
642cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Back pointer to the display
643cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
644cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    Display *dpy;
645cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
646cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
647cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * The \c majorOpcode is common to all connections to the same server.
648cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * It is also copied into the context structure.
649cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
650cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    int majorOpcode;
651cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
652cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
653cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name Server Version
654cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
655cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Major and minor version returned by the server during initialization.
656cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
657cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
658cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    int majorVersion, minorVersion;
659cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
660cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
661cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
662cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * \name Storage for the servers GLX vendor and versions strings.
663cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     *
664cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * These are the same for all screens on this display. These fields will
665cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * be filled in on demand.
666cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
667cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@{*/
668cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const char *serverGLXvendor;
669cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    const char *serverGLXversion;
670cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /*@}*/
671cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
672cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
673cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Configurations of visuals for all screens on this display.
674cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Also, per screen data which now includes the server \c GLX_EXTENSION
675cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * string.
676cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
677cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __GLXscreenConfigs *screenConfigs;
678cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
679cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_DIRECT_RENDERING
680cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    /**
681cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     * Per display direct rendering interface functions and data.
682cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson     */
683cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    __DRIdisplay driDisplay;
684cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
685cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson};
686cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
687cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonvoid __glXFreeContext(__GLXcontext*);
688cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
689cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern GLubyte *__glXFlushRenderBuffer(__GLXcontext*, GLubyte*);
690cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
691cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXSendLargeChunk(__GLXcontext *gc, GLint requestNumber,
692cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson				GLint totalRequests,
693cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson				const GLvoid * data, GLint dataLen);
694cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
695cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXSendLargeCommand(__GLXcontext *, const GLvoid *, GLint,
696cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson				  const GLvoid *, GLint);
697cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
698cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Initialize the GLX extension for dpy */
699cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern __GLXdisplayPrivate *__glXInitialize(Display*);
700cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
701cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
702cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
703cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern int __glXDebug;
704cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
705cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* This is per-thread storage in an MT environment */
706cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#if defined(GLX_DIRECT_RENDERING) && defined(XTHREADS)
707cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern __GLXcontext *__glXGetCurrentContext(void);
708cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXSetCurrentContext(__GLXcontext *c);
709cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#else
710cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern __GLXcontext *__glXcurrentContext;
711cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXGetCurrentContext()	__glXcurrentContext
712cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXSetCurrentContext(gc)	__glXcurrentContext = gc
713cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
714cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
715cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
716cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
717cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Global lock for all threads in this address space using the GLX
718cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** extension
719cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
720cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#if defined(GLX_DIRECT_RENDERING) && defined(XTHREADS)
721cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern xmutex_rec __glXmutex;
722cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXLock()    xmutex_lock(&__glXmutex)
723cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXUnlock()  xmutex_unlock(&__glXmutex)
724cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#else
725cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXLock()
726cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define __glXUnlock()
727cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
728cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
729cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
730cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Setup for a command.  Initialize the extension for dpy if necessary.
731cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
732cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern CARD8 __glXSetupForCommand(Display *dpy);
733cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
734cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
735cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
736cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
737cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Data conversion and packing support.
738cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
739cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
740cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Return the size, in bytes, of some pixel data */
741cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern GLint __glImageSize(GLint, GLint, GLint, GLenum, GLenum);
742cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
743cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Return the number of elements per group of a specified format*/
744cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern GLint __glElementsPerGroup(GLenum format, GLenum type);
745cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
746cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Return the number of bytes per element, based on the element type (other
747cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** than GL_BITMAP).
748cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
749cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern GLint __glBytesPerElement(GLenum type);
750cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
751cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Return the k value for a given map target */
752cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern GLint __glEvalComputeK(GLenum);
753cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
754cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
755cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Fill the transport buffer with the data from the users buffer,
756cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** applying some of the pixel store modes (unpack modes) to the data
757cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** first.  As a side effect of this call, the "modes" field is
758cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** updated to contain the modes needed by the server to decode the
759cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** sent data.
760cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
761cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFillImage(__GLXcontext*, GLint, GLint, GLint, GLint, GLenum,
762cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson			  GLenum, const GLvoid*, GLubyte*, GLubyte*);
763cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
764cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Copy map data with a stride into a packed buffer */
765cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFillMap1f(GLint, GLint, GLint, const GLfloat *, GLubyte *);
766cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFillMap1d(GLint, GLint, GLint, const GLdouble *, GLubyte *);
767cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFillMap2f(GLint, GLint, GLint, GLint, GLint,
768cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson			  const GLfloat *, GLfloat *);
769cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glFillMap2d(GLint, GLint, GLint, GLint, GLint,
770cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson			  const GLdouble *, GLdouble *);
771cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
772cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
773cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Empty an image out of the reply buffer into the clients memory applying
774cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** the pack modes to pack back into the clients requested format.
775cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
776cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glEmptyImage(__GLXcontext*, GLint, GLint, GLint, GLint, GLenum,
777cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson		           GLenum, const GLubyte *, GLvoid *);
778cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
779cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
780cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
781cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Allocate and Initialize Vertex Array client state
782cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
783cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXInitVertexArrayState(__GLXcontext*);
784cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
785cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
786cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Inform the Server of the major and minor numbers and of the client
787cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** libraries extension string.
788cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
789cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXClientInfo (  Display *dpy, int opcode );
790cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
791cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/************************************************************************/
792cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
793cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
794cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Declarations that should be in Xlib
795cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
796cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef __GL_USE_OUR_PROTOTYPES
797cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void _XFlush(Display*);
798cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern Status _XReply(Display*, xReply*, int, Bool);
799cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void _XRead(Display*, void*, long);
800cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void _XSend(Display*, const void*, long);
801cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
802cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
803cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
804cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/*
805cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** GLX_BUILT_IN_XMESA controls whether libGL has a built-in verions of
806cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson** Mesa that can render to non-GLX displays.
807cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson*/
808cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#ifdef GLX_BUILT_IN_XMESA
809cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define GLX_PREFIX(function)  _real_##function
810cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#else
811cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#define GLX_PREFIX(function)  function
812cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif
813cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
814cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
815cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern void __glXInitializeVisualConfigFromTags( __GLcontextModes *config,
816cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    int count, const INT32 *bp, Bool tagged_only, Bool fbconfig_style_tags );
817cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
818cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern char * __glXGetStringFromServer( Display * dpy, int opcode,
819cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson    CARD32 glxCode, CARD32 for_whom, CARD32 name );
820cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
821cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern char *__glXstrdup(const char *str);
822cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
823cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
824cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern const char __glXGLClientVersion[];
825cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern const char __glXGLClientExtensions[];
826cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
827cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Determine the internal API version */
828cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern int __glXGetInternalVersion(void);
829cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
830cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson/* Get the unadjusted system time */
831cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jacksonextern int __glXGetUST( int64_t * ust );
832cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson
833cb3610e37c4c0a40520441b8515d044dabcc8854Adam Jackson#endif /* !__GLX_client_h__ */
834