Mesa (master): r300g: Fix up resolve.

Corbin Simpson csimpson at kemper.freedesktop.org
Wed Jun 16 18:02:13 UTC 2010


Module: Mesa
Branch: master
Commit: e41ad8d2c5cac28cbdc3c1c234f1149c91a8d803
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=e41ad8d2c5cac28cbdc3c1c234f1149c91a8d803

Author: Corbin Simpson <MostAwesomeDude at gmail.com>
Date:   Wed Jun 16 11:01:34 2010 -0700

r300g: Fix up resolve.

Yay for old code.

---

 src/gallium/drivers/r300/r300_render.c |   20 ++++++++------------
 1 files changed, 8 insertions(+), 12 deletions(-)

diff --git a/src/gallium/drivers/r300/r300_render.c b/src/gallium/drivers/r300/r300_render.c
index 16add41..9b08187 100644
--- a/src/gallium/drivers/r300/r300_render.c
+++ b/src/gallium/drivers/r300/r300_render.c
@@ -1024,32 +1024,28 @@ static void r300_resource_resolve(struct pipe_context* pipe,
                                   struct pipe_subresource subsrc)
 {
     struct r300_context* r300 = r300_context(pipe);
-    struct r300_texture* tex = r300_texture(dest);
-    struct pipe_surface* surf = dest->screen->get_tex_surface(dest->screen,
-        dest, subdest.face, subdest.level, 0, 0);
+    struct r300_surface* destsurf = r300_surface(
+        dest->screen->get_tex_surface(dest->screen,
+            dest, subdest.face, subdest.level, 0, 0));
+    struct pipe_surface* srcsurf = src->screen->get_tex_surface(src->screen,
+            src, subsrc.face, subsrc.level, 0, 0);
     float color[] = {0, 0, 0, 0};
     CS_LOCALS(r300);
 
     DBG(r300, DBG_DRAW, "r300: Resolving resource...\n");
 
-    assert(tex && tex->buffer && "resolvebuf is marked, but NULL!");
-
     OUT_CS_REG_SEQ(R300_RB3D_AARESOLVE_OFFSET, 1);
-    OUT_CS_TEX_RELOC(tex, surf->offset, 0, tex->domain, 0);
+    OUT_CS_RELOC(destsurf->buffer, destsurf->offset, 0, destsurf->domain, 0);
 
     OUT_CS_REG_SEQ(R300_RB3D_AARESOLVE_PITCH, 1);
-    OUT_CS_TEX_RELOC(tex, tex->fb_state.colorpitch[surf->level],
-        0, tex->domain, 0);
+    OUT_CS_RELOC(destsurf->buffer, destsurf->pitch, 0, destsurf->domain, 0);
 
     OUT_CS_REG(R300_RB3D_AARESOLVE_CTL,
         R300_RB3D_AARESOLVE_CTL_AARESOLVE_MODE_RESOLVE |
         R300_RB3D_AARESOLVE_CTL_AARESOLVE_ALPHA_AVERAGE);
 
-    surf = src->screen->get_tex_surface(src->screen,
-        src, subsrc.face, subsrc.level, 0, 0);
-
     r300->context.clear_render_target(pipe,
-        surf, color, 0, 0, src->width0, src->height0);
+        srcsurf, color, 0, 0, src->width0, src->height0);
 
     OUT_CS_REG(R300_RB3D_AARESOLVE_CTL, 0x0);
 }




More information about the mesa-commit mailing list