blob: 9705fd8a988297e69902ca7ef093022b1a94b116 [file] [log] [blame]
jtgafb833d1999-08-19 00:55:39 +00001/*
2 * Mesa 3-D graphics library
Brian Paule9b34882008-12-31 11:54:02 -07003 * Version: 7.3
jtgafb833d1999-08-19 00:55:39 +00004 *
Brian145d7622007-08-16 10:05:00 +01005 * Copyright (C) 1999-2007 Brian Paul All Rights Reserved.
Brian Paule9b34882008-12-31 11:54:02 -07006 * Copyright (C) 2008 VMware, Inc. All Rights Reserved.
jtgafb833d1999-08-19 00:55:39 +00007 *
8 * Permission is hereby granted, free of charge, to any person obtaining a
9 * copy of this software and associated documentation files (the "Software"),
10 * to deal in the Software without restriction, including without limitation
11 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
12 * and/or sell copies of the Software, and to permit persons to whom the
13 * Software is furnished to do so, subject to the following conditions:
14 *
15 * The above copyright notice and this permission notice shall be included
16 * in all copies or substantial portions of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
21 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
22 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
23 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24 */
25
Brian Paule9b34882008-12-31 11:54:02 -070026/**
27 * \file context.c
28 * Mesa context/visual/framebuffer management functions.
29 * \author Brian Paul
30 */
jtgafb833d1999-08-19 00:55:39 +000031
Keith Whitwell6dc85572003-07-17 13:43:59 +000032/**
Brian Paul253204f2004-09-10 00:45:12 +000033 * \mainpage Mesa Main Module
Keith Whitwell6dc85572003-07-17 13:43:59 +000034 *
Brian Paul253204f2004-09-10 00:45:12 +000035 * \section MainIntroduction Introduction
Keith Whitwell6dc85572003-07-17 13:43:59 +000036 *
Brian Paul253204f2004-09-10 00:45:12 +000037 * The Mesa Main module consists of all the files in the main/ directory.
38 * Among the features of this module are:
39 * <UL>
40 * <LI> Structures to represent most GL state </LI>
41 * <LI> State set/get functions </LI>
42 * <LI> Display lists </LI>
43 * <LI> Texture unit, object and image handling </LI>
44 * <LI> Matrix and attribute stacks </LI>
45 * </UL>
Keith Whitwell6dc85572003-07-17 13:43:59 +000046 *
Brian Paul253204f2004-09-10 00:45:12 +000047 * Other modules are responsible for API dispatch, vertex transformation,
48 * point/line/triangle setup, rasterization, vertex array caching,
49 * vertex/fragment programs/shaders, etc.
Keith Whitwell6dc85572003-07-17 13:43:59 +000050 *
51 *
52 * \section AboutDoxygen About Doxygen
53 *
54 * If you're viewing this information as Doxygen-generated HTML you'll
55 * see the documentation index at the top of this page.
56 *
57 * The first line lists the Mesa source code modules.
58 * The second line lists the indexes available for viewing the documentation
59 * for each module.
60 *
61 * Selecting the <b>Main page</b> link will display a summary of the module
62 * (this page).
63 *
Jose Fonseca1a5709d2003-09-17 17:14:11 +000064 * Selecting <b>Data Structures</b> will list all C structures.
Keith Whitwell6dc85572003-07-17 13:43:59 +000065 *
66 * Selecting the <b>File List</b> link will list all the source files in
67 * the module.
68 * Selecting a filename will show a list of all functions defined in that file.
69 *
Jose Fonseca1a5709d2003-09-17 17:14:11 +000070 * Selecting the <b>Data Fields</b> link will display a list of all
Keith Whitwell6dc85572003-07-17 13:43:59 +000071 * documented structure members.
72 *
Jose Fonseca1a5709d2003-09-17 17:14:11 +000073 * Selecting the <b>Globals</b> link will display a list
Keith Whitwell6dc85572003-07-17 13:43:59 +000074 * of all functions, structures, global variables and macros in the module.
75 *
76 */
77
78
Brian Paulfbd8f211999-11-11 01:22:25 +000079#include "glheader.h"
Brian Paul3c634522002-10-24 23:57:19 +000080#include "imports.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070081#if FEATURE_accum
Keith Whitwell6dc85572003-07-17 13:43:59 +000082#include "accum.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070083#endif
Brian Paulc9e56712008-06-09 14:49:04 -060084#include "api_exec.h"
Brian Paulc04bb512006-07-11 21:56:43 +000085#include "arrayobj.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070086#if FEATURE_attrib_stack
Keith Whitwell6dc85572003-07-17 13:43:59 +000087#include "attrib.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070088#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +000089#include "blend.h"
Brian Paulb1394fa2000-09-26 20:53:53 +000090#include "buffers.h"
Brian Paul148a2842003-09-17 03:40:11 +000091#include "bufferobj.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070092#if FEATURE_colortable
Brian Paul4bdcfe52000-04-17 17:57:04 +000093#include "colortab.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070094#endif
jtgafb833d1999-08-19 00:55:39 +000095#include "context.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +000096#include "debug.h"
97#include "depth.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -070098#if FEATURE_dlist
jtgafb833d1999-08-19 00:55:39 +000099#include "dlist.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700100#endif
101#if FEATURE_evaluators
jtgafb833d1999-08-19 00:55:39 +0000102#include "eval.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700103#endif
jtgafb833d1999-08-19 00:55:39 +0000104#include "enums.h"
Brian Paul585a68c1999-09-11 11:31:34 +0000105#include "extensions.h"
Brian Paule4b23562005-05-04 20:11:35 +0000106#include "fbobject.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700107#if FEATURE_feedback
Keith Whitwell6dc85572003-07-17 13:43:59 +0000108#include "feedback.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700109#endif
jtgafb833d1999-08-19 00:55:39 +0000110#include "fog.h"
Briane6a93812007-02-26 11:37:37 -0700111#include "framebuffer.h"
Brian Paulb7a43041999-11-30 20:34:51 +0000112#include "get.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700113#if FEATURE_histogram
Keith Whitwell6dc85572003-07-17 13:43:59 +0000114#include "histogram.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700115#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +0000116#include "hint.h"
jtgafb833d1999-08-19 00:55:39 +0000117#include "hash.h"
118#include "light.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +0000119#include "lines.h"
jtgafb833d1999-08-19 00:55:39 +0000120#include "macros.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +0000121#include "matrix.h"
Brian Paulc132e2b2008-06-09 15:09:21 -0600122#include "multisample.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +0000123#include "pixel.h"
Brian Paul533c1db2008-06-09 14:25:23 -0600124#include "pixelstore.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +0000125#include "points.h"
126#include "polygon.h"
Brian Paul4e3ae762008-06-13 13:56:53 -0600127#if FEATURE_ARB_occlusion_query
Brian74afcab2007-04-21 12:42:54 -0600128#include "queryobj.h"
Brian Paul4e3ae762008-06-13 13:56:53 -0600129#endif
Keith Whitwell34a61c62008-09-21 19:29:15 -0700130#if FEATURE_drawpix
Keith Whitwell6dc85572003-07-17 13:43:59 +0000131#include "rastpos.h"
Keith Whitwell34a61c62008-09-21 19:29:15 -0700132#endif
Brian Paul55e341c2008-06-09 14:55:24 -0600133#include "scissor.h"
jtgafb833d1999-08-19 00:55:39 +0000134#include "simple_list.h"
Brian Paulfa9df402000-02-02 19:16:46 +0000135#include "state.h"
Keith Whitwell6dc85572003-07-17 13:43:59 +0000136#include "stencil.h"
Brian Paul8f04c122004-04-27 13:39:20 +0000137#include "texcompress.h"
jtgafb833d1999-08-19 00:55:39 +0000138#include "teximage.h"
139#include "texobj.h"
Brian Paul85d81602002-06-17 23:36:31 +0000140#include "texstate.h"
Jouk Jansen5e3bc0c2000-11-22 07:32:16 +0000141#include "mtypes.h"
jtgafb833d1999-08-19 00:55:39 +0000142#include "varray.h"
Brian Paul363344f2005-09-13 14:48:28 +0000143#include "version.h"
Gareth Hughesd4eb6652001-03-12 01:32:20 +0000144#include "vtxfmt.h"
Brianc223c6b2007-07-04 13:15:20 -0600145#include "glapi/glthread.h"
Brian Paul2dbc5152008-06-13 16:45:15 -0600146#include "glapi/glapioffsets.h"
147#include "glapi/glapitable.h"
Brianc223c6b2007-07-04 13:15:20 -0600148#include "shader/program.h"
Brianc223c6b2007-07-04 13:15:20 -0600149#include "shader/shader_api.h"
Brian Paulb51d73d2008-06-20 08:07:38 -0600150#if FEATURE_ATI_fragment_shader
Brianc223c6b2007-07-04 13:15:20 -0600151#include "shader/atifragshader.h"
Brian Paulb51d73d2008-06-20 08:07:38 -0600152#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +0000153#if _HAVE_FULL_GL
Keith Whitwell23caf202000-11-16 21:05:34 +0000154#include "math/m_matrix.h"
Brian Paulddc82ee2005-02-05 19:56:45 +0000155#endif
jtgafb833d1999-08-19 00:55:39 +0000156
davem69775355a2001-06-05 23:54:00 +0000157#ifdef USE_SPARC_ASM
Ian Romanicke16f6e32004-06-26 00:02:51 +0000158#include "sparc/sparc.h"
davem69775355a2001-06-05 23:54:00 +0000159#endif
jtgafb833d1999-08-19 00:55:39 +0000160
Keith Whitwell23caf202000-11-16 21:05:34 +0000161#ifndef MESA_VERBOSE
Keith Whitwell306d3fc2002-04-09 16:56:50 +0000162int MESA_VERBOSE = 0;
Keith Whitwell23caf202000-11-16 21:05:34 +0000163#endif
164
165#ifndef MESA_DEBUG_FLAGS
Keith Whitwell306d3fc2002-04-09 16:56:50 +0000166int MESA_DEBUG_FLAGS = 0;
Keith Whitwell23caf202000-11-16 21:05:34 +0000167#endif
Brian Paulb1394fa2000-09-26 20:53:53 +0000168
Brian Paul86b84272001-12-14 02:50:01 +0000169
Brian Paul27558a12003-03-01 01:50:20 +0000170/* ubyte -> float conversion */
171GLfloat _mesa_ubyte_to_float_color_tab[256];
172
Brian Paul9a33a112002-06-13 04:28:29 +0000173
Brian Paul86b84272001-12-14 02:50:01 +0000174
Keith Whitwell6dc85572003-07-17 13:43:59 +0000175/**
176 * Swap buffers notification callback.
177 *
178 * \param gc GL context.
179 *
180 * Called by window system just before swapping buffers.
Brian Paul9a33a112002-06-13 04:28:29 +0000181 * We have to finish any pending rendering.
182 */
183void
Brian96b06ac2007-10-19 10:12:00 -0600184_mesa_notifySwapBuffers(__GLcontext *ctx)
Brian Paul9a33a112002-06-13 04:28:29 +0000185{
Brian Paule8cd8be2009-02-12 08:58:12 -0700186 FLUSH_VERTICES( ctx, 0 );
Brian96b06ac2007-10-19 10:12:00 -0600187 if (ctx->Driver.Flush) {
188 ctx->Driver.Flush(ctx);
189 }
Brian Paul9a33a112002-06-13 04:28:29 +0000190}
191
Brian Paulb1394fa2000-09-26 20:53:53 +0000192
jtgafb833d1999-08-19 00:55:39 +0000193/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +0000194/** \name GL Visual allocation/destruction */
Brian Paul4d053dd2000-01-14 04:45:47 +0000195/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +0000196/*@{*/
Brian Paul4d053dd2000-01-14 04:45:47 +0000197
Keith Whitwell6dc85572003-07-17 13:43:59 +0000198/**
Brian Paul894844a2004-03-21 17:05:03 +0000199 * Allocates a GLvisual structure and initializes it via
200 * _mesa_initialize_visual().
Keith Whitwell6dc85572003-07-17 13:43:59 +0000201 *
202 * \param rgbFlag GL_TRUE for RGB(A) mode, GL_FALSE for Color Index mode.
203 * \param dbFlag double buffering
204 * \param stereoFlag stereo buffer
205 * \param depthBits requested bits per depth buffer value. Any value in [0, 32]
206 * is acceptable but the actual depth type will be GLushort or GLuint as
207 * needed.
208 * \param stencilBits requested minimum bits per stencil buffer value
209 * \param accumRedBits, accumGreenBits, accumBlueBits, accumAlphaBits number of bits per color component in accum buffer.
210 * \param indexBits number of bits per pixel if \p rgbFlag is GL_FALSE
211 * \param redBits number of bits per color component in frame buffer for RGB(A)
212 * mode. We always use 8 in core Mesa though.
213 * \param greenBits same as above.
214 * \param blueBits same as above.
215 * \param alphaBits same as above.
216 * \param numSamples not really used.
217 *
218 * \return pointer to new GLvisual or NULL if requested parameters can't be
219 * met.
220 *
Brian Paul894844a2004-03-21 17:05:03 +0000221 * \note Need to add params for level and numAuxBuffers (at least)
Brian Paul4d053dd2000-01-14 04:45:47 +0000222 */
Brian Paulb371e0d2000-03-31 01:05:51 +0000223GLvisual *
224_mesa_create_visual( GLboolean rgbFlag,
Brian Paulb371e0d2000-03-31 01:05:51 +0000225 GLboolean dbFlag,
226 GLboolean stereoFlag,
227 GLint redBits,
228 GLint greenBits,
229 GLint blueBits,
230 GLint alphaBits,
231 GLint indexBits,
232 GLint depthBits,
233 GLint stencilBits,
234 GLint accumRedBits,
235 GLint accumGreenBits,
236 GLint accumBlueBits,
237 GLint accumAlphaBits,
238 GLint numSamples )
Brian Paul4d053dd2000-01-14 04:45:47 +0000239{
Brian Paulc7e164f2006-06-30 15:44:30 +0000240 GLvisual *vis = (GLvisual *) _mesa_calloc(sizeof(GLvisual));
Brian Paul178a1c52000-04-22 01:05:00 +0000241 if (vis) {
Brian Paule70c6232000-05-04 13:53:55 +0000242 if (!_mesa_initialize_visual(vis, rgbFlag, dbFlag, stereoFlag,
Brian Paul178a1c52000-04-22 01:05:00 +0000243 redBits, greenBits, blueBits, alphaBits,
244 indexBits, depthBits, stencilBits,
245 accumRedBits, accumGreenBits,
246 accumBlueBits, accumAlphaBits,
Brian Paulb1394fa2000-09-26 20:53:53 +0000247 numSamples)) {
Brian Paulc7e164f2006-06-30 15:44:30 +0000248 _mesa_free(vis);
Brian Paul178a1c52000-04-22 01:05:00 +0000249 return NULL;
250 }
251 }
252 return vis;
253}
254
Keith Whitwell6dc85572003-07-17 13:43:59 +0000255/**
Brian Paul894844a2004-03-21 17:05:03 +0000256 * Makes some sanity checks and fills in the fields of the
Brian Paule4b23562005-05-04 20:11:35 +0000257 * GLvisual object with the given parameters. If the caller needs
258 * to set additional fields, he should just probably init the whole GLvisual
259 * object himself.
Keith Whitwell6dc85572003-07-17 13:43:59 +0000260 * \return GL_TRUE on success, or GL_FALSE on failure.
261 *
262 * \sa _mesa_create_visual() above for the parameter description.
Brian Paul178a1c52000-04-22 01:05:00 +0000263 */
264GLboolean
265_mesa_initialize_visual( GLvisual *vis,
266 GLboolean rgbFlag,
Brian Paul178a1c52000-04-22 01:05:00 +0000267 GLboolean dbFlag,
268 GLboolean stereoFlag,
269 GLint redBits,
270 GLint greenBits,
271 GLint blueBits,
272 GLint alphaBits,
273 GLint indexBits,
274 GLint depthBits,
275 GLint stencilBits,
276 GLint accumRedBits,
277 GLint accumGreenBits,
278 GLint accumBlueBits,
279 GLint accumAlphaBits,
280 GLint numSamples )
281{
282 assert(vis);
Brian Paul4d053dd2000-01-14 04:45:47 +0000283
Brian Pauled30dfa2000-03-03 17:47:39 +0000284 if (depthBits < 0 || depthBits > 32) {
Brian Paul178a1c52000-04-22 01:05:00 +0000285 return GL_FALSE;
Brian Paul4d053dd2000-01-14 04:45:47 +0000286 }
Brian Paule4b23562005-05-04 20:11:35 +0000287 if (stencilBits < 0 || stencilBits > STENCIL_BITS) {
Brian Paul178a1c52000-04-22 01:05:00 +0000288 return GL_FALSE;
Brian Paul4d053dd2000-01-14 04:45:47 +0000289 }
Brian Paul978ef2b2005-09-21 03:35:08 +0000290 assert(accumRedBits >= 0);
291 assert(accumGreenBits >= 0);
292 assert(accumBlueBits >= 0);
293 assert(accumAlphaBits >= 0);
Brian Paul4d053dd2000-01-14 04:45:47 +0000294
Brian Paulb6bcae52001-01-23 23:39:36 +0000295 vis->rgbMode = rgbFlag;
296 vis->doubleBufferMode = dbFlag;
297 vis->stereoMode = stereoFlag;
Brian Paul153f1542002-10-29 15:04:35 +0000298
Brian Paulb6bcae52001-01-23 23:39:36 +0000299 vis->redBits = redBits;
300 vis->greenBits = greenBits;
301 vis->blueBits = blueBits;
302 vis->alphaBits = alphaBits;
Brian Paule4b23562005-05-04 20:11:35 +0000303 vis->rgbBits = redBits + greenBits + blueBits;
Brian Paul4d053dd2000-01-14 04:45:47 +0000304
Brian Paulb6bcae52001-01-23 23:39:36 +0000305 vis->indexBits = indexBits;
306 vis->depthBits = depthBits;
Brian Paule4b23562005-05-04 20:11:35 +0000307 vis->stencilBits = stencilBits;
308
309 vis->accumRedBits = accumRedBits;
310 vis->accumGreenBits = accumGreenBits;
311 vis->accumBlueBits = accumBlueBits;
312 vis->accumAlphaBits = accumAlphaBits;
Brian Pauled30dfa2000-03-03 17:47:39 +0000313
Brian Paul153f1542002-10-29 15:04:35 +0000314 vis->haveAccumBuffer = accumRedBits > 0;
315 vis->haveDepthBuffer = depthBits > 0;
316 vis->haveStencilBuffer = stencilBits > 0;
317
318 vis->numAuxBuffers = 0;
319 vis->level = 0;
320 vis->pixmapMode = 0;
Brian Paule4b23562005-05-04 20:11:35 +0000321 vis->sampleBuffers = numSamples > 0 ? 1 : 0;
Brian Paul894844a2004-03-21 17:05:03 +0000322 vis->samples = numSamples;
Brian Paul153f1542002-10-29 15:04:35 +0000323
Brian Paul178a1c52000-04-22 01:05:00 +0000324 return GL_TRUE;
Brian Paul4d053dd2000-01-14 04:45:47 +0000325}
326
Brian Paul894844a2004-03-21 17:05:03 +0000327
Keith Whitwell6dc85572003-07-17 13:43:59 +0000328/**
Brian Paul894844a2004-03-21 17:05:03 +0000329 * Destroy a visual and free its memory.
Keith Whitwell6dc85572003-07-17 13:43:59 +0000330 *
331 * \param vis visual.
332 *
333 * Frees the visual structure.
334 */
Brian Paulb371e0d2000-03-31 01:05:51 +0000335void
336_mesa_destroy_visual( GLvisual *vis )
337{
Brian Paulc7e164f2006-06-30 15:44:30 +0000338 _mesa_free(vis);
Brian Paulb371e0d2000-03-31 01:05:51 +0000339}
340
Keith Whitwell6dc85572003-07-17 13:43:59 +0000341/*@}*/
342
Brian Paulb371e0d2000-03-31 01:05:51 +0000343
Brian Paul4d053dd2000-01-14 04:45:47 +0000344/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +0000345/** \name Context allocation, initialization, destroying
346 *
347 * The purpose of the most initialization functions here is to provide the
348 * default state values according to the OpenGL specification.
349 */
jtgafb833d1999-08-19 00:55:39 +0000350/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +0000351/*@{*/
jtgafb833d1999-08-19 00:55:39 +0000352
Keith Whitwell6dc85572003-07-17 13:43:59 +0000353/**
354 * One-time initialization mutex lock.
355 *
356 * \sa Used by one_time_init().
357 */
Brian Paul9560f052000-01-31 23:11:39 +0000358_glthread_DECLARE_STATIC_MUTEX(OneTimeLock);
359
Keith Whitwell6dc85572003-07-17 13:43:59 +0000360/**
361 * Calls all the various one-time-init functions in Mesa.
362 *
363 * While holding a global mutex lock, calls several initialization functions,
364 * and sets the glapi callbacks if the \c MESA_DEBUG environment variable is
365 * defined.
366 *
Brian Paula764b7e2006-02-26 17:16:37 +0000367 * \sa _math_init().
jtgafb833d1999-08-19 00:55:39 +0000368 */
Brian Paul178a1c52000-04-22 01:05:00 +0000369static void
Brian Paul4753d602002-06-15 02:38:15 +0000370one_time_init( GLcontext *ctx )
jtgafb833d1999-08-19 00:55:39 +0000371{
372 static GLboolean alreadyCalled = GL_FALSE;
Brian Paula6c423d2004-08-25 15:59:48 +0000373 (void) ctx;
Brian Paul9560f052000-01-31 23:11:39 +0000374 _glthread_LOCK_MUTEX(OneTimeLock);
jtgafb833d1999-08-19 00:55:39 +0000375 if (!alreadyCalled) {
Brian Paul27558a12003-03-01 01:50:20 +0000376 GLuint i;
377
Brian Paul4d053dd2000-01-14 04:45:47 +0000378 /* do some implementation tests */
379 assert( sizeof(GLbyte) == 1 );
Brian Paul4d053dd2000-01-14 04:45:47 +0000380 assert( sizeof(GLubyte) == 1 );
Brian Paul894844a2004-03-21 17:05:03 +0000381 assert( sizeof(GLshort) == 2 );
382 assert( sizeof(GLushort) == 2 );
383 assert( sizeof(GLint) == 4 );
384 assert( sizeof(GLuint) == 4 );
Brian Paul4d053dd2000-01-14 04:45:47 +0000385
Brian33c37392007-04-04 22:18:53 -0600386 _mesa_init_sqrt_table();
387
Brian Paul27558a12003-03-01 01:50:20 +0000388 for (i = 0; i < 256; i++) {
389 _mesa_ubyte_to_float_color_tab[i] = (float) i / 255.0F;
390 }
Brian Paul68ee4bc2000-01-28 19:02:22 +0000391
davem69775355a2001-06-05 23:54:00 +0000392#ifdef USE_SPARC_ASM
393 _mesa_init_sparc_glapi_relocs();
394#endif
Brian Paul3c634522002-10-24 23:57:19 +0000395 if (_mesa_getenv("MESA_DEBUG")) {
Brian Paul68ee4bc2000-01-28 19:02:22 +0000396 _glapi_noop_enable_warnings(GL_TRUE);
Brian Paul4e9676f2002-06-29 19:48:15 +0000397 _glapi_set_warning_func( (_glapi_warning_func) _mesa_warning );
Brian Paul68ee4bc2000-01-28 19:02:22 +0000398 }
399 else {
400 _glapi_noop_enable_warnings(GL_FALSE);
401 }
402
jtgafb833d1999-08-19 00:55:39 +0000403#if defined(DEBUG) && defined(__DATE__) && defined(__TIME__)
Brian Paul363344f2005-09-13 14:48:28 +0000404 _mesa_debug(ctx, "Mesa %s DEBUG build %s %s\n",
405 MESA_VERSION_STRING, __DATE__, __TIME__);
jtgafb833d1999-08-19 00:55:39 +0000406#endif
Brian Paul68ee4bc2000-01-28 19:02:22 +0000407
408 alreadyCalled = GL_TRUE;
409 }
Brian Paul9560f052000-01-31 23:11:39 +0000410 _glthread_UNLOCK_MUTEX(OneTimeLock);
jtgafb833d1999-08-19 00:55:39 +0000411}
412
Brian Paul894844a2004-03-21 17:05:03 +0000413
Keith Whitwell6dc85572003-07-17 13:43:59 +0000414/**
jtgafb833d1999-08-19 00:55:39 +0000415 * Allocate and initialize a shared context state structure.
Keith Whitwell6dc85572003-07-17 13:43:59 +0000416 * Initializes the display list, texture objects and vertex programs hash
417 * tables, allocates the texture objects. If it runs out of memory, frees
418 * everything already allocated before returning NULL.
Brian Paul894844a2004-03-21 17:05:03 +0000419 *
420 * \return pointer to a gl_shared_state structure on success, or NULL on
421 * failure.
jtgafb833d1999-08-19 00:55:39 +0000422 */
Brian Paula3f13702003-04-01 16:41:50 +0000423static GLboolean
424alloc_shared_state( GLcontext *ctx )
jtgafb833d1999-08-19 00:55:39 +0000425{
Brian Paula3f13702003-04-01 16:41:50 +0000426 struct gl_shared_state *ss = CALLOC_STRUCT(gl_shared_state);
jtgafb833d1999-08-19 00:55:39 +0000427 if (!ss)
Brian Paula3f13702003-04-01 16:41:50 +0000428 return GL_FALSE;
429
430 ctx->Shared = ss;
jtgafb833d1999-08-19 00:55:39 +0000431
Brian Paule4b684c2000-09-12 21:07:40 +0000432 _glthread_INIT_MUTEX(ss->Mutex);
jtgafb833d1999-08-19 00:55:39 +0000433
Brian Paule4b684c2000-09-12 21:07:40 +0000434 ss->DisplayList = _mesa_NewHashTable();
Brian Paulbb797902000-01-24 16:19:54 +0000435 ss->TexObjects = _mesa_NewHashTable();
Brian Paul610d5992003-01-14 04:55:45 +0000436 ss->Programs = _mesa_NewHashTable();
jtgafb833d1999-08-19 00:55:39 +0000437
Brian Paul451f3102003-04-17 01:48:19 +0000438#if FEATURE_ARB_vertex_program
Briandf43fb62008-05-06 23:08:51 -0600439 ss->DefaultVertexProgram = (struct gl_vertex_program *)
440 ctx->Driver.NewProgram(ctx, GL_VERTEX_PROGRAM_ARB, 0);
Brian Paul451f3102003-04-17 01:48:19 +0000441 if (!ss->DefaultVertexProgram)
442 goto cleanup;
443#endif
444#if FEATURE_ARB_fragment_program
Briandf43fb62008-05-06 23:08:51 -0600445 ss->DefaultFragmentProgram = (struct gl_fragment_program *)
446 ctx->Driver.NewProgram(ctx, GL_FRAGMENT_PROGRAM_ARB, 0);
Brian Paul451f3102003-04-17 01:48:19 +0000447 if (!ss->DefaultFragmentProgram)
448 goto cleanup;
449#endif
Dave Airlie7f752fe2004-12-19 03:06:59 +0000450#if FEATURE_ATI_fragment_shader
Brian Paul63d68302005-11-19 16:43:04 +0000451 ss->ATIShaders = _mesa_NewHashTable();
452 ss->DefaultFragmentShader = _mesa_new_ati_fragment_shader(ctx, 0);
Dave Airlie7f752fe2004-12-19 03:06:59 +0000453 if (!ss->DefaultFragmentShader)
454 goto cleanup;
455#endif
Brian Paul451f3102003-04-17 01:48:19 +0000456
Tilman Sauerbeck17b50632006-07-11 19:03:21 +0000457#if FEATURE_ARB_vertex_buffer_object || FEATURE_ARB_pixel_buffer_object
Brian Paulddc82ee2005-02-05 19:56:45 +0000458 ss->BufferObjects = _mesa_NewHashTable();
Tilman Sauerbeck17b50632006-07-11 19:03:21 +0000459#endif
460
Ian Romanickee34e6e2006-06-12 16:26:29 +0000461 ss->ArrayObjects = _mesa_NewHashTable();
Brian Paulddc82ee2005-02-05 19:56:45 +0000462
Michal Krol365582d2006-08-01 20:07:31 +0000463#if FEATURE_ARB_shader_objects
Briana90046f2006-12-15 10:07:26 -0700464 ss->ShaderObjects = _mesa_NewHashTable();
Michal Krol365582d2006-08-01 20:07:31 +0000465#endif
Ian Romanick0207b472003-09-09 00:10:12 +0000466
Brian Paula3f13702003-04-01 16:41:50 +0000467 ss->Default1D = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_1D);
468 if (!ss->Default1D)
469 goto cleanup;
Brian Paula8523782000-11-19 23:10:25 +0000470
Brian Paula3f13702003-04-01 16:41:50 +0000471 ss->Default2D = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_2D);
472 if (!ss->Default2D)
473 goto cleanup;
jtgafb833d1999-08-19 00:55:39 +0000474
Brian Paula3f13702003-04-01 16:41:50 +0000475 ss->Default3D = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_3D);
476 if (!ss->Default3D)
477 goto cleanup;
Brian Paula8523782000-11-19 23:10:25 +0000478
Brian Paula3f13702003-04-01 16:41:50 +0000479 ss->DefaultCubeMap = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_CUBE_MAP_ARB);
480 if (!ss->DefaultCubeMap)
481 goto cleanup;
Brian Paula8523782000-11-19 23:10:25 +0000482
Brian Paula3f13702003-04-01 16:41:50 +0000483 ss->DefaultRect = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_RECTANGLE_NV);
484 if (!ss->DefaultRect)
485 goto cleanup;
Brian Paul413d6a22000-05-26 14:44:59 +0000486
Ian Romanickbb372f12007-05-16 15:34:22 -0700487 ss->Default1DArray = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_1D_ARRAY_EXT);
488 if (!ss->Default1DArray)
489 goto cleanup;
490
491 ss->Default2DArray = (*ctx->Driver.NewTextureObject)(ctx, 0, GL_TEXTURE_2D_ARRAY_EXT);
492 if (!ss->Default2DArray)
493 goto cleanup;
494
Brian9e01b912007-08-13 11:29:46 +0100495 /* sanity check */
496 assert(ss->Default1D->RefCount == 1);
Brian Paula3f13702003-04-01 16:41:50 +0000497
Keith Whitwell5ac93f82006-11-01 14:21:57 +0000498 _glthread_INIT_MUTEX(ss->TexMutex);
499 ss->TextureStateStamp = 0;
500
Brian Paulddc82ee2005-02-05 19:56:45 +0000501#if FEATURE_EXT_framebuffer_object
502 ss->FrameBuffers = _mesa_NewHashTable();
503 if (!ss->FrameBuffers)
504 goto cleanup;
505 ss->RenderBuffers = _mesa_NewHashTable();
506 if (!ss->RenderBuffers)
507 goto cleanup;
508#endif
509
Brian Paula3f13702003-04-01 16:41:50 +0000510 return GL_TRUE;
511
Brian9e01b912007-08-13 11:29:46 +0100512cleanup:
Brian Paula3f13702003-04-01 16:41:50 +0000513 /* Ran out of memory at some point. Free everything and return NULL */
514 if (ss->DisplayList)
515 _mesa_DeleteHashTable(ss->DisplayList);
516 if (ss->TexObjects)
517 _mesa_DeleteHashTable(ss->TexObjects);
Brian Paula3f13702003-04-01 16:41:50 +0000518 if (ss->Programs)
519 _mesa_DeleteHashTable(ss->Programs);
Brian Paul451f3102003-04-17 01:48:19 +0000520#if FEATURE_ARB_vertex_program
Briandf43fb62008-05-06 23:08:51 -0600521 _mesa_reference_vertprog(ctx, &ss->DefaultVertexProgram, NULL);
Brian Paul451f3102003-04-17 01:48:19 +0000522#endif
523#if FEATURE_ARB_fragment_program
Briandf43fb62008-05-06 23:08:51 -0600524 _mesa_reference_fragprog(ctx, &ss->DefaultFragmentProgram, NULL);
Brian Paul451f3102003-04-17 01:48:19 +0000525#endif
Dave Airlie7f752fe2004-12-19 03:06:59 +0000526#if FEATURE_ATI_fragment_shader
527 if (ss->DefaultFragmentShader)
Brian Paul63d68302005-11-19 16:43:04 +0000528 _mesa_delete_ati_fragment_shader(ctx, ss->DefaultFragmentShader);
Dave Airlie7f752fe2004-12-19 03:06:59 +0000529#endif
Tilman Sauerbeck17b50632006-07-11 19:03:21 +0000530#if FEATURE_ARB_vertex_buffer_object || FEATURE_ARB_pixel_buffer_object
Ian Romanick0207b472003-09-09 00:10:12 +0000531 if (ss->BufferObjects)
532 _mesa_DeleteHashTable(ss->BufferObjects);
Brian Paulddc82ee2005-02-05 19:56:45 +0000533#endif
534
Tilman Sauerbeckc0eb7772006-07-11 19:36:27 +0000535 if (ss->ArrayObjects)
536 _mesa_DeleteHashTable (ss->ArrayObjects);
537
Michal Krol365582d2006-08-01 20:07:31 +0000538#if FEATURE_ARB_shader_objects
Brian0bf5dbe2006-12-19 18:02:41 -0700539 if (ss->ShaderObjects)
Briana90046f2006-12-15 10:07:26 -0700540 _mesa_DeleteHashTable (ss->ShaderObjects);
Michal Krol365582d2006-08-01 20:07:31 +0000541#endif
Ian Romanick0207b472003-09-09 00:10:12 +0000542
Brian Paulddc82ee2005-02-05 19:56:45 +0000543#if FEATURE_EXT_framebuffer_object
544 if (ss->FrameBuffers)
545 _mesa_DeleteHashTable(ss->FrameBuffers);
546 if (ss->RenderBuffers)
547 _mesa_DeleteHashTable(ss->RenderBuffers);
548#endif
549
Brian Paula3f13702003-04-01 16:41:50 +0000550 if (ss->Default1D)
551 (*ctx->Driver.DeleteTexture)(ctx, ss->Default1D);
552 if (ss->Default2D)
553 (*ctx->Driver.DeleteTexture)(ctx, ss->Default2D);
554 if (ss->Default3D)
555 (*ctx->Driver.DeleteTexture)(ctx, ss->Default3D);
556 if (ss->DefaultCubeMap)
557 (*ctx->Driver.DeleteTexture)(ctx, ss->DefaultCubeMap);
558 if (ss->DefaultRect)
559 (*ctx->Driver.DeleteTexture)(ctx, ss->DefaultRect);
Brian6f472502007-08-13 11:09:48 +0100560 if (ss->Default1DArray)
561 (*ctx->Driver.DeleteTexture)(ctx, ss->Default1DArray);
562 if (ss->Default2DArray)
563 (*ctx->Driver.DeleteTexture)(ctx, ss->Default2DArray);
Briana5c84de2008-01-01 10:20:21 -0700564
565 _mesa_free(ss);
566
Brian Paula3f13702003-04-01 16:41:50 +0000567 return GL_FALSE;
jtgafb833d1999-08-19 00:55:39 +0000568}
569
Brian Paulc7e164f2006-06-30 15:44:30 +0000570
Keith Whitwell6dc85572003-07-17 13:43:59 +0000571/**
Brian Paulc7e164f2006-06-30 15:44:30 +0000572 * Callback for deleting a display list. Called by _mesa_HashDeleteAll().
573 */
574static void
575delete_displaylist_cb(GLuint id, void *data, void *userData)
576{
Keith Whitwell34a61c62008-09-21 19:29:15 -0700577#if FEATURE_dlist
Brian446abc22009-01-31 11:57:22 -0700578 struct gl_display_list *list = (struct gl_display_list *) data;
Brian Paulc7e164f2006-06-30 15:44:30 +0000579 GLcontext *ctx = (GLcontext *) userData;
580 _mesa_delete_list(ctx, list);
Keith Whitwell34a61c62008-09-21 19:29:15 -0700581#endif
Brian Paulc7e164f2006-06-30 15:44:30 +0000582}
583
584/**
585 * Callback for deleting a texture object. Called by _mesa_HashDeleteAll().
586 */
587static void
588delete_texture_cb(GLuint id, void *data, void *userData)
589{
590 struct gl_texture_object *texObj = (struct gl_texture_object *) data;
591 GLcontext *ctx = (GLcontext *) userData;
592 ctx->Driver.DeleteTexture(ctx, texObj);
593}
594
595/**
596 * Callback for deleting a program object. Called by _mesa_HashDeleteAll().
597 */
598static void
599delete_program_cb(GLuint id, void *data, void *userData)
600{
Brian Paul122629f2006-07-20 16:49:57 +0000601 struct gl_program *prog = (struct gl_program *) data;
Brian Paulc7e164f2006-06-30 15:44:30 +0000602 GLcontext *ctx = (GLcontext *) userData;
Brian Paulfbfe2a52008-05-19 08:43:36 -0600603 ASSERT(prog->RefCount == 1); /* should only be referenced by hash table */
604 prog->RefCount = 0; /* now going away */
Brian Paulc7e164f2006-06-30 15:44:30 +0000605 ctx->Driver.DeleteProgram(ctx, prog);
606}
607
Brian Paule961a5d2008-06-12 16:55:28 -0600608#if FEATURE_ATI_fragment_shader
Brian Paulc7e164f2006-06-30 15:44:30 +0000609/**
610 * Callback for deleting an ATI fragment shader object.
611 * Called by _mesa_HashDeleteAll().
612 */
613static void
614delete_fragshader_cb(GLuint id, void *data, void *userData)
615{
616 struct ati_fragment_shader *shader = (struct ati_fragment_shader *) data;
617 GLcontext *ctx = (GLcontext *) userData;
618 _mesa_delete_ati_fragment_shader(ctx, shader);
619}
Brian Paule961a5d2008-06-12 16:55:28 -0600620#endif
Brian Paulc7e164f2006-06-30 15:44:30 +0000621
622/**
623 * Callback for deleting a buffer object. Called by _mesa_HashDeleteAll().
624 */
625static void
626delete_bufferobj_cb(GLuint id, void *data, void *userData)
627{
628 struct gl_buffer_object *bufObj = (struct gl_buffer_object *) data;
629 GLcontext *ctx = (GLcontext *) userData;
630 ctx->Driver.DeleteBuffer(ctx, bufObj);
631}
632
Brian Paulc04bb512006-07-11 21:56:43 +0000633/**
634 * Callback for deleting an array object. Called by _mesa_HashDeleteAll().
635 */
636static void
637delete_arrayobj_cb(GLuint id, void *data, void *userData)
638{
639 struct gl_array_object *arrayObj = (struct gl_array_object *) data;
640 GLcontext *ctx = (GLcontext *) userData;
641 _mesa_delete_array_object(ctx, arrayObj);
642}
643
Brian Paul4d4373b2006-11-18 17:44:28 +0000644/**
Xiang, Haihao63d8a842008-03-31 17:02:47 +0800645 * Callback for freeing shader program data. Call it before delete_shader_cb
646 * to avoid memory access error.
647 */
648static void
649free_shader_program_data_cb(GLuint id, void *data, void *userData)
650{
651 GLcontext *ctx = (GLcontext *) userData;
652 struct gl_shader_program *shProg = (struct gl_shader_program *) data;
653
654 if (shProg->Type == GL_SHADER_PROGRAM_MESA) {
655 _mesa_free_shader_program_data(ctx, shProg);
656 }
657}
658
659/**
Brian9e4bae92006-12-20 09:27:42 -0700660 * Callback for deleting shader and shader programs objects.
661 * Called by _mesa_HashDeleteAll().
Brian Paul4d4373b2006-11-18 17:44:28 +0000662 */
663static void
Brian9e4bae92006-12-20 09:27:42 -0700664delete_shader_cb(GLuint id, void *data, void *userData)
Brian Paul4d4373b2006-11-18 17:44:28 +0000665{
Brian9e4bae92006-12-20 09:27:42 -0700666 GLcontext *ctx = (GLcontext *) userData;
667 struct gl_shader *sh = (struct gl_shader *) data;
Xiang, Haihaoaef47c42008-03-31 16:27:47 +0800668 if (sh->Type == GL_FRAGMENT_SHADER || sh->Type == GL_VERTEX_SHADER) {
669 _mesa_free_shader(ctx, sh);
670 }
671 else {
672 struct gl_shader_program *shProg = (struct gl_shader_program *) data;
673 ASSERT(shProg->Type == GL_SHADER_PROGRAM_MESA);
674 _mesa_free_shader_program(ctx, shProg);
675 }
Brian Paul4d4373b2006-11-18 17:44:28 +0000676}
677
Brian393a6252007-08-13 17:37:30 +0100678/**
679 * Callback for deleting a framebuffer object. Called by _mesa_HashDeleteAll()
680 */
681static void
682delete_framebuffer_cb(GLuint id, void *data, void *userData)
683{
684 struct gl_framebuffer *fb = (struct gl_framebuffer *) data;
Briandc732172007-08-14 11:56:59 +0100685 /* The fact that the framebuffer is in the hashtable means its refcount
686 * is one, but we're removing from the hashtable now. So clear refcount.
687 */
688 /*assert(fb->RefCount == 1);*/
689 fb->RefCount = 0;
Brian2f7c8042008-01-30 08:08:23 -0700690
691 /* NOTE: Delete should always be defined but there are two reports
692 * of it being NULL (bugs 13507, 14293). Work-around for now.
693 */
694 if (fb->Delete)
695 fb->Delete(fb);
Brian393a6252007-08-13 17:37:30 +0100696}
697
698/**
699 * Callback for deleting a renderbuffer object. Called by _mesa_HashDeleteAll()
700 */
701static void
702delete_renderbuffer_cb(GLuint id, void *data, void *userData)
703{
704 struct gl_renderbuffer *rb = (struct gl_renderbuffer *) data;
Briandc732172007-08-14 11:56:59 +0100705 rb->RefCount = 0; /* see comment for FBOs above */
Brian Paul61b3ce82008-08-03 11:13:12 -0600706 if (rb->Delete)
707 rb->Delete(rb);
Brian393a6252007-08-13 17:37:30 +0100708}
709
710
Brian Paulc7e164f2006-06-30 15:44:30 +0000711/**
712 * Deallocate a shared state object and all children structures.
Keith Whitwell6dc85572003-07-17 13:43:59 +0000713 *
714 * \param ctx GL context.
715 * \param ss shared state pointer.
716 *
717 * Frees the display lists, the texture objects (calling the driver texture
718 * deletion callback to free its private data) and the vertex programs, as well
719 * as their hash tables.
720 *
721 * \sa alloc_shared_state().
jtgafb833d1999-08-19 00:55:39 +0000722 */
Brian Paul178a1c52000-04-22 01:05:00 +0000723static void
724free_shared_state( GLcontext *ctx, struct gl_shared_state *ss )
jtgafb833d1999-08-19 00:55:39 +0000725{
Brian Paulc7e164f2006-06-30 15:44:30 +0000726 /*
727 * Free display lists
728 */
729 _mesa_HashDeleteAll(ss->DisplayList, delete_displaylist_cb, ctx);
Brian Paulbb797902000-01-24 16:19:54 +0000730 _mesa_DeleteHashTable(ss->DisplayList);
jtgafb833d1999-08-19 00:55:39 +0000731
Brian Paulfbfe2a52008-05-19 08:43:36 -0600732#if FEATURE_ARB_shader_objects
733 _mesa_HashWalk(ss->ShaderObjects, free_shader_program_data_cb, ctx);
734 _mesa_HashDeleteAll(ss->ShaderObjects, delete_shader_cb, ctx);
735 _mesa_DeleteHashTable(ss->ShaderObjects);
736#endif
737
Brian Paulc7e164f2006-06-30 15:44:30 +0000738 _mesa_HashDeleteAll(ss->Programs, delete_program_cb, ctx);
Brian Paul610d5992003-01-14 04:55:45 +0000739 _mesa_DeleteHashTable(ss->Programs);
Brian Paul85f553d2008-06-20 10:47:38 -0600740
Brian Paul21841f02004-08-14 14:28:11 +0000741#if FEATURE_ARB_vertex_program
Briandf43fb62008-05-06 23:08:51 -0600742 _mesa_reference_vertprog(ctx, &ss->DefaultVertexProgram, NULL);
Brian Paul21841f02004-08-14 14:28:11 +0000743#endif
744#if FEATURE_ARB_fragment_program
Briandf43fb62008-05-06 23:08:51 -0600745 _mesa_reference_fragprog(ctx, &ss->DefaultFragmentProgram, NULL);
Brian Paul21841f02004-08-14 14:28:11 +0000746#endif
Brian Paul1096eae2006-01-16 16:35:13 +0000747
Dave Airlie7f752fe2004-12-19 03:06:59 +0000748#if FEATURE_ATI_fragment_shader
Brian Paulc7e164f2006-06-30 15:44:30 +0000749 _mesa_HashDeleteAll(ss->ATIShaders, delete_fragshader_cb, ctx);
Brian Paul1096eae2006-01-16 16:35:13 +0000750 _mesa_DeleteHashTable(ss->ATIShaders);
751 _mesa_delete_ati_fragment_shader(ctx, ss->DefaultFragmentShader);
Dave Airlie7f752fe2004-12-19 03:06:59 +0000752#endif
Brian Paul30f51ae2001-12-18 04:06:44 +0000753
Tilman Sauerbeck17b50632006-07-11 19:03:21 +0000754#if FEATURE_ARB_vertex_buffer_object || FEATURE_ARB_pixel_buffer_object
Brian Paulc7e164f2006-06-30 15:44:30 +0000755 _mesa_HashDeleteAll(ss->BufferObjects, delete_bufferobj_cb, ctx);
Ian Romanick0207b472003-09-09 00:10:12 +0000756 _mesa_DeleteHashTable(ss->BufferObjects);
Brian Paulddc82ee2005-02-05 19:56:45 +0000757#endif
758
Brian Paulc04bb512006-07-11 21:56:43 +0000759 _mesa_HashDeleteAll(ss->ArrayObjects, delete_arrayobj_cb, ctx);
Tilman Sauerbeckc0eb7772006-07-11 19:36:27 +0000760 _mesa_DeleteHashTable(ss->ArrayObjects);
761
Brian Paulddc82ee2005-02-05 19:56:45 +0000762#if FEATURE_EXT_framebuffer_object
Brian393a6252007-08-13 17:37:30 +0100763 _mesa_HashDeleteAll(ss->FrameBuffers, delete_framebuffer_cb, ctx);
Brian Paulddc82ee2005-02-05 19:56:45 +0000764 _mesa_DeleteHashTable(ss->FrameBuffers);
Brian393a6252007-08-13 17:37:30 +0100765 _mesa_HashDeleteAll(ss->RenderBuffers, delete_renderbuffer_cb, ctx);
Brian Paulddc82ee2005-02-05 19:56:45 +0000766 _mesa_DeleteHashTable(ss->RenderBuffers);
767#endif
Michal Krol9b3752c2005-01-13 14:08:47 +0000768
Briandc732172007-08-14 11:56:59 +0100769 /*
770 * Free texture objects (after FBOs since some textures might have
771 * been bound to FBOs).
772 */
773 ASSERT(ctx->Driver.DeleteTexture);
774 /* the default textures */
775 ctx->Driver.DeleteTexture(ctx, ss->Default1D);
776 ctx->Driver.DeleteTexture(ctx, ss->Default2D);
777 ctx->Driver.DeleteTexture(ctx, ss->Default3D);
778 ctx->Driver.DeleteTexture(ctx, ss->DefaultCubeMap);
779 ctx->Driver.DeleteTexture(ctx, ss->DefaultRect);
780 ctx->Driver.DeleteTexture(ctx, ss->Default1DArray);
781 ctx->Driver.DeleteTexture(ctx, ss->Default2DArray);
782 /* all other textures */
783 _mesa_HashDeleteAll(ss->TexObjects, delete_texture_cb, ctx);
784 _mesa_DeleteHashTable(ss->TexObjects);
785
Keith Whitwelle15fd852002-12-12 13:03:15 +0000786 _glthread_DESTROY_MUTEX(ss->Mutex);
787
Brian Paulc7e164f2006-06-30 15:44:30 +0000788 _mesa_free(ss);
jtgafb833d1999-08-19 00:55:39 +0000789}
790
791
Brian Paul4d859f72004-01-23 18:57:05 +0000792/**
793 * Initialize fields of gl_current_attrib (aka ctx->Current.*)
794 */
795static void
Briand881a9c2006-12-20 09:31:07 -0700796_mesa_init_current(GLcontext *ctx)
jtgafb833d1999-08-19 00:55:39 +0000797{
Brian Paul88bf0382004-02-13 15:30:08 +0000798 GLuint i;
jtgafb833d1999-08-19 00:55:39 +0000799
Brian Paul94b30dc2006-04-25 00:53:25 +0000800 /* Init all to (0,0,0,1) */
Keith Whitwell6dc85572003-07-17 13:43:59 +0000801 for (i = 0; i < VERT_ATTRIB_MAX; i++) {
802 ASSIGN_4V( ctx->Current.Attrib[i], 0.0, 0.0, 0.0, 1.0 );
jtgafb833d1999-08-19 00:55:39 +0000803 }
Brian Paul94b30dc2006-04-25 00:53:25 +0000804
805 /* redo special cases: */
Markus Amsler507da2472008-03-09 17:51:11 -0600806 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_WEIGHT], 1.0, 0.0, 0.0, 0.0 );
Keith Whitwell6dc85572003-07-17 13:43:59 +0000807 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_NORMAL], 0.0, 0.0, 1.0, 1.0 );
808 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_COLOR0], 1.0, 1.0, 1.0, 1.0 );
Brian Paul88bf0382004-02-13 15:30:08 +0000809 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_COLOR1], 0.0, 0.0, 0.0, 1.0 );
Keith Whitwellfd275602006-10-30 20:16:35 +0000810 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_COLOR_INDEX], 1.0, 0.0, 0.0, 1.0 );
811 ASSIGN_4V( ctx->Current.Attrib[VERT_ATTRIB_EDGEFLAG], 1.0, 0.0, 0.0, 1.0 );
jtgafb833d1999-08-19 00:55:39 +0000812}
813
814
Brian Paul4d859f72004-01-23 18:57:05 +0000815/**
Brian Paulf51cca72008-09-25 19:22:29 -0600816 * Init vertex/fragment program limits.
817 * Important: drivers should override these with actual limits.
Brian Paul05051032005-11-01 04:36:33 +0000818 */
819static void
Brian Paulf51cca72008-09-25 19:22:29 -0600820init_program_limits(GLenum type, struct gl_program_constants *prog)
Brian Paul05051032005-11-01 04:36:33 +0000821{
Brian Paulf51cca72008-09-25 19:22:29 -0600822 prog->MaxInstructions = MAX_PROGRAM_INSTRUCTIONS;
823 prog->MaxAluInstructions = MAX_PROGRAM_INSTRUCTIONS;
824 prog->MaxTexInstructions = MAX_PROGRAM_INSTRUCTIONS;
825 prog->MaxTexIndirections = MAX_PROGRAM_INSTRUCTIONS;
826 prog->MaxTemps = MAX_PROGRAM_TEMPS;
827 prog->MaxEnvParams = MAX_PROGRAM_ENV_PARAMS;
828 prog->MaxLocalParams = MAX_PROGRAM_LOCAL_PARAMS;
829 prog->MaxUniformComponents = 4 * MAX_UNIFORMS;
830
831 if (type == GL_VERTEX_PROGRAM_ARB) {
832 prog->MaxParameters = MAX_NV_VERTEX_PROGRAM_PARAMS;
833 prog->MaxAttribs = MAX_NV_VERTEX_PROGRAM_INPUTS;
834 prog->MaxAddressRegs = MAX_VERTEX_PROGRAM_ADDRESS_REGS;
835 }
836 else {
837 prog->MaxParameters = MAX_NV_FRAGMENT_PROGRAM_PARAMS;
838 prog->MaxAttribs = MAX_NV_FRAGMENT_PROGRAM_INPUTS;
839 prog->MaxAddressRegs = MAX_FRAGMENT_PROGRAM_ADDRESS_REGS;
840 }
841
842 /* copy the above limits to init native limits */
Brian Paul05051032005-11-01 04:36:33 +0000843 prog->MaxNativeInstructions = prog->MaxInstructions;
844 prog->MaxNativeAluInstructions = prog->MaxAluInstructions;
845 prog->MaxNativeTexInstructions = prog->MaxTexInstructions;
846 prog->MaxNativeTexIndirections = prog->MaxTexIndirections;
847 prog->MaxNativeAttribs = prog->MaxAttribs;
848 prog->MaxNativeTemps = prog->MaxTemps;
849 prog->MaxNativeAddressRegs = prog->MaxAddressRegs;
850 prog->MaxNativeParameters = prog->MaxParameters;
851}
852
853
854/**
Brian Paul4d859f72004-01-23 18:57:05 +0000855 * Initialize fields of gl_constants (aka ctx->Const.*).
856 * Use defaults from config.h. The device drivers will often override
857 * some of these values (such as number of texture units).
858 */
Keith Whitwell6dc85572003-07-17 13:43:59 +0000859static void
Briand881a9c2006-12-20 09:31:07 -0700860_mesa_init_constants(GLcontext *ctx)
jtgafb833d1999-08-19 00:55:39 +0000861{
Brian Paul4d053dd2000-01-14 04:45:47 +0000862 assert(ctx);
jtgafb833d1999-08-19 00:55:39 +0000863
Brian Paulcd1cefa2001-06-13 14:56:14 +0000864 assert(MAX_TEXTURE_LEVELS >= MAX_3D_TEXTURE_LEVELS);
865 assert(MAX_TEXTURE_LEVELS >= MAX_CUBE_TEXTURE_LEVELS);
866
Brian Paul65591072009-02-13 07:44:02 -0700867 /* Max texture size should be <= max viewport size (render to texture) */
868 assert((1 << (MAX_TEXTURE_LEVELS - 1)) <= MAX_WIDTH);
869
Brian Paul53f82c52004-10-02 16:39:09 +0000870 /* Constants, may be overriden (usually only reduced) by device drivers */
Brian Paul4d053dd2000-01-14 04:45:47 +0000871 ctx->Const.MaxTextureLevels = MAX_TEXTURE_LEVELS;
Brian Paulcd1cefa2001-06-13 14:56:14 +0000872 ctx->Const.Max3DTextureLevels = MAX_3D_TEXTURE_LEVELS;
873 ctx->Const.MaxCubeTextureLevels = MAX_CUBE_TEXTURE_LEVELS;
Brian Paul8afe7de2002-06-15 03:03:06 +0000874 ctx->Const.MaxTextureRectSize = MAX_TEXTURE_RECT_SIZE;
Ian Romanickbb372f12007-05-16 15:34:22 -0700875 ctx->Const.MaxArrayTextureLayers = MAX_ARRAY_TEXTURE_LAYERS;
Brian Paul610d5992003-01-14 04:55:45 +0000876 ctx->Const.MaxTextureCoordUnits = MAX_TEXTURE_COORD_UNITS;
877 ctx->Const.MaxTextureImageUnits = MAX_TEXTURE_IMAGE_UNITS;
Brian Paulda238ee2006-04-13 19:21:58 +0000878 ctx->Const.MaxTextureUnits = MIN2(ctx->Const.MaxTextureCoordUnits,
879 ctx->Const.MaxTextureImageUnits);
Gareth Hughes2c3d34c2001-03-18 08:53:49 +0000880 ctx->Const.MaxTextureMaxAnisotropy = MAX_TEXTURE_MAX_ANISOTROPY;
Brian Paul87c964d2001-11-06 15:53:00 +0000881 ctx->Const.MaxTextureLodBias = MAX_TEXTURE_LOD_BIAS;
Brian Paul4d053dd2000-01-14 04:45:47 +0000882 ctx->Const.MaxArrayLockSize = MAX_ARRAY_LOCK_SIZE;
Brian Paul539cce52000-02-03 19:40:07 +0000883 ctx->Const.SubPixelBits = SUB_PIXEL_BITS;
884 ctx->Const.MinPointSize = MIN_POINT_SIZE;
885 ctx->Const.MaxPointSize = MAX_POINT_SIZE;
886 ctx->Const.MinPointSizeAA = MIN_POINT_SIZE;
887 ctx->Const.MaxPointSizeAA = MAX_POINT_SIZE;
Brian Paulfde5e2c2001-09-15 18:02:49 +0000888 ctx->Const.PointSizeGranularity = (GLfloat) POINT_SIZE_GRANULARITY;
Brian Paul539cce52000-02-03 19:40:07 +0000889 ctx->Const.MinLineWidth = MIN_LINE_WIDTH;
890 ctx->Const.MaxLineWidth = MAX_LINE_WIDTH;
891 ctx->Const.MinLineWidthAA = MIN_LINE_WIDTH;
892 ctx->Const.MaxLineWidthAA = MAX_LINE_WIDTH;
Brian Paulfde5e2c2001-09-15 18:02:49 +0000893 ctx->Const.LineWidthGranularity = (GLfloat) LINE_WIDTH_GRANULARITY;
Brian Paul4bdcfe52000-04-17 17:57:04 +0000894 ctx->Const.MaxColorTableSize = MAX_COLOR_TABLE_SIZE;
Brian Paul82b02f02000-05-07 20:37:40 +0000895 ctx->Const.MaxConvolutionWidth = MAX_CONVOLUTION_WIDTH;
896 ctx->Const.MaxConvolutionHeight = MAX_CONVOLUTION_HEIGHT;
Brian Paula8644322000-11-27 18:22:13 +0000897 ctx->Const.MaxClipPlanes = MAX_CLIP_PLANES;
898 ctx->Const.MaxLights = MAX_LIGHTS;
Ian Romanick882caa12003-05-30 21:37:14 +0000899 ctx->Const.MaxShininess = 128.0;
Brian Paul53f82c52004-10-02 16:39:09 +0000900 ctx->Const.MaxSpotExponent = 128.0;
901 ctx->Const.MaxViewportWidth = MAX_WIDTH;
902 ctx->Const.MaxViewportHeight = MAX_HEIGHT;
Brian Pauld0492cf2003-04-11 01:20:06 +0000903#if FEATURE_ARB_vertex_program
Brian Paulf51cca72008-09-25 19:22:29 -0600904 init_program_limits(GL_VERTEX_PROGRAM_ARB, &ctx->Const.VertexProgram);
Brian Pauld0492cf2003-04-11 01:20:06 +0000905#endif
906#if FEATURE_ARB_fragment_program
Brian Paulf51cca72008-09-25 19:22:29 -0600907 init_program_limits(GL_FRAGMENT_PROGRAM_ARB, &ctx->Const.FragmentProgram);
Brian Pauld0492cf2003-04-11 01:20:06 +0000908#endif
Brian Pauledd67742003-04-18 18:02:43 +0000909 ctx->Const.MaxProgramMatrices = MAX_PROGRAM_MATRICES;
910 ctx->Const.MaxProgramMatrixStackDepth = MAX_PROGRAM_MATRIX_STACK_DEPTH;
Brian Pauld0492cf2003-04-11 01:20:06 +0000911
George Sapountzis507167d2006-12-06 06:54:13 +0200912 /* CheckArrayBounds is overriden by drivers/x11 for X server */
Brian Paula2b9bad2003-11-10 19:08:37 +0000913 ctx->Const.CheckArrayBounds = GL_FALSE;
Brian Paula2b9bad2003-11-10 19:08:37 +0000914
Brian Paul05051032005-11-01 04:36:33 +0000915 /* GL_ARB_draw_buffers */
Brian Paul53f82c52004-10-02 16:39:09 +0000916 ctx->Const.MaxDrawBuffers = MAX_DRAW_BUFFERS;
917
Brian Paul3deaa012005-02-07 05:08:24 +0000918 /* GL_OES_read_format */
Ian Romanick33899b72004-10-16 01:16:54 +0000919 ctx->Const.ColorReadFormat = GL_RGBA;
920 ctx->Const.ColorReadType = GL_UNSIGNED_BYTE;
921
Brian Paul3deaa012005-02-07 05:08:24 +0000922#if FEATURE_EXT_framebuffer_object
923 ctx->Const.MaxColorAttachments = MAX_COLOR_ATTACHMENTS;
924 ctx->Const.MaxRenderbufferSize = MAX_WIDTH;
925#endif
926
Brian Paul90fcf6c2006-11-01 00:12:41 +0000927#if FEATURE_ARB_vertex_shader
928 ctx->Const.MaxVertexTextureImageUnits = MAX_VERTEX_TEXTURE_IMAGE_UNITS;
Briana90046f2006-12-15 10:07:26 -0700929 ctx->Const.MaxVarying = MAX_VARYING;
Brian Paul90fcf6c2006-11-01 00:12:41 +0000930#endif
931
Brian Paul8fb88552009-01-20 15:29:08 -0700932 /* GL_ARB_framebuffer_object */
933 ctx->Const.MaxSamples = 0;
934
Brian Paul53f82c52004-10-02 16:39:09 +0000935 /* sanity checks */
Brian Paulda238ee2006-04-13 19:21:58 +0000936 ASSERT(ctx->Const.MaxTextureUnits == MIN2(ctx->Const.MaxTextureImageUnits,
937 ctx->Const.MaxTextureCoordUnits));
Brian Paul05051032005-11-01 04:36:33 +0000938 ASSERT(ctx->Const.FragmentProgram.MaxLocalParams <= MAX_PROGRAM_LOCAL_PARAMS);
939 ASSERT(ctx->Const.VertexProgram.MaxLocalParams <= MAX_PROGRAM_LOCAL_PARAMS);
Briana90046f2006-12-15 10:07:26 -0700940
941 ASSERT(MAX_NV_FRAGMENT_PROGRAM_TEMPS <= MAX_PROGRAM_TEMPS);
942 ASSERT(MAX_NV_VERTEX_PROGRAM_TEMPS <= MAX_PROGRAM_TEMPS);
943 ASSERT(MAX_NV_VERTEX_PROGRAM_INPUTS <= VERT_ATTRIB_MAX);
944 ASSERT(MAX_NV_VERTEX_PROGRAM_OUTPUTS <= VERT_RESULT_MAX);
Keith Whitwell6dc85572003-07-17 13:43:59 +0000945}
jtgafb833d1999-08-19 00:55:39 +0000946
Brian Paul4d859f72004-01-23 18:57:05 +0000947
Keith Whitwell6dc85572003-07-17 13:43:59 +0000948/**
Brian Paul5e2e96b2006-05-15 15:26:04 +0000949 * Do some sanity checks on the limits/constants for the given context.
950 * Only called the first time a context is bound.
951 */
952static void
953check_context_limits(GLcontext *ctx)
954{
955 /* Many context limits/constants are limited by the size of
956 * internal arrays.
957 */
958 assert(ctx->Const.MaxTextureImageUnits <= MAX_TEXTURE_IMAGE_UNITS);
959 assert(ctx->Const.MaxTextureCoordUnits <= MAX_TEXTURE_COORD_UNITS);
960 assert(ctx->Const.MaxTextureUnits <= MAX_TEXTURE_IMAGE_UNITS);
961 assert(ctx->Const.MaxTextureUnits <= MAX_TEXTURE_COORD_UNITS);
962
Brian Paule9b34882008-12-31 11:54:02 -0700963 /* number of coord units cannot be greater than number of image units */
964 assert(ctx->Const.MaxTextureCoordUnits <= ctx->Const.MaxTextureImageUnits);
965
Brian Paul65591072009-02-13 07:44:02 -0700966 assert(ctx->Const.MaxTextureLevels <= MAX_TEXTURE_LEVELS);
967 assert(ctx->Const.Max3DTextureLevels <= MAX_3D_TEXTURE_LEVELS);
968 assert(ctx->Const.MaxCubeTextureLevels <= MAX_CUBE_TEXTURE_LEVELS);
969 assert(ctx->Const.MaxTextureRectSize <= MAX_TEXTURE_RECT_SIZE);
Brian Paul5e2e96b2006-05-15 15:26:04 +0000970
971 /* make sure largest texture image is <= MAX_WIDTH in size */
Brian Paul65591072009-02-13 07:44:02 -0700972 assert((1 << (ctx->Const.MaxTextureLevels - 1)) <= MAX_WIDTH);
973 assert((1 << (ctx->Const.MaxCubeTextureLevels - 1)) <= MAX_WIDTH);
974 assert((1 << (ctx->Const.Max3DTextureLevels - 1)) <= MAX_WIDTH);
975
976 assert(ctx->Const.MaxViewportWidth <= MAX_WIDTH);
977 assert(ctx->Const.MaxViewportHeight <= MAX_WIDTH);
Brian Paul5e2e96b2006-05-15 15:26:04 +0000978
979 assert(ctx->Const.MaxDrawBuffers <= MAX_DRAW_BUFFERS);
980
981 /* XXX probably add more tests */
982}
983
984
985/**
Keith Whitwell6dc85572003-07-17 13:43:59 +0000986 * Initialize the attribute groups in a GL context.
987 *
988 * \param ctx GL context.
989 *
990 * Initializes all the attributes, calling the respective <tt>init*</tt>
991 * functions for the more complex data structures.
992 */
993static GLboolean
Briand881a9c2006-12-20 09:31:07 -0700994init_attrib_groups(GLcontext *ctx)
Keith Whitwell6dc85572003-07-17 13:43:59 +0000995{
996 assert(ctx);
Brian Paul4d053dd2000-01-14 04:45:47 +0000997
Keith Whitwell6dc85572003-07-17 13:43:59 +0000998 /* Constants */
999 _mesa_init_constants( ctx );
Brian Paul0771d152000-04-07 00:19:41 +00001000
Brian Paul4d053dd2000-01-14 04:45:47 +00001001 /* Extensions */
Brian Paulde4f4602003-07-03 02:15:06 +00001002 _mesa_init_extensions( ctx );
jtgafb833d1999-08-19 00:55:39 +00001003
Keith Whitwell6dc85572003-07-17 13:43:59 +00001004 /* Attribute Groups */
Keith Whitwell34a61c62008-09-21 19:29:15 -07001005#if FEATURE_accum
Keith Whitwell6dc85572003-07-17 13:43:59 +00001006 _mesa_init_accum( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001007#endif
1008#if FEATURE_attrib_stack
Keith Whitwell6dc85572003-07-17 13:43:59 +00001009 _mesa_init_attrib( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001010#endif
Brian Paul148a2842003-09-17 03:40:11 +00001011 _mesa_init_buffer_objects( ctx );
Keith Whitwell6dc85572003-07-17 13:43:59 +00001012 _mesa_init_color( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001013#if FEATURE_colortable
Brian Paul05944c02003-07-22 03:51:46 +00001014 _mesa_init_colortables( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001015#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +00001016 _mesa_init_current( ctx );
1017 _mesa_init_depth( ctx );
1018 _mesa_init_debug( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001019#if FEATURE_dlist
Keith Whitwell6dc85572003-07-17 13:43:59 +00001020 _mesa_init_display_list( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001021#endif
1022#if FEATURE_evaluators
Keith Whitwell6dc85572003-07-17 13:43:59 +00001023 _mesa_init_eval( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001024#endif
Brian Paul3dc65912008-07-03 15:40:38 -06001025 _mesa_init_fbobjects( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001026#if FEATURE_feedback
Keith Whitwell6dc85572003-07-17 13:43:59 +00001027 _mesa_init_feedback( ctx );
Brian Paulc1156162008-06-20 14:29:49 -06001028#else
1029 ctx->RenderMode = GL_RENDER;
Keith Whitwell34a61c62008-09-21 19:29:15 -07001030#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +00001031 _mesa_init_fog( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001032#if FEATURE_histogram
Keith Whitwell6dc85572003-07-17 13:43:59 +00001033 _mesa_init_histogram( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001034#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +00001035 _mesa_init_hint( ctx );
1036 _mesa_init_line( ctx );
1037 _mesa_init_lighting( ctx );
1038 _mesa_init_matrix( ctx );
Brian Paul67742382005-02-26 17:16:12 +00001039 _mesa_init_multisample( ctx );
Keith Whitwell6dc85572003-07-17 13:43:59 +00001040 _mesa_init_pixel( ctx );
Brian Paul533c1db2008-06-09 14:25:23 -06001041 _mesa_init_pixelstore( ctx );
Keith Whitwell6dc85572003-07-17 13:43:59 +00001042 _mesa_init_point( ctx );
1043 _mesa_init_polygon( ctx );
Brian Paul05944c02003-07-22 03:51:46 +00001044 _mesa_init_program( ctx );
Brian Paul4e3ae762008-06-13 13:56:53 -06001045#if FEATURE_ARB_occlusion_query
Brian Paul4fb99502005-09-02 13:42:49 +00001046 _mesa_init_query( ctx );
Brian Paul4e3ae762008-06-13 13:56:53 -06001047#endif
Keith Whitwell34a61c62008-09-21 19:29:15 -07001048#if FEATURE_drawpix
Brian Paulddc82ee2005-02-05 19:56:45 +00001049 _mesa_init_rastpos( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001050#endif
Brian Paul67742382005-02-26 17:16:12 +00001051 _mesa_init_scissor( ctx );
Brian0bf5dbe2006-12-19 18:02:41 -07001052 _mesa_init_shader_state( ctx );
Keith Whitwell6dc85572003-07-17 13:43:59 +00001053 _mesa_init_stencil( ctx );
1054 _mesa_init_transform( ctx );
1055 _mesa_init_varray( ctx );
1056 _mesa_init_viewport( ctx );
jtgafb833d1999-08-19 00:55:39 +00001057
Keith Whitwell6dc85572003-07-17 13:43:59 +00001058 if (!_mesa_init_texture( ctx ))
1059 return GL_FALSE;
Brian Paulb17a7222003-06-13 02:37:27 +00001060
Keith Whitwell34a61c62008-09-21 19:29:15 -07001061#if FEATURE_texture_s3tc
Brian Paul8f04c122004-04-27 13:39:20 +00001062 _mesa_init_texture_s3tc( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001063#endif
1064#if FEATURE_texture_fxt1
Brian Paul8f04c122004-04-27 13:39:20 +00001065 _mesa_init_texture_fxt1( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001066#endif
Brian Paul8f04c122004-04-27 13:39:20 +00001067
Brian Paul4d053dd2000-01-14 04:45:47 +00001068 /* Miscellaneous */
Keith Whitwella96308c2000-10-30 13:31:59 +00001069 ctx->NewState = _NEW_ALL;
Brian Paul4d053dd2000-01-14 04:45:47 +00001070 ctx->ErrorValue = (GLenum) GL_NO_ERROR;
Keith Whitwell568e96b2008-10-14 14:15:26 +01001071 ctx->varying_vp_inputs = ~0;
Brian Paul4d053dd2000-01-14 04:45:47 +00001072
Brian Paula3f13702003-04-01 16:41:50 +00001073 return GL_TRUE;
jtgafb833d1999-08-19 00:55:39 +00001074}
1075
1076
Brian Paulf44898c2003-07-18 15:44:57 +00001077/**
Brian4b654d42007-08-23 08:53:43 +01001078 * Update default objects in a GL context with respect to shared state.
1079 *
1080 * \param ctx GL context.
1081 *
1082 * Removes references to old default objects, (texture objects, program
1083 * objects, etc.) and changes to reference those from the current shared
1084 * state.
1085 */
1086static GLboolean
1087update_default_objects(GLcontext *ctx)
1088{
1089 assert(ctx);
1090
1091 _mesa_update_default_objects_program(ctx);
1092 _mesa_update_default_objects_texture(ctx);
1093 _mesa_update_default_objects_buffer_objects(ctx);
1094
1095 return GL_TRUE;
1096}
1097
1098
1099/**
Brian Paul21f69782004-11-27 05:05:32 +00001100 * This is the default function we plug into all dispatch table slots
1101 * This helps prevents a segfault when someone calls a GL function without
1102 * first checking if the extension's supported.
1103 */
1104static int
1105generic_nop(void)
1106{
Briancf239ce2007-06-11 10:57:01 -06001107 _mesa_warning(NULL, "User called no-op dispatch function (an unsupported extension function?)");
Brian Paul21f69782004-11-27 05:05:32 +00001108 return 0;
1109}
1110
1111
1112/**
1113 * Allocate and initialize a new dispatch table.
1114 */
1115static struct _glapi_table *
1116alloc_dispatch_table(void)
1117{
1118 /* Find the larger of Mesa's dispatch table and libGL's dispatch table.
1119 * In practice, this'll be the same for stand-alone Mesa. But for DRI
1120 * Mesa we do this to accomodate different versions of libGL and various
1121 * DRI drivers.
1122 */
1123 GLint numEntries = MAX2(_glapi_get_dispatch_table_size(),
1124 sizeof(struct _glapi_table) / sizeof(_glapi_proc));
1125 struct _glapi_table *table =
1126 (struct _glapi_table *) _mesa_malloc(numEntries * sizeof(_glapi_proc));
1127 if (table) {
1128 _glapi_proc *entry = (_glapi_proc *) table;
Brian Paula760ccf2004-12-03 15:24:34 +00001129 GLint i;
Brian Paul21f69782004-11-27 05:05:32 +00001130 for (i = 0; i < numEntries; i++) {
1131 entry[i] = (_glapi_proc) generic_nop;
1132 }
1133 }
1134 return table;
1135}
1136
1137
1138/**
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001139 * Initialize a GLcontext struct (rendering context).
Keith Whitwell6dc85572003-07-17 13:43:59 +00001140 *
1141 * This includes allocating all the other structs and arrays which hang off of
1142 * the context by pointers.
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001143 * Note that the driver needs to pass in its dd_function_table here since
1144 * we need to at least call driverFunctions->NewTextureObject to create the
1145 * default texture objects.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001146 *
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001147 * Called by _mesa_create_context().
Keith Whitwell6dc85572003-07-17 13:43:59 +00001148 *
1149 * Performs the imports and exports callback tables initialization, and
1150 * miscellaneous one-time initializations. If no shared context is supplied one
1151 * is allocated, and increase its reference count. Setups the GL API dispatch
1152 * tables. Initialize the TNL module. Sets the maximum Z buffer depth.
1153 * Finally queries the \c MESA_DEBUG and \c MESA_VERBOSE environment variables
1154 * for debug flags.
1155 *
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001156 * \param ctx the context to initialize
1157 * \param visual describes the visual attributes for this context
1158 * \param share_list points to context to share textures, display lists,
1159 * etc with, or NULL
1160 * \param driverFunctions table of device driver functions for this context
1161 * to use
1162 * \param driverContext pointer to driver-specific context data
jtgafb833d1999-08-19 00:55:39 +00001163 */
Brian Paul178a1c52000-04-22 01:05:00 +00001164GLboolean
Briand881a9c2006-12-20 09:31:07 -07001165_mesa_initialize_context(GLcontext *ctx,
1166 const GLvisual *visual,
1167 GLcontext *share_list,
1168 const struct dd_function_table *driverFunctions,
1169 void *driverContext)
jtgafb833d1999-08-19 00:55:39 +00001170{
Brian7cafaff2007-11-01 14:51:37 -06001171 /*ASSERT(driverContext);*/
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001172 assert(driverFunctions->NewTextureObject);
Keith Whitwell3e62d3a2005-03-22 14:27:10 +00001173 assert(driverFunctions->FreeTexImageData);
jtgafb833d1999-08-19 00:55:39 +00001174
Brian Paul4753d602002-06-15 02:38:15 +00001175 /* misc one-time initializations */
1176 one_time_init(ctx);
Brian Paul9a33a112002-06-13 04:28:29 +00001177
Brian Paulb1394fa2000-09-26 20:53:53 +00001178 ctx->Visual = *visual;
Brian Paul3f02f901999-11-24 18:48:30 +00001179 ctx->DrawBuffer = NULL;
1180 ctx->ReadBuffer = NULL;
Brian Paule4b23562005-05-04 20:11:35 +00001181 ctx->WinSysDrawBuffer = NULL;
1182 ctx->WinSysReadBuffer = NULL;
Jouk Jansen5e3bc0c2000-11-22 07:32:16 +00001183
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001184 /* Plug in driver functions and context pointer here.
1185 * This is important because when we call alloc_shared_state() below
1186 * we'll call ctx->Driver.NewTextureObject() to create the default
1187 * textures.
Brian Paula3f13702003-04-01 16:41:50 +00001188 */
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001189 ctx->Driver = *driverFunctions;
1190 ctx->DriverCtx = driverContext;
Brian Paula3f13702003-04-01 16:41:50 +00001191
jtgafb833d1999-08-19 00:55:39 +00001192 if (share_list) {
Brian Paul5a2f32b2001-04-25 18:21:05 +00001193 /* share state with another context */
jtgafb833d1999-08-19 00:55:39 +00001194 ctx->Shared = share_list->Shared;
1195 }
1196 else {
Brian Paul5a2f32b2001-04-25 18:21:05 +00001197 /* allocate new, unshared state */
Brian Paula3f13702003-04-01 16:41:50 +00001198 if (!alloc_shared_state( ctx )) {
Brian Paul4d053dd2000-01-14 04:45:47 +00001199 return GL_FALSE;
jtgafb833d1999-08-19 00:55:39 +00001200 }
1201 }
Brian Paul9560f052000-01-31 23:11:39 +00001202 _glthread_LOCK_MUTEX(ctx->Shared->Mutex);
jtgafb833d1999-08-19 00:55:39 +00001203 ctx->Shared->RefCount++;
Brian Paul9560f052000-01-31 23:11:39 +00001204 _glthread_UNLOCK_MUTEX(ctx->Shared->Mutex);
jtgafb833d1999-08-19 00:55:39 +00001205
Keith Whitwell6dc85572003-07-17 13:43:59 +00001206 if (!init_attrib_groups( ctx )) {
jtgafb833d1999-08-19 00:55:39 +00001207 free_shared_state(ctx, ctx->Shared);
Brian Paul4d053dd2000-01-14 04:45:47 +00001208 return GL_FALSE;
jtgafb833d1999-08-19 00:55:39 +00001209 }
jtgafb833d1999-08-19 00:55:39 +00001210
Brian Paul21f69782004-11-27 05:05:32 +00001211 /* setup the API dispatch tables */
1212 ctx->Exec = alloc_dispatch_table();
1213 ctx->Save = alloc_dispatch_table();
Brian Paul3ab6bbe2000-02-12 17:26:15 +00001214 if (!ctx->Exec || !ctx->Save) {
1215 free_shared_state(ctx, ctx->Shared);
Brian Paul3ab6bbe2000-02-12 17:26:15 +00001216 if (ctx->Exec)
Brian Paul21f69782004-11-27 05:05:32 +00001217 _mesa_free(ctx->Exec);
Brian Paul3ab6bbe2000-02-12 17:26:15 +00001218 }
Brian Paulcd4d4f52008-06-17 16:56:32 -06001219#if FEATURE_dispatch
Brian Paul21f69782004-11-27 05:05:32 +00001220 _mesa_init_exec_table(ctx->Exec);
Brian Paulcd4d4f52008-06-17 16:56:32 -06001221#endif
Brian Paul3ab6bbe2000-02-12 17:26:15 +00001222 ctx->CurrentDispatch = ctx->Exec;
Keith Whitwell34a61c62008-09-21 19:29:15 -07001223#if FEATURE_dlist
Brian Paul21f69782004-11-27 05:05:32 +00001224 _mesa_init_dlist_table(ctx->Save);
Keith Whitwellae0eaf92003-11-24 15:23:18 +00001225 _mesa_install_save_vtxfmt( ctx, &ctx->ListState.ListVtxfmt );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001226#endif
Gareth Hughesd8aa0262001-03-11 18:49:11 +00001227 /* Neutral tnl module stuff */
Keith Whitwell6dc85572003-07-17 13:43:59 +00001228 _mesa_init_exec_vtxfmt( ctx );
Gareth Hughesd8aa0262001-03-11 18:49:11 +00001229 ctx->TnlModule.Current = NULL;
1230 ctx->TnlModule.SwapCount = 0;
Brian Paulb6bcae52001-01-23 23:39:36 +00001231
Brian3e45db62007-03-27 09:51:52 -06001232 ctx->FragmentProgram._MaintainTexEnvProgram
1233 = (_mesa_getenv("MESA_TEX_PROG") != NULL);
Brian3e45db62007-03-27 09:51:52 -06001234
Briana90046f2006-12-15 10:07:26 -07001235 ctx->VertexProgram._MaintainTnlProgram
1236 = (_mesa_getenv("MESA_TNL_PROG") != NULL);
Brian3e45db62007-03-27 09:51:52 -06001237 if (ctx->VertexProgram._MaintainTnlProgram) {
Briana90046f2006-12-15 10:07:26 -07001238 /* this is required... */
1239 ctx->FragmentProgram._MaintainTexEnvProgram = GL_TRUE;
Brian3e45db62007-03-27 09:51:52 -06001240 }
Keith Whitwell47b29f52005-05-04 11:44:44 +00001241
Brian Paul6fd15dd2008-08-19 18:14:15 -06001242#ifdef FEATURE_extra_context_init
1243 _mesa_initialize_context_extra(ctx);
1244#endif
1245
Brian Paula96f8892005-09-13 01:19:29 +00001246 ctx->FirstTimeCurrent = GL_TRUE;
1247
Brian Paul4d053dd2000-01-14 04:45:47 +00001248 return GL_TRUE;
jtgafb833d1999-08-19 00:55:39 +00001249}
1250
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001251
Brian Paulde4f4602003-07-03 02:15:06 +00001252/**
Brian Paul4d053dd2000-01-14 04:45:47 +00001253 * Allocate and initialize a GLcontext structure.
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001254 * Note that the driver needs to pass in its dd_function_table here since
1255 * we need to at least call driverFunctions->NewTextureObject to initialize
1256 * the rendering context.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001257 *
1258 * \param visual a GLvisual pointer (we copy the struct contents)
1259 * \param share_list another context to share display lists with or NULL
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001260 * \param driverFunctions points to the dd_function_table into which the
1261 * driver has plugged in all its special functions.
1262 * \param driverCtx points to the device driver's private context state
Keith Whitwell6dc85572003-07-17 13:43:59 +00001263 *
1264 * \return pointer to a new __GLcontextRec or NULL if error.
Brian Paul4d053dd2000-01-14 04:45:47 +00001265 */
Brian Paul178a1c52000-04-22 01:05:00 +00001266GLcontext *
Briand881a9c2006-12-20 09:31:07 -07001267_mesa_create_context(const GLvisual *visual,
1268 GLcontext *share_list,
1269 const struct dd_function_table *driverFunctions,
1270 void *driverContext)
Brian Paul4d053dd2000-01-14 04:45:47 +00001271{
Brian Paul4753d602002-06-15 02:38:15 +00001272 GLcontext *ctx;
1273
1274 ASSERT(visual);
Brian7cafaff2007-11-01 14:51:37 -06001275 /*ASSERT(driverContext);*/
Brian Paul4753d602002-06-15 02:38:15 +00001276
Brian Paul3c634522002-10-24 23:57:19 +00001277 ctx = (GLcontext *) _mesa_calloc(sizeof(GLcontext));
Brian Paul4753d602002-06-15 02:38:15 +00001278 if (!ctx)
Brian Paul4d053dd2000-01-14 04:45:47 +00001279 return NULL;
Brian Paul4753d602002-06-15 02:38:15 +00001280
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001281 if (_mesa_initialize_context(ctx, visual, share_list,
1282 driverFunctions, driverContext)) {
Brian Paul4d053dd2000-01-14 04:45:47 +00001283 return ctx;
1284 }
1285 else {
Brian Paul3c634522002-10-24 23:57:19 +00001286 _mesa_free(ctx);
Brian Paul4d053dd2000-01-14 04:45:47 +00001287 return NULL;
1288 }
1289}
1290
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001291
Keith Whitwell6dc85572003-07-17 13:43:59 +00001292/**
Brian Paul4d053dd2000-01-14 04:45:47 +00001293 * Free the data associated with the given context.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001294 *
1295 * But doesn't free the GLcontext struct itself.
1296 *
1297 * \sa _mesa_initialize_context() and init_attrib_groups().
Brian Paul4d053dd2000-01-14 04:45:47 +00001298 */
Brian Paul178a1c52000-04-22 01:05:00 +00001299void
Brian Paulb1394fa2000-09-26 20:53:53 +00001300_mesa_free_context_data( GLcontext *ctx )
Brian Paul4d053dd2000-01-14 04:45:47 +00001301{
Briandc732172007-08-14 11:56:59 +01001302 if (!_mesa_get_current_context()){
1303 /* No current context, but we may need one in order to delete
1304 * texture objs, etc. So temporarily bind the context now.
1305 */
1306 _mesa_make_current(ctx, NULL, NULL);
Brian Paul4d053dd2000-01-14 04:45:47 +00001307 }
Briandc732172007-08-14 11:56:59 +01001308
1309 /* unreference WinSysDraw/Read buffers */
Brian Pauld5229442009-02-09 08:30:55 -07001310 _mesa_reference_framebuffer(&ctx->WinSysDrawBuffer, NULL);
1311 _mesa_reference_framebuffer(&ctx->WinSysReadBuffer, NULL);
1312 _mesa_reference_framebuffer(&ctx->DrawBuffer, NULL);
1313 _mesa_reference_framebuffer(&ctx->ReadBuffer, NULL);
Brian Paul4d053dd2000-01-14 04:45:47 +00001314
Briandf43fb62008-05-06 23:08:51 -06001315 _mesa_reference_vertprog(ctx, &ctx->VertexProgram.Current, NULL);
1316 _mesa_reference_vertprog(ctx, &ctx->VertexProgram._Current, NULL);
1317 _mesa_reference_vertprog(ctx, &ctx->VertexProgram._TnlProgram, NULL);
1318
1319 _mesa_reference_fragprog(ctx, &ctx->FragmentProgram.Current, NULL);
1320 _mesa_reference_fragprog(ctx, &ctx->FragmentProgram._Current, NULL);
1321 _mesa_reference_fragprog(ctx, &ctx->FragmentProgram._TexEnvProgram, NULL);
1322
Alan Hourihane13e7e4b2008-09-19 14:55:49 +01001323#if FEATURE_attrib_stack
Brian145d7622007-08-16 10:05:00 +01001324 _mesa_free_attrib_data(ctx);
Alan Hourihane13e7e4b2008-09-19 14:55:49 +01001325#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +00001326 _mesa_free_lighting_data( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001327#if FEATURE_evaluators
Keith Whitwell6dc85572003-07-17 13:43:59 +00001328 _mesa_free_eval_data( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001329#endif
Keith Whitwell6dc85572003-07-17 13:43:59 +00001330 _mesa_free_texture_data( ctx );
1331 _mesa_free_matrix_data( ctx );
1332 _mesa_free_viewport_data( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001333#if FEATURE_colortable
Brian Paul05944c02003-07-22 03:51:46 +00001334 _mesa_free_colortables_data( ctx );
Keith Whitwell34a61c62008-09-21 19:29:15 -07001335#endif
Brian Paul21841f02004-08-14 14:28:11 +00001336 _mesa_free_program_data(ctx);
Brian935f93f2007-03-24 16:20:02 -06001337 _mesa_free_shader_state(ctx);
Brian Paul4e3ae762008-06-13 13:56:53 -06001338#if FEATURE_ARB_occlusion_query
Brian Paul4fb99502005-09-02 13:42:49 +00001339 _mesa_free_query_data(ctx);
Brian Paul4e3ae762008-06-13 13:56:53 -06001340#endif
Brian Paul21841f02004-08-14 14:28:11 +00001341
1342#if FEATURE_ARB_vertex_buffer_object
1343 _mesa_delete_buffer_object(ctx, ctx->Array.NullBufferObj);
Brian Paul8dfc5b92002-10-16 17:57:51 +00001344#endif
Brian Paulc04bb512006-07-11 21:56:43 +00001345 _mesa_delete_array_object(ctx, ctx->Array.DefaultArrayObj);
Brian Paulfd284452001-07-19 15:54:34 +00001346
Brian Paul65a66f52004-11-27 22:47:59 +00001347 /* free dispatch tables */
1348 _mesa_free(ctx->Exec);
1349 _mesa_free(ctx->Save);
1350
Brian Paul30f51ae2001-12-18 04:06:44 +00001351 /* Shared context state (display lists, textures, etc) */
Brian Paul9560f052000-01-31 23:11:39 +00001352 _glthread_LOCK_MUTEX(ctx->Shared->Mutex);
Brian Paul4d053dd2000-01-14 04:45:47 +00001353 ctx->Shared->RefCount--;
Brian Paul9560f052000-01-31 23:11:39 +00001354 assert(ctx->Shared->RefCount >= 0);
1355 _glthread_UNLOCK_MUTEX(ctx->Shared->Mutex);
1356 if (ctx->Shared->RefCount == 0) {
Brian Paul4d053dd2000-01-14 04:45:47 +00001357 /* free shared state */
1358 free_shared_state( ctx, ctx->Shared );
1359 }
1360
Brian Paul702ca202003-07-18 15:22:16 +00001361 if (ctx->Extensions.String)
Brian Paulc7e164f2006-06-30 15:44:30 +00001362 _mesa_free((void *) ctx->Extensions.String);
Briandc732172007-08-14 11:56:59 +01001363
1364 /* unbind the context if it's currently bound */
1365 if (ctx == _mesa_get_current_context()) {
1366 _mesa_make_current(NULL, NULL, NULL);
1367 }
Brian Paul4d053dd2000-01-14 04:45:47 +00001368}
1369
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001370
Keith Whitwell6dc85572003-07-17 13:43:59 +00001371/**
Brian Paul4d053dd2000-01-14 04:45:47 +00001372 * Destroy a GLcontext structure.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001373 *
1374 * \param ctx GL context.
1375 *
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001376 * Calls _mesa_free_context_data() and frees the GLcontext structure itself.
jtgafb833d1999-08-19 00:55:39 +00001377 */
Brian Paul178a1c52000-04-22 01:05:00 +00001378void
Brian Paulb1394fa2000-09-26 20:53:53 +00001379_mesa_destroy_context( GLcontext *ctx )
jtgafb833d1999-08-19 00:55:39 +00001380{
1381 if (ctx) {
Brian Paulb1394fa2000-09-26 20:53:53 +00001382 _mesa_free_context_data(ctx);
Brian Paulc7e164f2006-06-30 15:44:30 +00001383 _mesa_free( (void *) ctx );
jtgafb833d1999-08-19 00:55:39 +00001384 }
1385}
1386
Brian Pauld3fd7ba2004-01-20 02:49:27 +00001387
Keith Whitwell6dc85572003-07-17 13:43:59 +00001388#if _HAVE_FULL_GL
1389/**
jtgafb833d1999-08-19 00:55:39 +00001390 * Copy attribute groups from one context to another.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001391 *
1392 * \param src source context
1393 * \param dst destination context
1394 * \param mask bitwise OR of GL_*_BIT flags
1395 *
1396 * According to the bits specified in \p mask, copies the corresponding
Jose Fonseca375457b2004-09-09 22:23:24 +00001397 * attributes from \p src into \p dst. For many of the attributes a simple \c
Keith Whitwell6dc85572003-07-17 13:43:59 +00001398 * memcpy is not enough due to the existence of internal pointers in their data
1399 * structures.
jtgafb833d1999-08-19 00:55:39 +00001400 */
Brian Paul178a1c52000-04-22 01:05:00 +00001401void
Brian Paulb1394fa2000-09-26 20:53:53 +00001402_mesa_copy_context( const GLcontext *src, GLcontext *dst, GLuint mask )
jtgafb833d1999-08-19 00:55:39 +00001403{
1404 if (mask & GL_ACCUM_BUFFER_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001405 /* OK to memcpy */
1406 dst->Accum = src->Accum;
jtgafb833d1999-08-19 00:55:39 +00001407 }
1408 if (mask & GL_COLOR_BUFFER_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001409 /* OK to memcpy */
1410 dst->Color = src->Color;
jtgafb833d1999-08-19 00:55:39 +00001411 }
1412 if (mask & GL_CURRENT_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001413 /* OK to memcpy */
1414 dst->Current = src->Current;
jtgafb833d1999-08-19 00:55:39 +00001415 }
1416 if (mask & GL_DEPTH_BUFFER_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001417 /* OK to memcpy */
1418 dst->Depth = src->Depth;
jtgafb833d1999-08-19 00:55:39 +00001419 }
1420 if (mask & GL_ENABLE_BIT) {
1421 /* no op */
1422 }
1423 if (mask & GL_EVAL_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001424 /* OK to memcpy */
1425 dst->Eval = src->Eval;
jtgafb833d1999-08-19 00:55:39 +00001426 }
1427 if (mask & GL_FOG_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001428 /* OK to memcpy */
1429 dst->Fog = src->Fog;
jtgafb833d1999-08-19 00:55:39 +00001430 }
1431 if (mask & GL_HINT_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001432 /* OK to memcpy */
1433 dst->Hint = src->Hint;
jtgafb833d1999-08-19 00:55:39 +00001434 }
1435 if (mask & GL_LIGHTING_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001436 GLuint i;
1437 /* begin with memcpy */
Brian Paul2aabdc72006-02-24 18:19:11 +00001438 dst->Light = src->Light;
Brian Paul85d81602002-06-17 23:36:31 +00001439 /* fixup linked lists to prevent pointer insanity */
1440 make_empty_list( &(dst->Light.EnabledList) );
1441 for (i = 0; i < MAX_LIGHTS; i++) {
1442 if (dst->Light.Light[i].Enabled) {
1443 insert_at_tail(&(dst->Light.EnabledList), &(dst->Light.Light[i]));
1444 }
1445 }
jtgafb833d1999-08-19 00:55:39 +00001446 }
1447 if (mask & GL_LINE_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001448 /* OK to memcpy */
1449 dst->Line = src->Line;
jtgafb833d1999-08-19 00:55:39 +00001450 }
1451 if (mask & GL_LIST_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001452 /* OK to memcpy */
1453 dst->List = src->List;
jtgafb833d1999-08-19 00:55:39 +00001454 }
1455 if (mask & GL_PIXEL_MODE_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001456 /* OK to memcpy */
1457 dst->Pixel = src->Pixel;
jtgafb833d1999-08-19 00:55:39 +00001458 }
1459 if (mask & GL_POINT_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001460 /* OK to memcpy */
1461 dst->Point = src->Point;
jtgafb833d1999-08-19 00:55:39 +00001462 }
1463 if (mask & GL_POLYGON_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001464 /* OK to memcpy */
1465 dst->Polygon = src->Polygon;
jtgafb833d1999-08-19 00:55:39 +00001466 }
1467 if (mask & GL_POLYGON_STIPPLE_BIT) {
1468 /* Use loop instead of MEMCPY due to problem with Portland Group's
1469 * C compiler. Reported by John Stone.
1470 */
Brian Paul85d81602002-06-17 23:36:31 +00001471 GLuint i;
1472 for (i = 0; i < 32; i++) {
jtgafb833d1999-08-19 00:55:39 +00001473 dst->PolygonStipple[i] = src->PolygonStipple[i];
1474 }
1475 }
1476 if (mask & GL_SCISSOR_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001477 /* OK to memcpy */
1478 dst->Scissor = src->Scissor;
jtgafb833d1999-08-19 00:55:39 +00001479 }
1480 if (mask & GL_STENCIL_BUFFER_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001481 /* OK to memcpy */
1482 dst->Stencil = src->Stencil;
jtgafb833d1999-08-19 00:55:39 +00001483 }
1484 if (mask & GL_TEXTURE_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001485 /* Cannot memcpy because of pointers */
1486 _mesa_copy_texture_state(src, dst);
jtgafb833d1999-08-19 00:55:39 +00001487 }
1488 if (mask & GL_TRANSFORM_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001489 /* OK to memcpy */
1490 dst->Transform = src->Transform;
jtgafb833d1999-08-19 00:55:39 +00001491 }
1492 if (mask & GL_VIEWPORT_BIT) {
Brian Paul85d81602002-06-17 23:36:31 +00001493 /* Cannot use memcpy, because of pointers in GLmatrix _WindowMap */
1494 dst->Viewport.X = src->Viewport.X;
1495 dst->Viewport.Y = src->Viewport.Y;
1496 dst->Viewport.Width = src->Viewport.Width;
1497 dst->Viewport.Height = src->Viewport.Height;
1498 dst->Viewport.Near = src->Viewport.Near;
1499 dst->Viewport.Far = src->Viewport.Far;
1500 _math_matrix_copy(&dst->Viewport._WindowMap, &src->Viewport._WindowMap);
jtgafb833d1999-08-19 00:55:39 +00001501 }
Brian Paul85d81602002-06-17 23:36:31 +00001502
Keith Whitwella96308c2000-10-30 13:31:59 +00001503 /* XXX FIXME: Call callbacks?
1504 */
1505 dst->NewState = _NEW_ALL;
jtgafb833d1999-08-19 00:55:39 +00001506}
Keith Whitwell23caf202000-11-16 21:05:34 +00001507#endif
Keith Whitwell23caf202000-11-16 21:05:34 +00001508
1509
Brian Paulb1d53d92003-06-11 18:48:19 +00001510/**
1511 * Check if the given context can render into the given framebuffer
1512 * by checking visual attributes.
Brian Paulca007cb2006-03-07 03:01:26 +00001513 *
Brianee170f22007-06-08 14:12:27 -06001514 * Most of these tests could go away because Mesa is now pretty flexible
1515 * in terms of mixing rendering contexts with framebuffers. As long
1516 * as RGB vs. CI mode agree, we're probably good.
Brian Paulca007cb2006-03-07 03:01:26 +00001517 *
Brian Paulb1d53d92003-06-11 18:48:19 +00001518 * \return GL_TRUE if compatible, GL_FALSE otherwise.
1519 */
1520static GLboolean
1521check_compatible(const GLcontext *ctx, const GLframebuffer *buffer)
1522{
1523 const GLvisual *ctxvis = &ctx->Visual;
1524 const GLvisual *bufvis = &buffer->Visual;
1525
1526 if (ctxvis == bufvis)
1527 return GL_TRUE;
1528
1529 if (ctxvis->rgbMode != bufvis->rgbMode)
1530 return GL_FALSE;
Brian Pauld75963d2006-03-07 02:57:04 +00001531#if 0
1532 /* disabling this fixes the fgl_glxgears pbuffer demo */
Brian Paulb1d53d92003-06-11 18:48:19 +00001533 if (ctxvis->doubleBufferMode && !bufvis->doubleBufferMode)
1534 return GL_FALSE;
Brian Pauld75963d2006-03-07 02:57:04 +00001535#endif
Brian Paulb1d53d92003-06-11 18:48:19 +00001536 if (ctxvis->stereoMode && !bufvis->stereoMode)
1537 return GL_FALSE;
1538 if (ctxvis->haveAccumBuffer && !bufvis->haveAccumBuffer)
1539 return GL_FALSE;
1540 if (ctxvis->haveDepthBuffer && !bufvis->haveDepthBuffer)
1541 return GL_FALSE;
1542 if (ctxvis->haveStencilBuffer && !bufvis->haveStencilBuffer)
1543 return GL_FALSE;
1544 if (ctxvis->redMask && ctxvis->redMask != bufvis->redMask)
1545 return GL_FALSE;
1546 if (ctxvis->greenMask && ctxvis->greenMask != bufvis->greenMask)
1547 return GL_FALSE;
1548 if (ctxvis->blueMask && ctxvis->blueMask != bufvis->blueMask)
1549 return GL_FALSE;
Brianee170f22007-06-08 14:12:27 -06001550#if 0
1551 /* disabled (see bug 11161) */
Brian Paulb1d53d92003-06-11 18:48:19 +00001552 if (ctxvis->depthBits && ctxvis->depthBits != bufvis->depthBits)
1553 return GL_FALSE;
Brianee170f22007-06-08 14:12:27 -06001554#endif
Brian Paulb1d53d92003-06-11 18:48:19 +00001555 if (ctxvis->stencilBits && ctxvis->stencilBits != bufvis->stencilBits)
1556 return GL_FALSE;
1557
1558 return GL_TRUE;
1559}
1560
1561
Keith Whitwell6dc85572003-07-17 13:43:59 +00001562/**
Brian Paula702bbf2005-09-14 03:11:36 +00001563 * Do one-time initialization for the given framebuffer. Specifically,
1564 * ask the driver for the window's current size and update the framebuffer
1565 * object to match.
1566 * Really, the device driver should totally take care of this.
1567 */
1568static void
1569initialize_framebuffer_size(GLcontext *ctx, GLframebuffer *fb)
1570{
1571 GLuint width, height;
Brian Paul55e42e52006-10-17 17:43:47 +00001572 if (ctx->Driver.GetBufferSize) {
1573 ctx->Driver.GetBufferSize(fb, &width, &height);
1574 if (ctx->Driver.ResizeBuffers)
1575 ctx->Driver.ResizeBuffers(ctx, fb, width, height);
1576 fb->Initialized = GL_TRUE;
1577 }
Brian Paula702bbf2005-09-14 03:11:36 +00001578}
1579
1580
1581/**
1582 * Bind the given context to the given drawBuffer and readBuffer and
1583 * make it the current context for the calling thread.
1584 * We'll render into the drawBuffer and read pixels from the
1585 * readBuffer (i.e. glRead/CopyPixels, glCopyTexImage, etc).
Keith Whitwell6dc85572003-07-17 13:43:59 +00001586 *
Brian Paula702bbf2005-09-14 03:11:36 +00001587 * We check that the context's and framebuffer's visuals are compatible
1588 * and return immediately if they're not.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001589 *
Brian Paula702bbf2005-09-14 03:11:36 +00001590 * \param newCtx the new GL context. If NULL then there will be no current GL
1591 * context.
1592 * \param drawBuffer the drawing framebuffer
1593 * \param readBuffer the reading framebuffer
Brian Paul00037781999-12-17 14:52:35 +00001594 */
Brian Paulb1394fa2000-09-26 20:53:53 +00001595void
Brian Paule4b23562005-05-04 20:11:35 +00001596_mesa_make_current( GLcontext *newCtx, GLframebuffer *drawBuffer,
1597 GLframebuffer *readBuffer )
Brian Paul00037781999-12-17 14:52:35 +00001598{
Keith Whitwell5c728372005-05-12 10:22:29 +00001599 if (MESA_VERBOSE & VERBOSE_API)
Brian Paule4b23562005-05-04 20:11:35 +00001600 _mesa_debug(newCtx, "_mesa_make_current()\n");
Brian Paul00037781999-12-17 14:52:35 +00001601
Brian Paulbe3602d2001-02-28 00:27:48 +00001602 /* Check that the context's and framebuffer's visuals are compatible.
Brian Paulbe3602d2001-02-28 00:27:48 +00001603 */
Brian Paulf1038f82006-03-20 15:20:57 +00001604 if (newCtx && drawBuffer && newCtx->WinSysDrawBuffer != drawBuffer) {
Brian Pauld75963d2006-03-07 02:57:04 +00001605 if (!check_compatible(newCtx, drawBuffer)) {
1606 _mesa_warning(newCtx,
1607 "MakeCurrent: incompatible visuals for context and drawbuffer");
Brian Paulb1d53d92003-06-11 18:48:19 +00001608 return;
Brian Pauld75963d2006-03-07 02:57:04 +00001609 }
Brian Paulb1d53d92003-06-11 18:48:19 +00001610 }
Brian Paulf1038f82006-03-20 15:20:57 +00001611 if (newCtx && readBuffer && newCtx->WinSysReadBuffer != readBuffer) {
Brian Pauld75963d2006-03-07 02:57:04 +00001612 if (!check_compatible(newCtx, readBuffer)) {
1613 _mesa_warning(newCtx,
1614 "MakeCurrent: incompatible visuals for context and readbuffer");
Brian Paulb1d53d92003-06-11 18:48:19 +00001615 return;
Brian Pauld75963d2006-03-07 02:57:04 +00001616 }
Brian Paulbe3602d2001-02-28 00:27:48 +00001617 }
1618
Brian Paulc6c0f942006-03-16 18:05:25 +00001619 /* We used to call _glapi_check_multithread() here. Now do it in drivers */
Brian Paulf9b97d92000-01-28 20:17:42 +00001620 _glapi_set_context((void *) newCtx);
Brian Paulb1394fa2000-09-26 20:53:53 +00001621 ASSERT(_mesa_get_current_context() == newCtx);
Keith Whitwell23caf202000-11-16 21:05:34 +00001622
Keith Whitwell23caf202000-11-16 21:05:34 +00001623 if (!newCtx) {
Brian Paul00037781999-12-17 14:52:35 +00001624 _glapi_set_dispatch(NULL); /* none current */
1625 }
Keith Whitwell23caf202000-11-16 21:05:34 +00001626 else {
1627 _glapi_set_dispatch(newCtx->CurrentDispatch);
Brian Paul00037781999-12-17 14:52:35 +00001628
Keith Whitwell23caf202000-11-16 21:05:34 +00001629 if (drawBuffer && readBuffer) {
1630 /* TODO: check if newCtx and buffer's visual match??? */
Brian Paule4b23562005-05-04 20:11:35 +00001631
Brian Paule4b23562005-05-04 20:11:35 +00001632 ASSERT(drawBuffer->Name == 0);
1633 ASSERT(readBuffer->Name == 0);
Briana510bc32007-03-06 10:07:59 -07001634 _mesa_reference_framebuffer(&newCtx->WinSysDrawBuffer, drawBuffer);
1635 _mesa_reference_framebuffer(&newCtx->WinSysReadBuffer, readBuffer);
Brian Paulf1038f82006-03-20 15:20:57 +00001636
1637 /*
1638 * Only set the context's Draw/ReadBuffer fields if they're NULL
1639 * or not bound to a user-created FBO.
1640 */
Brian Paule4b23562005-05-04 20:11:35 +00001641 if (!newCtx->DrawBuffer || newCtx->DrawBuffer->Name == 0) {
Keith Whitwell0397b2b2008-09-11 16:05:15 +01001642 /* KW: merge conflict here, revisit.
1643 */
1644 /* fix up the fb fields - these will end up wrong otherwise
1645 * if the DRIdrawable changes, and everything relies on them.
1646 * This is a bit messy (same as needed in _mesa_BindFramebufferEXT)
1647 */
José Fonseca53174af2008-05-31 18:14:09 +09001648 unsigned int i;
Roland Scheideggercbfe29c2007-07-16 18:21:36 +02001649 GLenum buffers[MAX_DRAW_BUFFERS];
Alan Hourihanee97bedb2008-05-01 14:54:56 +01001650
Roland Scheideggercbfe29c2007-07-16 18:21:36 +02001651 _mesa_reference_framebuffer(&newCtx->DrawBuffer, drawBuffer);
Alan Hourihanee97bedb2008-05-01 14:54:56 +01001652
Roland Scheideggercbfe29c2007-07-16 18:21:36 +02001653 for(i = 0; i < newCtx->Const.MaxDrawBuffers; i++) {
1654 buffers[i] = newCtx->Color.DrawBuffer[i];
1655 }
Alan Hourihanee97bedb2008-05-01 14:54:56 +01001656
Roland Scheideggercbfe29c2007-07-16 18:21:36 +02001657 _mesa_drawbuffers(newCtx, newCtx->Const.MaxDrawBuffers, buffers, NULL);
Brian Paulf1038f82006-03-20 15:20:57 +00001658 }
1659 if (!newCtx->ReadBuffer || newCtx->ReadBuffer->Name == 0) {
Briana510bc32007-03-06 10:07:59 -07001660 _mesa_reference_framebuffer(&newCtx->ReadBuffer, readBuffer);
Brian Paule4b23562005-05-04 20:11:35 +00001661 }
Brian Paulbb5c84f2005-07-01 01:22:25 +00001662
Brian32d86eb2007-08-16 18:52:48 +01001663 /* XXX only set this flag if we're really changing the draw/read
1664 * framebuffer bindings.
1665 */
Keith Whitwell23caf202000-11-16 21:05:34 +00001666 newCtx->NewState |= _NEW_BUFFERS;
Brian Paul10d7f542002-06-17 23:38:14 +00001667
Brian Paul4d4add02006-10-15 19:26:43 +00001668#if 1
1669 /* We want to get rid of these lines: */
1670
Keith Whitwell6dc85572003-07-17 13:43:59 +00001671#if _HAVE_FULL_GL
Brian Paul65a66f52004-11-27 22:47:59 +00001672 if (!drawBuffer->Initialized) {
Brian Paula702bbf2005-09-14 03:11:36 +00001673 initialize_framebuffer_size(newCtx, drawBuffer);
Brian Paul10d7f542002-06-17 23:38:14 +00001674 }
Brian Paul65a66f52004-11-27 22:47:59 +00001675 if (readBuffer != drawBuffer && !readBuffer->Initialized) {
Brian Paula702bbf2005-09-14 03:11:36 +00001676 initialize_framebuffer_size(newCtx, readBuffer);
Brian Paul10d7f542002-06-17 23:38:14 +00001677 }
Keith Whitwellf9bfdb12006-09-22 11:36:30 +00001678
1679 _mesa_resizebuffers(newCtx);
Keith Whitwell6dc85572003-07-17 13:43:59 +00001680#endif
Brian Paul4d4add02006-10-15 19:26:43 +00001681
1682#else
1683 /* We want the drawBuffer and readBuffer to be initialized by
1684 * the driver.
1685 * This generally means the Width and Height match the actual
1686 * window size and the renderbuffers (both hardware and software
1687 * based) are allocated to match. The later can generally be
1688 * done with a call to _mesa_resize_framebuffer().
1689 *
1690 * It's theoretically possible for a buffer to have zero width
1691 * or height, but for now, assert check that the driver did what's
1692 * expected of it.
1693 */
1694 ASSERT(drawBuffer->Width > 0);
1695 ASSERT(drawBuffer->Height > 0);
1696#endif
1697
Brian Paul65a66f52004-11-27 22:47:59 +00001698 if (newCtx->FirstTimeCurrent) {
1699 /* set initial viewport and scissor size now */
Brian Paula702bbf2005-09-14 03:11:36 +00001700 _mesa_set_viewport(newCtx, 0, 0,
1701 drawBuffer->Width, drawBuffer->Height);
Brian Pauldb79d2a2006-03-29 18:41:19 +00001702 _mesa_set_scissor(newCtx, 0, 0,
1703 drawBuffer->Width, drawBuffer->Height );
Brian Paul5e2e96b2006-05-15 15:26:04 +00001704 check_context_limits(newCtx);
Brian Paul65a66f52004-11-27 22:47:59 +00001705 }
Brian Paul00037781999-12-17 14:52:35 +00001706 }
Keith Whitwell23caf202000-11-16 21:05:34 +00001707
Keith Whitwell23caf202000-11-16 21:05:34 +00001708 /* We can use this to help debug user's problems. Tell them to set
1709 * the MESA_INFO env variable before running their app. Then the
1710 * first time each context is made current we'll print some useful
1711 * information.
1712 */
1713 if (newCtx->FirstTimeCurrent) {
Brian Paul3c634522002-10-24 23:57:19 +00001714 if (_mesa_getenv("MESA_INFO")) {
Keith Whitwell6dc85572003-07-17 13:43:59 +00001715 _mesa_print_info();
Keith Whitwell23caf202000-11-16 21:05:34 +00001716 }
1717 newCtx->FirstTimeCurrent = GL_FALSE;
1718 }
Brian Paul00037781999-12-17 14:52:35 +00001719 }
1720}
1721
Brian Paul635ee2d2005-04-15 17:25:07 +00001722
1723/**
1724 * Make context 'ctx' share the display lists, textures and programs
1725 * that are associated with 'ctxToShare'.
1726 * Any display lists, textures or programs associated with 'ctx' will
1727 * be deleted if nobody else is sharing them.
1728 */
1729GLboolean
1730_mesa_share_state(GLcontext *ctx, GLcontext *ctxToShare)
1731{
1732 if (ctx && ctxToShare && ctx->Shared && ctxToShare->Shared) {
Brian4b654d42007-08-23 08:53:43 +01001733 struct gl_shared_state *oldSharedState = ctx->Shared;
1734
Brian Paul635ee2d2005-04-15 17:25:07 +00001735 ctx->Shared = ctxToShare->Shared;
1736 ctx->Shared->RefCount++;
Brian4b654d42007-08-23 08:53:43 +01001737
1738 update_default_objects(ctx);
1739
1740 oldSharedState->RefCount--;
1741 if (oldSharedState->RefCount == 0) {
1742 free_shared_state(ctx, oldSharedState);
1743 }
1744
Brian Paul635ee2d2005-04-15 17:25:07 +00001745 return GL_TRUE;
1746 }
1747 else {
1748 return GL_FALSE;
1749 }
1750}
1751
1752
1753
Keith Whitwell6dc85572003-07-17 13:43:59 +00001754/**
Briand881a9c2006-12-20 09:31:07 -07001755 * \return pointer to the current GL context for this thread.
Keith Whitwell6dc85572003-07-17 13:43:59 +00001756 *
1757 * Calls _glapi_get_context(). This isn't the fastest way to get the current
Briand881a9c2006-12-20 09:31:07 -07001758 * context. If you need speed, see the #GET_CURRENT_CONTEXT macro in
1759 * context.h.
Brian Paul00037781999-12-17 14:52:35 +00001760 */
Brian Paulb1394fa2000-09-26 20:53:53 +00001761GLcontext *
1762_mesa_get_current_context( void )
Brian Paul00037781999-12-17 14:52:35 +00001763{
Brian Paulf9b97d92000-01-28 20:17:42 +00001764 return (GLcontext *) _glapi_get_context();
Brian Paul00037781999-12-17 14:52:35 +00001765}
1766
Briand881a9c2006-12-20 09:31:07 -07001767
Keith Whitwell6dc85572003-07-17 13:43:59 +00001768/**
1769 * Get context's current API dispatch table.
1770 *
1771 * It'll either be the immediate-mode execute dispatcher or the display list
1772 * compile dispatcher.
1773 *
1774 * \param ctx GL context.
1775 *
1776 * \return pointer to dispatch_table.
1777 *
1778 * Simply returns __GLcontextRec::CurrentDispatch.
Brian Paulfbd8f211999-11-11 01:22:25 +00001779 */
1780struct _glapi_table *
1781_mesa_get_dispatch(GLcontext *ctx)
1782{
1783 return ctx->CurrentDispatch;
1784}
1785
Keith Whitwell6dc85572003-07-17 13:43:59 +00001786/*@}*/
Brian Paulfbd8f211999-11-11 01:22:25 +00001787
1788
jtgafb833d1999-08-19 00:55:39 +00001789/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +00001790/** \name Miscellaneous functions */
jtgafb833d1999-08-19 00:55:39 +00001791/**********************************************************************/
Keith Whitwell6dc85572003-07-17 13:43:59 +00001792/*@{*/
jtgafb833d1999-08-19 00:55:39 +00001793
Keith Whitwell6dc85572003-07-17 13:43:59 +00001794/**
1795 * Record an error.
1796 *
1797 * \param ctx GL context.
1798 * \param error error code.
1799 *
1800 * Records the given error code and call the driver's dd_function_table::Error
1801 * function if defined.
1802 *
1803 * \sa
Brian Paul4e9676f2002-06-29 19:48:15 +00001804 * This is called via _mesa_error().
jtgafb833d1999-08-19 00:55:39 +00001805 */
Brian Paulb1394fa2000-09-26 20:53:53 +00001806void
Briand881a9c2006-12-20 09:31:07 -07001807_mesa_record_error(GLcontext *ctx, GLenum error)
jtgafb833d1999-08-19 00:55:39 +00001808{
Brian Paul18a285a2002-03-16 00:53:15 +00001809 if (!ctx)
1810 return;
1811
Brian Paul7eb06032000-07-14 04:13:40 +00001812 if (ctx->ErrorValue == GL_NO_ERROR) {
jtgafb833d1999-08-19 00:55:39 +00001813 ctx->ErrorValue = error;
1814 }
1815
1816 /* Call device driver's error handler, if any. This is used on the Mac. */
1817 if (ctx->Driver.Error) {
Briand881a9c2006-12-20 09:31:07 -07001818 ctx->Driver.Error(ctx);
jtgafb833d1999-08-19 00:55:39 +00001819 }
1820}
1821
Briand881a9c2006-12-20 09:31:07 -07001822
Keith Whitwell6dc85572003-07-17 13:43:59 +00001823/**
1824 * Execute glFinish().
1825 *
1826 * Calls the #ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH macro and the
1827 * dd_function_table::Finish driver callback, if not NULL.
1828 */
Kendall Bennettc40d1dd2003-10-21 22:22:17 +00001829void GLAPIENTRY
Briand881a9c2006-12-20 09:31:07 -07001830_mesa_Finish(void)
jtgafb833d1999-08-19 00:55:39 +00001831{
Brian Paulfa9df402000-02-02 19:16:46 +00001832 GET_CURRENT_CONTEXT(ctx);
Keith Whitwellcab974c2000-12-26 05:09:27 +00001833 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx);
Brian Paulfa9df402000-02-02 19:16:46 +00001834 if (ctx->Driver.Finish) {
Briand881a9c2006-12-20 09:31:07 -07001835 ctx->Driver.Finish(ctx);
jtgafb833d1999-08-19 00:55:39 +00001836 }
1837}
1838
Briand881a9c2006-12-20 09:31:07 -07001839
Keith Whitwell6dc85572003-07-17 13:43:59 +00001840/**
1841 * Execute glFlush().
1842 *
1843 * Calls the #ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH macro and the
1844 * dd_function_table::Flush driver callback, if not NULL.
1845 */
Kendall Bennettc40d1dd2003-10-21 22:22:17 +00001846void GLAPIENTRY
Briand881a9c2006-12-20 09:31:07 -07001847_mesa_Flush(void)
jtgafb833d1999-08-19 00:55:39 +00001848{
Brian Paulfa9df402000-02-02 19:16:46 +00001849 GET_CURRENT_CONTEXT(ctx);
Keith Whitwellcab974c2000-12-26 05:09:27 +00001850 ASSERT_OUTSIDE_BEGIN_END_AND_FLUSH(ctx);
Brian Paulfa9df402000-02-02 19:16:46 +00001851 if (ctx->Driver.Flush) {
Briand881a9c2006-12-20 09:31:07 -07001852 ctx->Driver.Flush(ctx);
jtgafb833d1999-08-19 00:55:39 +00001853 }
jtgafb833d1999-08-19 00:55:39 +00001854}
Brian Paul48c6a6e2000-09-08 21:28:04 +00001855
1856
Keith Whitwell6dc85572003-07-17 13:43:59 +00001857/*@}*/