summaryrefslogtreecommitdiff
path: root/src/mesa/drivers/x11/xm_api.c
diff options
context:
space:
mode:
authorKeith Whitwell <keith@tungstengraphics.com>2000-11-05 18:26:12 +0000
committerKeith Whitwell <keith@tungstengraphics.com>2000-11-05 18:26:12 +0000
commitec0585883a85a495d94e24970d64e5d6fc889147 (patch)
treee33f8668e6fd6682ba865b7f0c418887e83fa579 /src/mesa/drivers/x11/xm_api.c
parentcd03ed4f54444d96e4e47cdb118a3dfd94d92bb0 (diff)
Use the new software rasterizer. Reworked optimized line,tri,point
functions to fit into the framework provided for extending the software rasterizer.
Diffstat (limited to 'src/mesa/drivers/x11/xm_api.c')
-rw-r--r--src/mesa/drivers/x11/xm_api.c57
1 files changed, 32 insertions, 25 deletions
diff --git a/src/mesa/drivers/x11/xm_api.c b/src/mesa/drivers/x11/xm_api.c
index 6e8fa3c0d7..3120b24a5e 100644
--- a/src/mesa/drivers/x11/xm_api.c
+++ b/src/mesa/drivers/x11/xm_api.c
@@ -1,4 +1,4 @@
-/* $Id: xm_api.c,v 1.5 2000/10/31 18:09:46 keithw Exp $ */
+/* $Id: xm_api.c,v 1.6 2000/11/05 18:26:12 keithw Exp $ */
/*
* Mesa 3-D graphics library
@@ -77,6 +77,7 @@
#endif
#include "macros.h"
#include "swrast/swrast.h"
+#include "swrast_setup/swrast_setup.h"
#ifndef GLX_NONE_EXT
#define GLX_NONE_EXT 0x8000
@@ -1616,6 +1617,7 @@ void XMesaDestroyVisual( XMesaVisual v )
XMesaContext XMesaCreateContext( XMesaVisual v, XMesaContext share_list )
{
XMesaContext c;
+ GLcontext *ctx;
GLboolean direct = GL_TRUE; /* XXXX */
/* NOT_DONE: should this be GL_FALSE??? */
static GLboolean firstTime = GL_TRUE;
@@ -1630,7 +1632,7 @@ XMesaContext XMesaCreateContext( XMesaVisual v, XMesaContext share_list )
return NULL;
}
- c->gl_ctx = _mesa_create_context( v->gl_visual,
+ ctx = c->gl_ctx = _mesa_create_context( v->gl_visual,
share_list ? share_list->gl_ctx : (GLcontext *) NULL,
(void *) c, direct );
if (!c->gl_ctx) {
@@ -1638,9 +1640,9 @@ XMesaContext XMesaCreateContext( XMesaVisual v, XMesaContext share_list )
return NULL;
}
- gl_extensions_enable(c->gl_ctx, "GL_HP_occlusion_test");
- gl_extensions_enable(c->gl_ctx, "GL_ARB_texture_cube_map");
- gl_extensions_enable(c->gl_ctx, "GL_EXT_texture_env_combine");
+ gl_extensions_enable(ctx, "GL_HP_occlusion_test");
+ gl_extensions_enable(ctx, "GL_ARB_texture_cube_map");
+ gl_extensions_enable(ctx, "GL_EXT_texture_env_combine");
if (CHECK_BYTE_ORDER(v)) {
c->swapbytes = GL_FALSE;
@@ -1654,30 +1656,32 @@ XMesaContext XMesaCreateContext( XMesaVisual v, XMesaContext share_list )
c->display = v->display;
c->pixelformat = v->dithered_pf; /* Dithering is enabled by default */
- c->gl_ctx->Driver.UpdateState = xmesa_update_state;
-
- /* These flags cover all the tests made in UpdateState, plus what
- * the software rasterizer needs to choose line,point and triangle
- * functions.
- */
- c->gl_ctx->Driver.UpdateStateNotify = (_NEW_POINT|
- _NEW_TEXTURE|
- _NEW_LINE|
- _NEW_LIGHT|
- _NEW_DEPTH|
- _NEW_POLYGON|
- _NEW_TEXTURE|
- _SWRAST_NEW_RASTERMASK|
- _SWRAST_NEW_TRIANGLE|
- _SWRAST_NEW_LINE|
- _SWRAST_NEW_POINT);
+ ctx->Driver.UpdateState = xmesa_update_state;
+ ctx->Driver.UpdateStateNotify = ~0;
#if defined(GLX_DIRECT_RENDERING) && !defined(XFree86Server)
c->driContextPriv = driContextPriv;
#endif
- /* Run the config file */
- _mesa_context_initialize( c->gl_ctx );
+ /* Set up some constant pointers:
+ */
+ xmesa_init_pointers( ctx );
+
+ if (ctx->VB)
+ _swsetup_RegisterVB( ctx->VB );
+
+
+ /* Initialize the software rasterizer and helper modules.
+ */
+ _swrast_CreateContext( ctx );
+ _swsetup_CreateContext( ctx );
+
+ xmesa_register_swrast_functions( ctx );
+
+ /* Run the config file
+ */
+ _mesa_context_initialize( ctx );
+
return c;
}
@@ -1691,8 +1695,11 @@ void XMesaDestroyContext( XMesaContext c )
if (c->xm_buffer && c->xm_buffer->FXctx)
fxMesaDestroyContext(c->xm_buffer->FXctx);
#endif
- if (c->gl_ctx)
+ if (c->gl_ctx) {
+ _swsetup_DestroyContext( c->gl_ctx );
+ _swrast_DestroyContext( c->gl_ctx );
_mesa_destroy_context( c->gl_ctx );
+ }
/* Disassociate old buffer with this context */
if (c->xm_buffer)