summaryrefslogtreecommitdiffstats
path: root/src/intel
diff options
context:
space:
mode:
authorJason Ekstrand <[email protected]>2020-03-05 11:30:59 -0600
committerMarge Bot <[email protected]>2020-03-12 17:51:28 +0000
commitfeaedc1fbe43ed4ad4978b9ff6815711ffd640a2 (patch)
tree2ef1ad4e1a2f920aa77e479633598aa15b8c69a4 /src/intel
parent84f97a21a669a42d458d9d8c7f52b65c4af355b5 (diff)
intel/isl: Clean up some aux surface logic
The first check is redundant because the first thing we do in the "emit the aux surface" section is assert that we actually have an aux_surf. The second check involves an exclusion list of things which don't have aux surfaces on Gen12 but an inclusion list is much simpler because it's just "does it have MCS?". Reviewed-by: Nanley Chery <[email protected]> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4056>
Diffstat (limited to 'src/intel')
-rw-r--r--src/intel/isl/isl_surface_state.c26
1 files changed, 11 insertions, 15 deletions
diff --git a/src/intel/isl/isl_surface_state.c b/src/intel/isl/isl_surface_state.c
index c66f09b4b68..e44e16c87fa 100644
--- a/src/intel/isl/isl_surface_state.c
+++ b/src/intel/isl/isl_surface_state.c
@@ -574,15 +574,6 @@ isl_genX(surf_fill_state_s)(const struct isl_device *dev, void *state,
info->aux_usage == ISL_AUX_USAGE_CCS_D);
}
- if (GEN_GEN >= 12) {
- /* We don't need an auxiliary surface for CCS on gen12+ */
- assert (info->aux_usage == ISL_AUX_USAGE_CCS_E ||
- info->aux_usage == ISL_AUX_USAGE_MC || info->aux_surf);
- } else {
- /* We must have an auxiliary surface */
- assert(info->aux_surf);
- }
-
/* The docs don't appear to say anything whatsoever about compression
* and the data port. Testing seems to indicate that the data port
* completely ignores the AuxiliarySurfaceMode field.
@@ -615,13 +606,18 @@ isl_genX(surf_fill_state_s)(const struct isl_device *dev, void *state,
#endif
}
- /* The auxiliary buffer info is filled when it's useable by the HW. On
- * gen12 and above, CCS is controlled by the aux table and not the
- * auxiliary surface information in SURFACE_STATE.
+ /* The auxiliary buffer info is filled when it's useable by the HW.
+ *
+ * Starting with Gen12, the only form of compression that can be used
+ * with RENDER_SURFACE_STATE which requires an aux surface is MCS.
+ * HiZ still requires a surface but the HiZ surface can only be
+ * accessed through 3DSTATE_HIER_DEPTH_BUFFER.
+ *
+ * On all earlier hardware, an aux surface is required for all forms
+ * of compression.
*/
- if (info->aux_usage != ISL_AUX_USAGE_NONE &&
- ((info->aux_usage != ISL_AUX_USAGE_MC &&
- info->aux_usage != ISL_AUX_USAGE_CCS_E) || GEN_GEN <= 11)) {
+ if ((GEN_GEN < 12 && info->aux_usage != ISL_AUX_USAGE_NONE) ||
+ (GEN_GEN >= 12 && isl_aux_usage_has_mcs(info->aux_usage))) {
assert(info->aux_surf != NULL);