[Mesa-dev] [PATCH 1/2] radv: fix a GPU hang with RADV_DEBUG=syncshaders
Bas Nieuwenhuizen
basni at chromium.org
Thu Jan 25 17:07:18 UTC 2018
Reviewed-by: Bas Nieuwenhuizen <bas at basnieuwenhuizen.nl>
On Thu, Jan 25, 2018 at 3:46 PM, Samuel Pitoiset <samuel.pitoiset at gmail.com>
wrote:
> The GPU hangs when the driver forces a PS_PARTIAL_FLUSH after
> a dispatch call (and vice versa for graphics). Something has
> changed in the kernel driver because it used to work.
>
> Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
> ---
> src/amd/vulkan/radv_cmd_buffer.c | 15 +++++++--------
> 1 file changed, 7 insertions(+), 8 deletions(-)
>
> diff --git a/src/amd/vulkan/radv_cmd_buffer.c b/src/amd/vulkan/radv_cmd_
> buffer.c
> index 6d512c6070a..ba5fd92f2a1 100644
> --- a/src/amd/vulkan/radv_cmd_buffer.c
> +++ b/src/amd/vulkan/radv_cmd_buffer.c
> @@ -429,15 +429,14 @@ void radv_cmd_buffer_trace_emit(struct
> radv_cmd_buffer *cmd_buffer)
> }
>
> static void
> -radv_cmd_buffer_after_draw(struct radv_cmd_buffer *cmd_buffer)
> +radv_cmd_buffer_after_draw(struct radv_cmd_buffer *cmd_buffer,
> + enum radv_cmd_flush_bits flags)
> {
> if (cmd_buffer->device->instance->debug_flags &
> RADV_DEBUG_SYNC_SHADERS) {
> - enum radv_cmd_flush_bits flags;
> -
> - /* Force wait for graphics/compute engines to be idle. */
> - flags = RADV_CMD_FLAG_PS_PARTIAL_FLUSH |
> - RADV_CMD_FLAG_CS_PARTIAL_FLUSH;
> + assert(flags & (RADV_CMD_FLAG_PS_PARTIAL_FLUSH |
> + RADV_CMD_FLAG_CS_PARTIAL_FLUSH));
>
> + /* Force wait for graphics or compute engines to be idle.
> */
> si_cs_emit_cache_flush(cmd_buffer->cs, false,
> cmd_buffer->device->physical_
> device->rad_info.chip_class,
> NULL, 0,
> @@ -3501,7 +3500,7 @@ radv_draw(struct radv_cmd_buffer *cmd_buffer,
> }
>
> assert(cmd_buffer->cs->cdw <= cdw_max);
> - radv_cmd_buffer_after_draw(cmd_buffer);
> + radv_cmd_buffer_after_draw(cmd_buffer, RADV_CMD_FLAG_PS_PARTIAL_
> FLUSH);
> }
>
> void radv_CmdDraw(
> @@ -3821,7 +3820,7 @@ radv_dispatch(struct radv_cmd_buffer *cmd_buffer,
> radv_emit_dispatch_packets(cmd_buffer, info);
> }
>
> - radv_cmd_buffer_after_draw(cmd_buffer);
> + radv_cmd_buffer_after_draw(cmd_buffer, RADV_CMD_FLAG_CS_PARTIAL_
> FLUSH);
> }
>
> void radv_CmdDispatch(
> --
> 2.16.1
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/mesa-dev/attachments/20180125/3ea3a249/attachment.html>
More information about the mesa-dev
mailing list