diff options
author | Luca Barbieri <[email protected]> | 2010-02-23 15:09:32 +0100 |
---|---|---|
committer | Luca Barbieri <[email protected]> | 2010-04-12 12:13:17 +0200 |
commit | f8f29e619124ec947dd3b5e0c93dcbd200f843fc (patch) | |
tree | 4791d7fe91fce1400e3df47ce09b79253b615bf7 | |
parent | 5c89cb0f6cfe30d5b15a57179ad16c0f209ff47e (diff) |
nvfx: so->RING_3D: stipple
-rw-r--r-- | src/gallium/drivers/nvfx/nvfx_context.c | 1 | ||||
-rw-r--r-- | src/gallium/drivers/nvfx/nvfx_state_stipple.c | 25 |
2 files changed, 11 insertions, 15 deletions
diff --git a/src/gallium/drivers/nvfx/nvfx_context.c b/src/gallium/drivers/nvfx/nvfx_context.c index eabf9ae7a07..e7b1486d496 100644 --- a/src/gallium/drivers/nvfx/nvfx_context.c +++ b/src/gallium/drivers/nvfx/nvfx_context.c @@ -85,5 +85,6 @@ nvfx_create(struct pipe_screen *pscreen, void *priv) /* set these to that we init them on first validation */ nvfx->state.scissor_enabled = ~0; + nvfx->state.stipple_enabled = ~0; return &nvfx->pipe; } diff --git a/src/gallium/drivers/nvfx/nvfx_state_stipple.c b/src/gallium/drivers/nvfx/nvfx_state_stipple.c index 57cd3c936a7..828113c4dfe 100644 --- a/src/gallium/drivers/nvfx/nvfx_state_stipple.c +++ b/src/gallium/drivers/nvfx/nvfx_state_stipple.c @@ -3,31 +3,27 @@ static boolean nvfx_state_stipple_validate(struct nvfx_context *nvfx) { + struct nouveau_channel *chan = nvfx->screen->base.channel; struct pipe_rasterizer_state *rast = &nvfx->rasterizer->pipe; - struct nouveau_grobj *eng3d = nvfx->screen->eng3d; - struct nouveau_stateobj *so; - if (nvfx->state.hw[NVFX_STATE_STIPPLE] && - (rast->poly_stipple_enable == 0 && nvfx->state.stipple_enabled == 0)) + if ((rast->poly_stipple_enable == 0 && nvfx->state.stipple_enabled == 0)) return FALSE; if (rast->poly_stipple_enable) { unsigned i; - so = so_new(2, 33, 0); - so_method(so, eng3d, NV34TCL_POLYGON_STIPPLE_ENABLE, 1); - so_data (so, 1); - so_method(so, eng3d, NV34TCL_POLYGON_STIPPLE_PATTERN(0), 32); + WAIT_RING(chan, 35); + OUT_RING(chan, RING_3D(NV34TCL_POLYGON_STIPPLE_ENABLE, 1)); + OUT_RING(chan, 1); + OUT_RING(chan, RING_3D(NV34TCL_POLYGON_STIPPLE_PATTERN(0), 32)); for (i = 0; i < 32; i++) - so_data(so, nvfx->stipple[i]); + OUT_RING(chan, nvfx->stipple[i]); } else { - so = so_new(1, 1, 0); - so_method(so, eng3d, NV34TCL_POLYGON_STIPPLE_ENABLE, 1); - so_data (so, 0); + WAIT_RING(chan, 2); + OUT_RING(chan, RING_3D(NV34TCL_POLYGON_STIPPLE_ENABLE, 1)); + OUT_RING(chan, 0); } - so_ref(so, &nvfx->state.hw[NVFX_STATE_STIPPLE]); - so_ref(NULL, &so); return TRUE; } @@ -35,6 +31,5 @@ struct nvfx_state_entry nvfx_state_stipple = { .validate = nvfx_state_stipple_validate, .dirty = { .pipe = NVFX_NEW_STIPPLE | NVFX_NEW_RAST, - .hw = NVFX_STATE_STIPPLE, } }; |