From e41ad8d2c5cac28cbdc3c1c234f1149c91a8d803 Mon Sep 17 00:00:00 2001 From: Corbin Simpson Date: Wed, 16 Jun 2010 11:01:34 -0700 Subject: [PATCH] r300g: Fix up resolve. Yay for old code. --- src/gallium/drivers/r300/r300_render.c | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/src/gallium/drivers/r300/r300_render.c b/src/gallium/drivers/r300/r300_render.c index 16add416a4f..9b081870ff8 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); } -- 2.30.2