Module: Mesa
Branch: master
Commit: 6be017fdc4c4edd6c1815254f51e8dc2f02d79ac
URL:    
http://cgit.freedesktop.org/mesa/mesa/commit/?id=6be017fdc4c4edd6c1815254f51e8dc2f02d79ac

Author: Wladimir J. van der Laan <laa...@gmail.com>
Date:   Wed Aug 23 12:43:14 2017 +0000

freedreno: a2xx: Prevent crash in emit_texture if view is not set

Textures will sometimes be updated if texture view state was
un-set, without this change that causes an assertion crash or
segfault.

Signed-off-by: Wladimir J. van der Laan <laa...@gmail.com>
Reviewed-by: Ilia Mirkin <imir...@alum.mit.edu>
Reviewed-by: Rob Clark <robdcl...@gmail.com>

---

 src/gallium/drivers/freedreno/a2xx/fd2_emit.c | 13 ++++++++++---
 1 file changed, 10 insertions(+), 3 deletions(-)

diff --git a/src/gallium/drivers/freedreno/a2xx/fd2_emit.c 
b/src/gallium/drivers/freedreno/a2xx/fd2_emit.c
index 5a1db1335e..a787b71e37 100644
--- a/src/gallium/drivers/freedreno/a2xx/fd2_emit.c
+++ b/src/gallium/drivers/freedreno/a2xx/fd2_emit.c
@@ -125,8 +125,9 @@ emit_texture(struct fd_ringbuffer *ring, struct fd_context 
*ctx,
 {
        unsigned const_idx = fd2_get_const_idx(ctx, tex, samp_id);
        static const struct fd2_sampler_stateobj dummy_sampler = {};
+       static const struct fd2_pipe_sampler_view dummy_view = {};
        const struct fd2_sampler_stateobj *sampler;
-       struct fd2_pipe_sampler_view *view;
+       const struct fd2_pipe_sampler_view *view;
 
        if (emitted & (1 << const_idx))
                return 0;
@@ -134,13 +135,19 @@ emit_texture(struct fd_ringbuffer *ring, struct 
fd_context *ctx,
        sampler = tex->samplers[samp_id] ?
                        fd2_sampler_stateobj(tex->samplers[samp_id]) :
                        &dummy_sampler;
-       view = fd2_pipe_sampler_view(tex->textures[samp_id]);
+       view = tex->textures[samp_id] ?
+                       fd2_pipe_sampler_view(tex->textures[samp_id]) :
+                       &dummy_view;
 
        OUT_PKT3(ring, CP_SET_CONSTANT, 7);
        OUT_RING(ring, 0x00010000 + (0x6 * const_idx));
 
        OUT_RING(ring, sampler->tex0 | view->tex0);
-       OUT_RELOC(ring, fd_resource(view->base.texture)->bo, 0, view->fmt, 0);
+       if (view->base.texture)
+               OUT_RELOC(ring, fd_resource(view->base.texture)->bo, 0, 
view->fmt, 0);
+       else
+               OUT_RING(ring, 0);
+
        OUT_RING(ring, view->tex2);
        OUT_RING(ring, sampler->tex3 | view->tex3);
        OUT_RING(ring, sampler->tex4);

_______________________________________________
mesa-commit mailing list
mesa-commit@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-commit

Reply via email to