From: Marek Olšák <[email protected]>

The src type is different on purpose.
---
 src/gallium/drivers/radeonsi/si_state_streamout.c | 10 ++++++++--
 1 file changed, 8 insertions(+), 2 deletions(-)

diff --git a/src/gallium/drivers/radeonsi/si_state_streamout.c 
b/src/gallium/drivers/radeonsi/si_state_streamout.c
index 42a83d4..92c5c59 100644
--- a/src/gallium/drivers/radeonsi/si_state_streamout.c
+++ b/src/gallium/drivers/radeonsi/si_state_streamout.c
@@ -25,20 +25,26 @@
  */
 
 #include "si_pipe.h"
 #include "si_state.h"
 #include "radeon/r600_cs.h"
 
 #include "util/u_memory.h"
 
 static void si_set_streamout_enable(struct si_context *sctx, bool enable);
 
+static inline void si_so_target_reference(struct si_streamout_target **dst,
+                                         struct pipe_stream_output_target *src)
+{
+       pipe_so_target_reference((struct pipe_stream_output_target**)dst, src);
+}
+
 static struct pipe_stream_output_target *
 si_create_so_target(struct pipe_context *ctx,
                    struct pipe_resource *buffer,
                    unsigned buffer_offset,
                    unsigned buffer_size)
 {
        struct si_context *sctx = (struct si_context *)ctx;
        struct si_streamout_target *t;
        struct r600_resource *rbuffer = (struct r600_resource*)buffer;
 
@@ -93,31 +99,31 @@ void si_common_set_streamout_targets(struct pipe_context 
*ctx,
        unsigned i;
         unsigned enabled_mask = 0, append_bitmask = 0;
 
        /* Stop streamout. */
        if (sctx->streamout.num_targets && sctx->streamout.begin_emitted) {
                si_emit_streamout_end(sctx);
        }
 
        /* Set the new targets. */
        for (i = 0; i < num_targets; i++) {
-               pipe_so_target_reference((struct 
pipe_stream_output_target**)&sctx->streamout.targets[i], targets[i]);
+               si_so_target_reference(&sctx->streamout.targets[i], targets[i]);
                if (!targets[i])
                        continue;
 
                r600_context_add_resource_size(ctx, targets[i]->buffer);
                enabled_mask |= 1 << i;
                if (offsets[i] == ((unsigned)-1))
                        append_bitmask |= 1 << i;
        }
        for (; i < sctx->streamout.num_targets; i++) {
-               pipe_so_target_reference((struct 
pipe_stream_output_target**)&sctx->streamout.targets[i], NULL);
+               si_so_target_reference(&sctx->streamout.targets[i], NULL);
        }
 
        sctx->streamout.enabled_mask = enabled_mask;
 
        sctx->streamout.num_targets = num_targets;
        sctx->streamout.append_bitmask = append_bitmask;
 
        if (num_targets) {
                si_streamout_buffers_dirty(sctx);
        } else {
-- 
2.7.4

_______________________________________________
mesa-dev mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to