diff options
| author | Roland Scheidegger <sroland@vmware.com> | 2010-02-11 22:48:31 +0100 | 
|---|---|---|
| committer | Roland Scheidegger <sroland@vmware.com> | 2010-02-11 22:48:31 +0100 | 
| commit | dc8c0959bd2b0fb9927f365d3e75e6a9e3c9cf14 (patch) | |
| tree | 65adad21922bf17792ca314f44a51e76a9300c6d | |
| parent | bedb6faec0882cf01ae8773f2ea685135471a87b (diff) | |
nv40: adapt to stencil ref changes
| -rw-r--r-- | src/gallium/drivers/nv40/nv40_context.h | 6 | ||||
| -rw-r--r-- | src/gallium/drivers/nv40/nv40_state.c | 21 | ||||
| -rw-r--r-- | src/gallium/drivers/nv40/nv40_state_emit.c | 2 | ||||
| -rw-r--r-- | src/gallium/drivers/nv40/nv40_state_zsa.c | 24 | 
4 files changed, 47 insertions, 6 deletions
diff --git a/src/gallium/drivers/nv40/nv40_context.h b/src/gallium/drivers/nv40/nv40_context.h index 958a48f2a4..4861924dac 100644 --- a/src/gallium/drivers/nv40/nv40_context.h +++ b/src/gallium/drivers/nv40/nv40_context.h @@ -61,7 +61,8 @@ enum nv40_state_index {  	NV40_STATE_VTXBUF = 31,  	NV40_STATE_VTXFMT = 32,  	NV40_STATE_VTXATTR = 33, -	NV40_STATE_MAX = 34 +	NV40_STATE_SR = 34, +	NV40_STATE_MAX = 35  };  #include "nv40_screen.h" @@ -79,6 +80,7 @@ enum nv40_state_index {  #define NV40_NEW_FRAGPROG	(1 << 10)  #define NV40_NEW_ARRAYS		(1 << 11)  #define NV40_NEW_UCP		(1 << 12) +#define NV40_NEW_SR		(1 << 13)  struct nv40_rasterizer_state {  	struct pipe_rasterizer_state pipe; @@ -144,6 +146,7 @@ struct nv40_context {  	struct nv40_zsa_state *zsa;  	struct nv40_blend_state *blend;  	struct pipe_blend_color blend_colour; +	struct pipe_stencil_ref stencil_ref;  	struct pipe_viewport_state viewport;  	struct pipe_framebuffer_state framebuffer;  	struct pipe_buffer *idxbuf; @@ -215,6 +218,7 @@ extern struct nv40_state_entry nv40_state_framebuffer;  extern struct nv40_state_entry nv40_state_fragtex;  extern struct nv40_state_entry nv40_state_vbo;  extern struct nv40_state_entry nv40_state_vtxfmt; +extern struct nv40_state_entry nv40_state_sr;  /* nv40_vbo.c */  extern void nv40_draw_arrays(struct pipe_context *, unsigned mode, diff --git a/src/gallium/drivers/nv40/nv40_state.c b/src/gallium/drivers/nv40/nv40_state.c index 51b40e51e4..d068be6243 100644 --- a/src/gallium/drivers/nv40/nv40_state.c +++ b/src/gallium/drivers/nv40/nv40_state.c @@ -445,7 +445,7 @@ nv40_depth_stencil_alpha_state_create(struct pipe_context *pipe,  {  	struct nv40_context *nv40 = nv40_context(pipe);  	struct nv40_zsa_state *zsaso = CALLOC(1, sizeof(*zsaso)); -	struct nouveau_stateobj *so = so_new(4, 21, 0); +	struct nouveau_stateobj *so = so_new(6, 20, 0);  	struct nouveau_grobj *curie = nv40->screen->curie;  	so_method(so, curie, NV40TCL_DEPTH_FUNC, 3); @@ -459,11 +459,11 @@ nv40_depth_stencil_alpha_state_create(struct pipe_context *pipe,  	so_data  (so, float_to_ubyte(cso->alpha.ref_value));  	if (cso->stencil[0].enabled) { -		so_method(so, curie, NV40TCL_STENCIL_FRONT_ENABLE, 8); +		so_method(so, curie, NV40TCL_STENCIL_FRONT_ENABLE, 3);  		so_data  (so, cso->stencil[0].enabled ? 1 : 0);  		so_data  (so, cso->stencil[0].writemask);  		so_data  (so, nvgl_comparison_op(cso->stencil[0].func)); -		so_data  (so, cso->stencil[0].ref_value); +		so_method(so, curie, NV40TCL_STENCIL_FRONT_FUNC_MASK, 4);  		so_data  (so, cso->stencil[0].valuemask);  		so_data  (so, nvgl_stencil_op(cso->stencil[0].fail_op));  		so_data  (so, nvgl_stencil_op(cso->stencil[0].zfail_op)); @@ -474,11 +474,11 @@ nv40_depth_stencil_alpha_state_create(struct pipe_context *pipe,  	}  	if (cso->stencil[1].enabled) { -		so_method(so, curie, NV40TCL_STENCIL_BACK_ENABLE, 8); +		so_method(so, curie, NV40TCL_STENCIL_BACK_ENABLE, 3);  		so_data  (so, cso->stencil[1].enabled ? 1 : 0);  		so_data  (so, cso->stencil[1].writemask);  		so_data  (so, nvgl_comparison_op(cso->stencil[1].func)); -		so_data  (so, cso->stencil[1].ref_value); +		so_method(so, curie, NV40TCL_STENCIL_BACK_FUNC_MASK, 4);  		so_data  (so, cso->stencil[1].valuemask);  		so_data  (so, nvgl_stencil_op(cso->stencil[1].fail_op));  		so_data  (so, nvgl_stencil_op(cso->stencil[1].zfail_op)); @@ -592,6 +592,16 @@ nv40_set_blend_color(struct pipe_context *pipe,  	nv40->dirty |= NV40_NEW_BCOL;  } + static void +nv40_set_stencil_ref(struct pipe_context *pipe, +		     const struct pipe_stencil_ref *sr) +{ +	struct nv40_context *nv40 = nv40_context(pipe); + +	nv40->stencil_ref = *sr; +	nv40->dirty |= NV40_NEW_SR; +} +  static void  nv40_set_clip_state(struct pipe_context *pipe,  		    const struct pipe_clip_state *clip) @@ -719,6 +729,7 @@ nv40_init_state_functions(struct nv40_context *nv40)  	nv40->pipe.delete_fs_state = nv40_fp_state_delete;  	nv40->pipe.set_blend_color = nv40_set_blend_color; +        nv40->pipe.set_stencil_ref = nv40_set_stencil_ref;  	nv40->pipe.set_clip_state = nv40_set_clip_state;  	nv40->pipe.set_constant_buffer = nv40_set_constant_buffer;  	nv40->pipe.set_framebuffer_state = nv40_set_framebuffer_state; diff --git a/src/gallium/drivers/nv40/nv40_state_emit.c b/src/gallium/drivers/nv40/nv40_state_emit.c index 1c4007a129..8990f303ce 100644 --- a/src/gallium/drivers/nv40/nv40_state_emit.c +++ b/src/gallium/drivers/nv40/nv40_state_emit.c @@ -13,6 +13,7 @@ static struct nv40_state_entry *render_states[] = {  	&nv40_state_blend,  	&nv40_state_blend_colour,  	&nv40_state_zsa, +	&nv40_state_sr,  	&nv40_state_viewport,  	&nv40_state_vbo,  	NULL @@ -29,6 +30,7 @@ static struct nv40_state_entry *swtnl_states[] = {  	&nv40_state_blend,  	&nv40_state_blend_colour,  	&nv40_state_zsa, +	&nv40_state_sr,  	&nv40_state_viewport,  	&nv40_state_vtxfmt,  	NULL diff --git a/src/gallium/drivers/nv40/nv40_state_zsa.c b/src/gallium/drivers/nv40/nv40_state_zsa.c index fb760677c8..4c734f4864 100644 --- a/src/gallium/drivers/nv40/nv40_state_zsa.c +++ b/src/gallium/drivers/nv40/nv40_state_zsa.c @@ -15,3 +15,27 @@ struct nv40_state_entry nv40_state_zsa = {  		.hw = NV40_STATE_ZSA  	}  }; + +static boolean +nv40_state_sr_validate(struct nv40_context *nv40) +{ +	struct nouveau_stateobj *so = so_new(2, 2, 0); +	struct pipe_stencil_ref *sr = &nv40->stencil_ref; + +	so_method(so, nv40->screen->rankine, NV40TCL_STENCIL_FRONT_FUNC_REF, 1); +	so_data  (so, sr->ref_value[0]; +	so_method(so, nv40->screen->rankine, NV40TCL_STENCIL_BACK_FUNC_REF, 1); +	so_data  (so, sr->ref_value[1]; + +	so_ref(so, &nv40->state.hw[NV40_STATE_SR]); +	so_ref(NULL, &so); +	return TRUE; +} + +struct nv40_state_entry nv40_state_sr = { +	.validate = nv40_state_sr_validate, +	.dirty = { +		.pipe = NV40_NEW_SR, +		.hw = NV40_STATE_SR +	} +};  | 
