radv: Add flushing for DGC.
Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/17269>
This commit is contained in:

committed by
Marge Bot

parent
df69b34450
commit
848d3fdeb6
@@ -4175,6 +4175,15 @@ radv_dst_access_flush(struct radv_cmd_buffer *cmd_buffer, VkAccessFlags2 dst_fla
|
|||||||
/* SMEM loads are used to read compute dispatch size in shaders */
|
/* SMEM loads are used to read compute dispatch size in shaders */
|
||||||
if (!cmd_buffer->device->load_grid_size_from_user_sgpr)
|
if (!cmd_buffer->device->load_grid_size_from_user_sgpr)
|
||||||
flush_bits |= RADV_CMD_FLAG_INV_SCACHE;
|
flush_bits |= RADV_CMD_FLAG_INV_SCACHE;
|
||||||
|
|
||||||
|
/* Ensure the DGC meta shader can read the commands. */
|
||||||
|
if (cmd_buffer->device->uses_device_generated_commands) {
|
||||||
|
flush_bits |= RADV_CMD_FLAG_INV_SCACHE | RADV_CMD_FLAG_INV_VCACHE;
|
||||||
|
|
||||||
|
if (cmd_buffer->device->physical_device->rad_info.gfx_level < GFX9)
|
||||||
|
flush_bits |= RADV_CMD_FLAG_INV_L2;
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case VK_ACCESS_2_INDEX_READ_BIT:
|
case VK_ACCESS_2_INDEX_READ_BIT:
|
||||||
case VK_ACCESS_2_TRANSFORM_FEEDBACK_COUNTER_WRITE_BIT_EXT:
|
case VK_ACCESS_2_TRANSFORM_FEEDBACK_COUNTER_WRITE_BIT_EXT:
|
||||||
|
Reference in New Issue
Block a user