gallium/util: simplify util_framebuffer_state_equal()
authorBrian Paul <brianp@vmware.com>
Fri, 11 Dec 2009 18:39:53 +0000 (11:39 -0700)
committerBrian Paul <brianp@vmware.com>
Fri, 11 Dec 2009 18:39:55 +0000 (11:39 -0700)
And copy width, height in util_copy_framebuffer_state().

src/gallium/auxiliary/util/u_surface.c
src/gallium/auxiliary/util/u_surface.h

index a95b887e847e7287838e3b2ca3a1a715c0c6b20f..daaa275ef25bde83a0515d0b90387bb273563da4 100644 (file)
@@ -122,24 +122,27 @@ boolean
 util_framebuffer_state_equal(const struct pipe_framebuffer_state *dst,
                              const struct pipe_framebuffer_state *src)
 {
-   boolean changed = FALSE;
    unsigned i;
 
+   if (dst->width != src->width ||
+       dst->height != src->height)
+      return FALSE;
+
    for (i = 0; i < Elements(src->cbufs); i++) {
       if (dst->cbufs[i] != src->cbufs[i]) {
-         changed = TRUE;
+         return FALSE;
       }
    }
 
    if (dst->nr_cbufs != src->nr_cbufs) {
-      changed = TRUE;
+      return FALSE;
    }
 
    if (dst->zsbuf != src->zsbuf) {
-      changed = TRUE;
+      return FALSE;
    }
 
-   return changed;
+   return TRUE;
 }
 
 
@@ -152,6 +155,9 @@ util_copy_framebuffer_state(struct pipe_framebuffer_state *dst,
 {
    unsigned i;
 
+   dst->width = src->width;
+   dst->height = src->height;
+
    for (i = 0; i < Elements(src->cbufs); i++) {
       pipe_surface_reference(&dst->cbufs[i], src->cbufs[i]);
    }
index a9da9aadcbb7183a91f6469a6b4fc0a8007f9615..3c60df2c3e52249991ca3c92b5a3ebcd94c8afcf 100644 (file)
 
 
 #include "pipe/p_compiler.h"
-
-
-struct pipe_screen;
-struct pipe_texture;
-struct pipe_surface;
+#include "pipe/p_state.h"
 
 
 /**
@@ -75,4 +71,8 @@ util_copy_framebuffer_state(struct pipe_framebuffer_state *dst,
                             const struct pipe_framebuffer_state *src);
 
 
+extern void
+util_unreference_framebuffer_state(struct pipe_framebuffer_state *fb);
+
+
 #endif /* U_SURFACE_H */