[Mesa-dev] [v2 10/39] i965/gen6: Allocate hiz directly without miptree

Topi Pohjolainen topi.pohjolainen at gmail.com
Wed May 3 09:22:23 UTC 2017


Reviewed-by: Jason Ekstrand <jason at jlekstrand.net>
Signed-off-by: Topi Pohjolainen <topi.pohjolainen at intel.com>
---
 src/mesa/drivers/dri/i965/brw_blorp.c         | 13 +-------
 src/mesa/drivers/dri/i965/gen6_depth_state.c  |  8 -----
 src/mesa/drivers/dri/i965/intel_mipmap_tree.c | 46 +++++++++------------------
 src/mesa/drivers/dri/i965/intel_mipmap_tree.h |  5 ---
 4 files changed, 16 insertions(+), 56 deletions(-)

diff --git a/src/mesa/drivers/dri/i965/brw_blorp.c b/src/mesa/drivers/dri/i965/brw_blorp.c
index 63bda23..c72d433 100644
--- a/src/mesa/drivers/dri/i965/brw_blorp.c
+++ b/src/mesa/drivers/dri/i965/brw_blorp.c
@@ -231,11 +231,7 @@ blorp_surf_for_miptree(struct brw_context *brw,
          surf->aux_addr.buffer = mt->hiz_buf->aux_base.bo;
          surf->aux_addr.offset = mt->hiz_buf->aux_base.offset;
 
-         struct intel_mipmap_tree *hiz_mt = mt->hiz_buf->mt;
-         if (hiz_mt) {
-            assert(brw->gen == 6 &&
-                   hiz_mt->array_layout == ALL_SLICES_AT_EACH_LOD);
-
+         if (brw->gen == 6) {
             /* gen6 requires the HiZ buffer to be manually offset to the
              * right location. 
              */
@@ -243,13 +239,6 @@ blorp_surf_for_miptree(struct brw_context *brw,
                &surf->surf->phys_level0_sa, surf->surf->dim,
                surf->surf->levels, surf->surf->format, *level);
 
-            assert(surf->aux_addr.offset ==
-                   intel_miptree_get_aligned_offset(
-                      hiz_mt,
-                      hiz_mt->level[*level].level_x,
-                      hiz_mt->level[*level].level_y));
-            assert(mt->hiz_buf->aux_base.pitch == hiz_mt->pitch);
-
             /* In depth state setup only surf->aux_surf.row_pitch gets
              * consulted. Otherwise surf->aux_surf is ignored and there is
              * no need to adjust it.  See blorp_emit_depth_stencil_config().
diff --git a/src/mesa/drivers/dri/i965/gen6_depth_state.c b/src/mesa/drivers/dri/i965/gen6_depth_state.c
index f709ee7..9bc1daf 100644
--- a/src/mesa/drivers/dri/i965/gen6_depth_state.c
+++ b/src/mesa/drivers/dri/i965/gen6_depth_state.c
@@ -161,9 +161,6 @@ gen6_emit_depth_stencil_hiz(struct brw_context *brw,
       /* Emit hiz buffer. */
       if (hiz) {
          assert(depth_mt);
-         struct intel_mipmap_tree *hiz_mt = depth_mt->hiz_buf->mt;
-
-         assert(hiz_mt->array_layout == ALL_SLICES_AT_EACH_LOD);
 
          struct isl_surf temp_surf;
          intel_miptree_get_isl_surf(brw, mt, &temp_surf);
@@ -175,11 +172,6 @@ gen6_emit_depth_stencil_hiz(struct brw_context *brw,
             &temp_surf.phys_level0_sa, temp_surf.dim, temp_surf.levels,
             temp_surf.format, lod);
 
-         assert(offset == intel_miptree_get_aligned_offset(
-                             hiz_mt,
-                             hiz_mt->level[lod].level_x,
-                             hiz_mt->level[lod].level_y));
-
 	 BEGIN_BATCH(3);
 	 OUT_BATCH((_3DSTATE_HIER_DEPTH_BUFFER << 16) | (3 - 2));
 	 OUT_BATCH(depth_mt->hiz_buf->aux_base.pitch - 1);
diff --git a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
index d5267df..684c371 100644
--- a/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
+++ b/src/mesa/drivers/dri/i965/intel_mipmap_tree.c
@@ -288,6 +288,7 @@ static void
 all_slices_at_each_lod_aux_init(struct brw_context *brw,
                                 const struct intel_mipmap_tree *mt,
                                 unsigned halign_bytes, unsigned valign,
+                                uint32_t tiling, const char *name,
                                 struct intel_miptree_aux_buffer *buf)
 {
    const uint32_t format = translate_tex_format(brw, mt->format, false);
@@ -315,6 +316,12 @@ all_slices_at_each_lod_aux_init(struct brw_context *brw,
     * hardware qpitch setting of hiz on gen6.
     */
    buf->qpitch = 0;
+
+   unsigned pitch = buf->pitch;
+   buf->bo = brw_bo_alloc_tiled(brw->bufmgr, name, total_w, total_h, cpp,
+                                tiling, &pitch, BO_ALLOC_FOR_RENDER);
+ 
+   assert(!buf->bo || pitch == buf->pitch);
 }
 
 /**
@@ -938,10 +945,7 @@ intel_miptree_hiz_buffer_free(struct intel_miptree_hiz_buffer *hiz_buf)
    if (hiz_buf == NULL)
       return;
 
-   if (hiz_buf->mt)
-      intel_miptree_release(&hiz_buf->mt);
-   else
-      brw_bo_unreference(hiz_buf->aux_base.bo);
+   brw_bo_unreference(hiz_buf->aux_base.bo);
 
    free(hiz_buf);
 }
@@ -1818,39 +1822,19 @@ intel_hiz_miptree_buf_create(struct brw_context *brw,
                              struct intel_mipmap_tree *mt)
 {
    struct intel_miptree_hiz_buffer *buf = calloc(sizeof(*buf), 1);
-   uint32_t layout_flags = MIPTREE_LAYOUT_ACCELERATED_UPLOAD;
-
-   if (brw->gen == 6)
-      layout_flags |= MIPTREE_LAYOUT_FORCE_ALL_SLICE_AT_LOD;
-
    if (!buf)
       return NULL;
 
-   layout_flags |= MIPTREE_LAYOUT_TILING_ANY;
-   buf->mt = intel_miptree_create(brw,
-                                  mt->target,
-                                  mt->format,
-                                  mt->first_level,
-                                  mt->last_level,
-                                  mt->logical_width0,
-                                  mt->logical_height0,
-                                  mt->logical_depth0,
-                                  mt->num_samples,
-                                  layout_flags);
-   if (!buf->mt) {
-      free(buf);
-      return NULL;
-   }
-
    const unsigned halign_bytes = 128;
    const unsigned valign = 32;
-   all_slices_at_each_lod_aux_init(brw, mt, halign_bytes, valign,
-                                   &buf->aux_base);
-
-   buf->aux_base.bo = buf->mt->bo;
+   uint32_t tiling = I915_TILING_Y;
+   all_slices_at_each_lod_aux_init(brw, mt, halign_bytes, valign, tiling,
+                                   "hiz", &buf->aux_base);
 
-   assert(buf->aux_base.pitch == buf->mt->pitch);
-   assert(buf->aux_base.size == buf->mt->total_height * buf->mt->pitch);
+   if (!buf->aux_base.bo) {
+      free(buf);
+      return NULL;
+   }
 
    return buf;
 }
diff --git a/src/mesa/drivers/dri/i965/intel_mipmap_tree.h b/src/mesa/drivers/dri/i965/intel_mipmap_tree.h
index 9495da0..c951e1a 100644
--- a/src/mesa/drivers/dri/i965/intel_mipmap_tree.h
+++ b/src/mesa/drivers/dri/i965/intel_mipmap_tree.h
@@ -326,11 +326,6 @@ struct intel_miptree_aux_buffer
 struct intel_miptree_hiz_buffer
 {
    struct intel_miptree_aux_buffer aux_base;
-
-   /**
-    * Hiz miptree. Used only by Gen6.
-    */
-   struct intel_mipmap_tree *mt;
 };
 
 struct intel_mipmap_tree
-- 
2.9.3



More information about the mesa-dev mailing list