summaryrefslogtreecommitdiff
path: root/src/gallium/drivers/nvfx/nvfx_state_zsa.c
diff options
context:
space:
mode:
authorKeith Whitwell <keithw@vmware.com>2010-03-23 06:40:39 -0700
committerKeith Whitwell <keithw@vmware.com>2010-03-23 06:40:39 -0700
commit058c5697bda4c9cf7b49d26ee27a34586544efaa (patch)
tree90f111873e4c123d40831c5706f9628a05babc9d /src/gallium/drivers/nvfx/nvfx_state_zsa.c
parentdd7ba1378fc50710667724d30d6d4cf1125ad61e (diff)
parentb33fd3ce3daf2921a895367d0ed3fd9c718a8575 (diff)
Merge commit 'origin/gallium-resources' into gallium-buffer-usage-cleanup
Conflicts: src/gallium/state_trackers/vega/api_filters.c src/mesa/state_tracker/st_cb_drawpixels.c
Diffstat (limited to 'src/gallium/drivers/nvfx/nvfx_state_zsa.c')
-rw-r--r--src/gallium/drivers/nvfx/nvfx_state_zsa.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/gallium/drivers/nvfx/nvfx_state_zsa.c b/src/gallium/drivers/nvfx/nvfx_state_zsa.c
new file mode 100644
index 0000000000..c84fd041c1
--- /dev/null
+++ b/src/gallium/drivers/nvfx/nvfx_state_zsa.c
@@ -0,0 +1,41 @@
+#include "nvfx_context.h"
+
+static boolean
+nvfx_state_zsa_validate(struct nvfx_context *nvfx)
+{
+ so_ref(nvfx->zsa->so,
+ &nvfx->state.hw[NVFX_STATE_ZSA]);
+ return TRUE;
+}
+
+struct nvfx_state_entry nvfx_state_zsa = {
+ .validate = nvfx_state_zsa_validate,
+ .dirty = {
+ .pipe = NVFX_NEW_ZSA,
+ .hw = NVFX_STATE_ZSA
+ }
+};
+
+static boolean
+nvfx_state_sr_validate(struct nvfx_context *nvfx)
+{
+ struct nouveau_stateobj *so = so_new(2, 2, 0);
+ struct pipe_stencil_ref *sr = &nvfx->stencil_ref;
+
+ so_method(so, nvfx->screen->eng3d, NV34TCL_STENCIL_FRONT_FUNC_REF, 1);
+ so_data (so, sr->ref_value[0]);
+ so_method(so, nvfx->screen->eng3d, NV34TCL_STENCIL_BACK_FUNC_REF, 1);
+ so_data (so, sr->ref_value[1]);
+
+ so_ref(so, &nvfx->state.hw[NVFX_STATE_SR]);
+ so_ref(NULL, &so);
+ return TRUE;
+}
+
+struct nvfx_state_entry nvfx_state_sr = {
+ .validate = nvfx_state_sr_validate,
+ .dirty = {
+ .pipe = NVFX_NEW_SR,
+ .hw = NVFX_STATE_SR
+ }
+};