[Mesa-dev] [PATCH 4/5] i965: Only do depth resolves prior to clearing when needed
Jason Ekstrand
jason at jlekstrand.net
Thu Jun 15 01:54:28 UTC 2017
---
src/mesa/drivers/dri/i965/brw_clear.c | 35 +++++++++++++++++++++++++++++++++--
1 file changed, 33 insertions(+), 2 deletions(-)
diff --git a/src/mesa/drivers/dri/i965/brw_clear.c b/src/mesa/drivers/dri/i965/brw_clear.c
index f5a990d..99ddc4e 100644
--- a/src/mesa/drivers/dri/i965/brw_clear.c
+++ b/src/mesa/drivers/dri/i965/brw_clear.c
@@ -164,8 +164,39 @@ brw_fast_clear_depth(struct gl_context *ctx)
* flags out of the HiZ buffer into the real depth buffer.
*/
if (mt->fast_clear_color.f32[0] != ctx->Depth.Clear) {
- intel_miptree_prepare_access(brw, mt, 0, INTEL_REMAINING_LEVELS,
- 0, INTEL_REMAINING_LAYERS, true, false);
+ for (uint32_t level = mt->first_level; level <= mt->last_level; level++) {
+ if (!intel_miptree_level_has_hiz(mt, level))
+ continue;
+
+ for (uint32_t layer = 0; layer < mt->level[level].depth; layer++) {
+ if (level == depth_irb->mt_level &&
+ layer >= depth_irb->mt_layer &&
+ layer < depth_irb->mt_layer + num_layers) {
+ /* We're going to clear this layer anyway. Leave it alone. */
+ continue;
+ }
+
+ enum isl_aux_state aux_state =
+ intel_miptree_get_aux_state(mt, level, layer);
+
+ if (aux_state != ISL_AUX_STATE_CLEAR &&
+ aux_state != ISL_AUX_STATE_COMPRESSED_CLEAR) {
+ /* This slice doesn't have any fast-cleared bits. */
+ continue;
+ }
+
+ /* If we got here, then the level may have fast-clear bits that
+ * use the old clear value. We need to do a depth resolve to get
+ * rid of their use of the clear value before we can change it.
+ * Fortunately, few applications ever change their depth clear
+ * value so this shouldn't happen often.
+ */
+ intel_hiz_exec(brw, mt, level, layer, 1,
+ BLORP_HIZ_OP_DEPTH_RESOLVE);
+ intel_miptree_set_aux_state(brw, mt, level, layer, 1,
+ ISL_AUX_STATE_RESOLVED);
+ }
+ }
mt->fast_clear_color.f32[0] = ctx->Depth.Clear;
}
--
2.5.0.400.gff86faf
More information about the mesa-dev
mailing list