summaryrefslogtreecommitdiffstats
path: root/src/gallium/auxiliary/util/u_surface.c
diff options
context:
space:
mode:
authorBrian Paul <[email protected]>2009-12-10 14:54:57 -0700
committerBrian Paul <[email protected]>2009-12-10 14:54:57 -0700
commita67f39810b5c88367ae2a9ee564b1a740b27601b (patch)
treed5cc1843bfb11e73ce6ffe447de38416ecb636a4 /src/gallium/auxiliary/util/u_surface.c
parent721b5167dcb2558b4bd53e09fc33936feeb93744 (diff)
gallium/util: added framebuffer compare, copy util funcs
Diffstat (limited to 'src/gallium/auxiliary/util/u_surface.c')
-rw-r--r--src/gallium/auxiliary/util/u_surface.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/src/gallium/auxiliary/util/u_surface.c b/src/gallium/auxiliary/util/u_surface.c
index 85e443204e3..a95b887e847 100644
--- a/src/gallium/auxiliary/util/u_surface.c
+++ b/src/gallium/auxiliary/util/u_surface.c
@@ -36,6 +36,7 @@
#include "pipe/p_state.h"
#include "pipe/p_defines.h"
+#include "util/u_memory.h"
#include "util/u_surface.h"
@@ -111,3 +112,51 @@ util_destroy_rgba_surface(struct pipe_texture *texture,
pipe_texture_reference(&texture, NULL);
}
+
+
+/**
+ * Compare pipe_framebuffer_state objects.
+ * \return TRUE if same, FALSE if different
+ */
+boolean
+util_framebuffer_state_equal(const struct pipe_framebuffer_state *dst,
+ const struct pipe_framebuffer_state *src)
+{
+ boolean changed = FALSE;
+ unsigned i;
+
+ for (i = 0; i < Elements(src->cbufs); i++) {
+ if (dst->cbufs[i] != src->cbufs[i]) {
+ changed = TRUE;
+ }
+ }
+
+ if (dst->nr_cbufs != src->nr_cbufs) {
+ changed = TRUE;
+ }
+
+ if (dst->zsbuf != src->zsbuf) {
+ changed = TRUE;
+ }
+
+ return changed;
+}
+
+
+/**
+ * Copy framebuffer state from src to dst, updating refcounts.
+ */
+void
+util_copy_framebuffer_state(struct pipe_framebuffer_state *dst,
+ const struct pipe_framebuffer_state *src)
+{
+ unsigned i;
+
+ for (i = 0; i < Elements(src->cbufs); i++) {
+ pipe_surface_reference(&dst->cbufs[i], src->cbufs[i]);
+ }
+
+ dst->nr_cbufs = src->nr_cbufs;
+
+ pipe_surface_reference(&dst->zsbuf, src->zsbuf);
+}