svga: document magic number of 8 render targets per batch
authorBrian Paul <brianp@vmware.com>
Thu, 7 Nov 2013 23:57:23 +0000 (16:57 -0700)
committerBrian Paul <brianp@vmware.com>
Mon, 11 Nov 2013 15:12:18 +0000 (08:12 -0700)
Grab the comments from commit message b84b7f19dfdc0 to explain
what the code is doing.

src/gallium/drivers/svga/svga_state_framebuffer.c

index 8232c3282332ab41f8aa34f414b8826ab215fc52..42544047bdc52c0641e1a5e770e82f0108836df8 100644 (file)
 #include "svga_debug.h"
 
 
+/*
+ * flush our command buffer after the 8th distinct render target
+ *
+ * This helps improve the surface cache behaviour in the face of the
+ * large number of single-use render targets generated by EXA and the xorg
+ * state tracker.  Without this we can reference hundreds of individual
+ * render targets from a command buffer, which leaves little scope for
+ * sharing or reuse of those targets.
+ */
+#define MAX_RT_PER_BATCH 8
+
+
 /***********************************************************************
  * Hardware state update
  */
@@ -56,7 +68,7 @@ emit_framebuffer( struct svga_context *svga,
    for(i = 0; i < PIPE_MAX_COLOR_BUFS; ++i) {
       if (curr->cbufs[i] != hw->cbufs[i] ||
           (reemit && hw->cbufs[i])) {
-         if (svga->curr.nr_fbs++ > 8)
+         if (svga->curr.nr_fbs++ > MAX_RT_PER_BATCH)
             return PIPE_ERROR_OUT_OF_MEMORY;
 
          ret = SVGA3D_SetRenderTarget(svga->swc, SVGA3D_RT_COLOR0 + i, curr->cbufs[i]);