diff options
author | Samuel Pitoiset <samuel.pitoiset@gmail.com> | 2021-01-13 10:34:03 +0100 |
---|---|---|
committer | Marge Bot <eric+marge@anholt.net> | 2021-01-13 13:42:04 +0000 |
commit | 755a8313fcf33a5646c8e7e2dd05adf73814dead (patch) | |
tree | dd431fdf4cd4ebaa0d769b3274060a309ac6858e | |
parent | 5537c9de73a2af8a9203d261ed914df92b7ae467 (diff) |
radv: add support for fast-clearing DCC levels on GFX10+
Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8468>
-rw-r--r-- | src/amd/vulkan/radv_meta_clear.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/src/amd/vulkan/radv_meta_clear.c b/src/amd/vulkan/radv_meta_clear.c index 4cad6c57bb4..cb7e86524b8 100644 --- a/src/amd/vulkan/radv_meta_clear.c +++ b/src/amd/vulkan/radv_meta_clear.c @@ -1413,11 +1413,10 @@ radv_clear_dcc(struct radv_cmd_buffer *cmd_buffer, uint64_t size; if (cmd_buffer->device->physical_device->rad_info.chip_class >= GFX10) { - /* Mipmap levels aren't implemented. */ - assert(level == 0); - - offset += image->planes[0].surface.dcc_slice_size * range->baseArrayLayer; - size = image->planes[0].surface.dcc_slice_size * layer_count; + /* DCC for mipmaps+layers is currently disabled. */ + offset += image->planes[0].surface.dcc_slice_size * range->baseArrayLayer + + image->planes[0].surface.u.gfx9.dcc_levels[level].offset; + size = image->planes[0].surface.u.gfx9.dcc_levels[level].size * layer_count; } else if (cmd_buffer->device->physical_device->rad_info.chip_class == GFX9) { /* Mipmap levels and layers aren't implemented. */ assert(level == 0); |