[Mesa-dev] [PATCH 00/29] anv: Rework resolves and fast clears
Jason Ekstrand
jason at jlekstrand.net
Tue Nov 28 03:05:50 UTC 2017
This patch series is a major rework of the aux tracking and fast clear code
in our Vulkan driver. It's broken up into three basic pieces:
1) Patches 1-13 rework the way layout transitions work and add some
additional granularity to our aux tracking scheme. This is required to
support Y-tiled window system buffers where we have CCS_E but need to
do a full resolve prior to handing it off to the window system. The
current code does a partial resolve if and only if CCS_E is enabled.
These patches may get back-ported to 17.3 because it seems that people
are hitting issues with this somewhere in Chrome.
2) Patches 14-25 rework the code we have for doing fast clears, setting up
indirect clear colors, and doing implicit layout transitions. In
particular, we pull them all together into a single begin/end_subpass
function pair instead of scattering them across multiple functions in
genX_cmd_buffer.c and anv_blorp.c. This allows us to avoid the
redundant fast-clear that you get when you have LOAD_OP_CLEAR combined
with IMAGE_LAYOUT_UNDEFINED.
3) Patches 26-29 revive my old CCS ambiguate pass and make us use that
instead of a fast-clear for initializing CCS buffers on gen9+. This
should allow us to avoid some unneeded resolves in a couple of corner
cases. It also simplifies transition_color_buffer a decent bit.
I've organized this patch series in order of priority both in terms of time
and in terms of importance. If the third chunk doesn't land for a while or
never at all, I'm not going to cry over it, but I do think it's quite a bit
better.
Cc: Nanley Chery <nanley.g.chery at intel.com>
Jason Ekstrand (29):
intel/isl: Codify AUX operations in an enum
anv/blorp: Rework image clear/resolve helpers
anv/blorp: Support ISL_AUX_USAGE_HIZ in surf_for_anv_image
anv/blorp: Rework HiZ ops to look like MCS and CCS
anv/image: Update a comment
anv/image: Add a helper for determining when fast clears are supported
anv/image: Support color aspects in layout_to_aux_usage
anv/cmd_buffer: Recurse in transition_color_buffer instead of falling
through
anv/cmd_buffer: Generalize transition_color_buffer
anv/cmd_buffer: Add an anv_genX_call macro
anv/cmd_buffer: Add a mark_image_written helper
anv/cmd_buffer: Drop the genX from get/set_needs_resolve
anv/cmd_buffer: Rework aux tracking
anv/cmd_buffer: Apply subpass flushes before set_subpass
anv/cmd_buffer: Add begin/end_subpass helpers
anv/cmd_buffer: Pass a subpass id into begin_subpass
anv/cmd_buffer: Move the color portion of clear_subpass into
begin_subpass
intel/blorp: Add a blorp_hiz_clear_depth_stencil helper
anv/cmd_buffer: Move the rest of clear_subpass into begin_subpass
anv/cmd_buffer: Decide whether or not to HiZ clear up-front
anv/cmd_buffer: Iterate all subpass attachments when clearing
anv/cmd_buffer: Add a concept of pending load aspects
anv/cmd_buffer: Sync clear values in begin_subpass
anv/cmd_buffer: Do subpass image transitions in begin/end_subpass
anv/cmd_buffer: Avoid unnecessary transitions before fast clears
intel/blorp: Add a CCS ambiguation pass
anv/cmd_buffer: Pull the undefined layout condition into the if
anv/cmd_buffer: Re-arrange the logic around UNDEFINED fast-clears
anv: Use blorp_ccs_ambiguate instead of fast-clears
src/intel/blorp/blorp.h | 16 +
src/intel/blorp/blorp_clear.c | 156 ++++++++
src/intel/isl/isl.h | 74 ++--
src/intel/vulkan/anv_blorp.c | 661 +++++++++++++++---------------
src/intel/vulkan/anv_cmd_buffer.c | 52 ++-
src/intel/vulkan/anv_genX.h | 6 +
src/intel/vulkan/anv_image.c | 108 ++++-
src/intel/vulkan/anv_private.h | 86 +++-
src/intel/vulkan/genX_cmd_buffer.c | 795 +++++++++++++++++++++++--------------
9 files changed, 1249 insertions(+), 705 deletions(-)
--
2.5.0.400.gff86faf
More information about the mesa-dev
mailing list