radeonsi: Use explicit stencil mipmap level offsets.
authorMichel Dänzer <michel.daenzer@amd.com>
Tue, 20 Nov 2012 11:48:30 +0000 (12:48 +0100)
committerMichel Dänzer <michel@daenzer.net>
Wed, 28 Nov 2012 12:35:17 +0000 (13:35 +0100)
Extracted from r600g commit 428e37c2da420f7dc14a2ea265f2387270f9bee1.

Signed-off-by: Michel Dänzer <michel.daenzer@amd.com>
src/gallium/drivers/radeonsi/r600_texture.c
src/gallium/drivers/radeonsi/si_state.c

index 64d4b0e64a8e27b52ebbee821cac8c0eb2c4826b..3a62898cac26f77ffc313601d74a5516a47fc0bf 100644 (file)
@@ -157,7 +157,8 @@ static int r600_init_surface(struct r600_screen *rscreen,
                surface->flags |= RADEON_SURF_ZBUFFER;
 
                if (is_stencil) {
-                       surface->flags |= RADEON_SURF_SBUFFER;
+                       surface->flags |= RADEON_SURF_SBUFFER |
+                               RADEON_SURF_HAS_SBUFFER_MIPTREE;
                }
        }
        return 0;
@@ -183,7 +184,8 @@ static int r600_setup_surface(struct pipe_screen *screen,
                rtex->surface.level[0].pitch_bytes = pitch_in_bytes_override;
                rtex->surface.level[0].slice_size = pitch_in_bytes_override * rtex->surface.level[0].nblk_y;
                if (rtex->surface.flags & RADEON_SURF_SBUFFER) {
-                       rtex->surface.stencil_offset = rtex->surface.level[0].slice_size;
+                       rtex->surface.stencil_offset =
+                       rtex->surface.stencil_level[0].offset = rtex->surface.level[0].slice_size;
                }
        }
        return 0;
index 09948618b939af04185f53e44b9e4f6635620d82..95ea8606053cad08fdd0966b6015faa6b0a06067 100644 (file)
@@ -1694,12 +1694,9 @@ static void si_db(struct r600_context *rctx, struct si_pm4_state *pm4,
                R600_ERR("Invalid DB format: %d, disabling DB.\n", rtex->real_format);
        }
 
-       z_offs = r600_resource_va(rctx->context.screen, surf->base.texture);
+       s_offs = z_offs = r600_resource_va(rctx->context.screen, surf->base.texture);
        z_offs += rtex->surface.level[level].offset;
-
-       s_offs = r600_resource_va(rctx->context.screen, surf->base.texture);
-       s_offs += rtex->surface.stencil_offset;
-       z_offs += rtex->surface.level[level].offset / 4;
+       s_offs += rtex->surface.stencil_level[level].offset;
 
        z_offs >>= 8;
        s_offs >>= 8;