For the series: Reviewed-by: Marek Olšák <marek.ol...@amd.com>
Marek On Tue, Dec 1, 2015 at 4:16 AM, Dave Airlie <airl...@gmail.com> wrote: > From: Dave Airlie <airl...@redhat.com> > > streamout, gs rings bug on certain r600s, requires a wait idle > before each surface sync. > > Signed-off-by: Dave Airlie <airl...@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@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/mesa-dev _______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev