diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/mesa/drivers/dri/i965/brw_cc.c | 7 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/brw_wm.c | 3 | ||||
| -rw-r--r-- | src/mesa/drivers/dri/i965/intel_context.c | 8 | 
3 files changed, 14 insertions, 4 deletions
| diff --git a/src/mesa/drivers/dri/i965/brw_cc.c b/src/mesa/drivers/dri/i965/brw_cc.c index 245d2ddcad..357704c577 100644 --- a/src/mesa/drivers/dri/i965/brw_cc.c +++ b/src/mesa/drivers/dri/i965/brw_cc.c @@ -77,8 +77,8 @@ static void upload_cc_unit( struct brw_context *brw )        cc.cc1.stencil_write_mask = brw->attribs.Stencil->WriteMask[0];        cc.cc1.stencil_test_mask = brw->attribs.Stencil->ValueMask[0]; -      if (brw->attribs.Stencil->TestTwoSide) { -	 cc.cc0.bf_stencil_enable = brw->attribs.Stencil->TestTwoSide; +      if (brw->attribs.Stencil->_TestTwoSide) { +	 cc.cc0.bf_stencil_enable = brw->attribs.Stencil->_TestTwoSide;  	 cc.cc0.bf_stencil_func = intel_translate_compare_func(brw->attribs.Stencil->Function[1]);  	 cc.cc0.bf_stencil_fail_op = intel_translate_stencil_op(brw->attribs.Stencil->FailFunc[1]);  	 cc.cc0.bf_stencil_pass_depth_fail_op = intel_translate_stencil_op(brw->attribs.Stencil->ZFailFunc[1]); @@ -91,7 +91,8 @@ static void upload_cc_unit( struct brw_context *brw )        /* Not really sure about this:         */        if (brw->attribs.Stencil->WriteMask[0] || -	  (brw->attribs.Stencil->TestTwoSide && brw->attribs.Stencil->WriteMask[1])) +	  (brw->attribs.Stencil->_TestTwoSide && +	   brw->attribs.Stencil->WriteMask[1]))  	 cc.cc0.stencil_write_enable = 1;     } diff --git a/src/mesa/drivers/dri/i965/brw_wm.c b/src/mesa/drivers/dri/i965/brw_wm.c index 009acc7680..2775fad37b 100644 --- a/src/mesa/drivers/dri/i965/brw_wm.c +++ b/src/mesa/drivers/dri/i965/brw_wm.c @@ -247,7 +247,8 @@ static void brw_wm_populate_key( struct brw_context *brw,        lookup |= IZ_STENCIL_TEST_ENABLE_BIT;        if (brw->attribs.Stencil->WriteMask[0] || -	  (brw->attribs.Stencil->TestTwoSide && brw->attribs.Stencil->WriteMask[1])) +	  (brw->attribs.Stencil->_TestTwoSide && +	   brw->attribs.Stencil->WriteMask[1]))  	 lookup |= IZ_STENCIL_WRITE_ENABLE_BIT;     } diff --git a/src/mesa/drivers/dri/i965/intel_context.c b/src/mesa/drivers/dri/i965/intel_context.c index d3b0b06f88..0866c5ccc6 100644 --- a/src/mesa/drivers/dri/i965/intel_context.c +++ b/src/mesa/drivers/dri/i965/intel_context.c @@ -89,6 +89,7 @@ int INTEL_DEBUG = (0);  #define need_GL_EXT_framebuffer_object  #define need_GL_EXT_multi_draw_arrays  #define need_GL_EXT_secondary_color +#define need_GL_ATI_separate_stencil  #define need_GL_EXT_point_parameters  #define need_GL_VERSION_2_0  #define need_GL_VERSION_2_1 @@ -188,7 +189,14 @@ const struct dri_extension card_extensions[] =      { "GL_EXT_fog_coord",                  GL_EXT_fog_coord_functions },      { "GL_EXT_multi_draw_arrays",          GL_EXT_multi_draw_arrays_functions },      { "GL_EXT_secondary_color",            GL_EXT_secondary_color_functions }, +    { "GL_ATI_separate_stencil",           GL_ATI_separate_stencil_functions },      { "GL_EXT_stencil_wrap",               NULL }, +    /* Do not enable this extension.  It conflicts with GL_ATI_separate_stencil +     * and 2.0's separate stencil, because mesa's computed _TestTwoSide will +     * only reflect whether it's enabled through this extension, even if the +     * application is using the other interfaces. +     */ +/*{ "GL_EXT_stencil_two_side",           GL_EXT_stencil_two_side_functions },*/      { "GL_EXT_texture_edge_clamp",         NULL },      { "GL_EXT_texture_env_combine",        NULL },      { "GL_EXT_texture_env_dot3",           NULL }, | 
