gallium/svga: added debug code for dumping framebuffer images (disabled)
authorBrian Paul <brianp@vmware.com>
Mon, 31 Jan 2011 21:41:36 +0000 (14:41 -0700)
committerBrian Paul <brianp@vmware.com>
Thu, 3 Feb 2011 21:22:21 +0000 (14:22 -0700)
src/gallium/drivers/svga/svga_pipe_flush.c

index ab243aa6ec59160a4d399d83610efecd99d64090..6c69d29d15e59e22d369389dea10e4dd38ff594a 100644 (file)
@@ -24,6 +24,7 @@
  **********************************************************/
 
 #include "pipe/p_defines.h"
+#include "util/u_string.h"
 #include "svga_screen.h"
 #include "svga_surface.h"
 #include "svga_context.h"
@@ -56,6 +57,28 @@ static void svga_flush( struct pipe_context *pipe,
 
    SVGA_DBG(DEBUG_DMA|DEBUG_PERF, "%s flags %x fence_ptr %p\n",
             __FUNCTION__, flags, fence ? *fence : 0x0);
+
+   /* Enable to dump BMPs of the color/depth buffers each frame */
+   if (0) {
+      if (flags & PIPE_FLUSH_FRAME) {
+         struct pipe_framebuffer_state *fb = &svga->curr.framebuffer;
+         static unsigned frame_no = 1;
+         char filename[256];
+         unsigned i;
+
+         for (i = 0; i < fb->nr_cbufs; i++) {
+            util_snprintf(filename, sizeof(filename), "cbuf%u_%04u", i, frame_no);
+            debug_dump_surface_bmp(&svga->pipe, filename, fb->cbufs[i]);
+         }
+
+         if (0 && fb->zsbuf) {
+            util_snprintf(filename, sizeof(filename), "zsbuf_%04u", frame_no);
+            debug_dump_surface_bmp(&svga->pipe, filename, fb->zsbuf);
+         }
+
+         ++frame_no;
+      }
+   }
 }