[Mesa-dev] [PATCH 2/2] r600: SMX returns CONTEXT_DONE early workaround

Marek Olšák maraeo at gmail.com
Tue Dec 1 03:19:19 PST 2015


For the series:

Reviewed-by: Marek Olšák <marek.olsak at amd.com>

Marek

On Tue, Dec 1, 2015 at 4:16 AM, Dave Airlie <airlied at gmail.com> wrote:
> From: Dave Airlie <airlied at redhat.com>
>
> streamout, gs rings bug on certain r600s, requires a wait idle
> before each surface sync.
>
> Signed-off-by: Dave Airlie <airlied at redhat.com>
> ---
>  src/gallium/drivers/r600/r600_pipe.h         |  2 +-
>  src/gallium/drivers/r600/r600_state_common.c | 12 ++++++++++++
>  2 files changed, 13 insertions(+), 1 deletion(-)
>
> diff --git a/src/gallium/drivers/r600/r600_pipe.h b/src/gallium/drivers/r600/r600_pipe.h
> index 71a435f..c8ee612 100644
> --- a/src/gallium/drivers/r600/r600_pipe.h
> +++ b/src/gallium/drivers/r600/r600_pipe.h
> @@ -59,7 +59,7 @@
>
>  /* the number of CS dwords for flushing and drawing */
>  #define R600_MAX_FLUSH_CS_DWORDS       16
> -#define R600_MAX_DRAW_CS_DWORDS                49
> +#define R600_MAX_DRAW_CS_DWORDS                52
>  #define R600_TRACE_CS_DWORDS           7
>
>  #define R600_MAX_USER_CONST_BUFFERS 13
> diff --git a/src/gallium/drivers/r600/r600_state_common.c b/src/gallium/drivers/r600/r600_state_common.c
> index 82430e5..e50f24e 100644
> --- a/src/gallium/drivers/r600/r600_state_common.c
> +++ b/src/gallium/drivers/r600/r600_state_common.c
> @@ -1769,6 +1769,18 @@ static void r600_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info
>                                         (info.count_from_stream_output ? S_0287F0_USE_OPAQUE(1) : 0);
>         }
>
> +       /* SMX returns CONTEXT_DONE too early workaround */
> +       if (rctx->b.family == CHIP_R600 ||
> +           rctx->b.family == CHIP_RV610 ||
> +           rctx->b.family == CHIP_RV630 ||
> +           rctx->b.family == CHIP_RV635) {
> +               /* if we have gs shader or streamout
> +                  we need to do a wait idle after every draw */
> +               if (rctx->gs_shader || rctx->b.streamout.streamout_enabled) {
> +                       radeon_set_config_reg(cs, R_008040_WAIT_UNTIL, S_008040_WAIT_3D_IDLE(1));
> +               }
> +       }
> +
>         /* ES ring rolling over at EOP - workaround */
>         if (rctx->b.chip_class == R600) {
>                 cs->buf[cs->cdw++] = PKT3(PKT3_EVENT_WRITE, 0, 0);
> --
> 2.1.0
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list