Mesa (master): zink: pass so_info directly to update_so_info()

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Mar 9 03:01:22 UTC 2021


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

Author: Mike Blumenkrantz <michael.blumenkrantz at gmail.com>
Date:   Wed Feb 24 18:20:55 2021 -0500

zink: pass so_info directly to update_so_info()

Reviewed-by: Dave Airlie <airlied at redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/9271>

---

 src/gallium/drivers/zink/zink_compiler.c | 11 ++++++-----
 1 file changed, 6 insertions(+), 5 deletions(-)

diff --git a/src/gallium/drivers/zink/zink_compiler.c b/src/gallium/drivers/zink/zink_compiler.c
index 66bc7c8d2e6..229050121f9 100644
--- a/src/gallium/drivers/zink/zink_compiler.c
+++ b/src/gallium/drivers/zink/zink_compiler.c
@@ -403,7 +403,7 @@ check_psiz(struct nir_shader *s)
 }
 
 static void
-update_so_info(struct zink_shader *zs,
+update_so_info(struct zink_shader *zs, const struct pipe_stream_output_info *so_info,
                uint64_t outputs_written, bool have_psiz)
 {
    uint8_t reverse_map[64] = {};
@@ -421,8 +421,8 @@ update_so_info(struct zink_shader *zs,
       var->data.explicit_xfb_buffer = 0;
 
    bool inlined[64] = {0};
-   for (unsigned i = 0; i < zs->streamout.so_info.num_outputs; i++) {
-      struct pipe_stream_output *output = &zs->streamout.so_info.output[i];
+   for (unsigned i = 0; i < so_info->num_outputs; i++) {
+      const struct pipe_stream_output *output = &so_info->output[i];
       unsigned slot = reverse_map[output->register_index];
       if ((zs->nir->info.stage != MESA_SHADER_GEOMETRY || util_bitcount(zs->nir->info.gs.active_stream_mask) == 1) &&
           !output->start_component) {
@@ -439,7 +439,7 @@ update_so_info(struct zink_shader *zs,
          if (glsl_get_components(var->type) == output->num_components) {
             var->data.explicit_xfb_buffer = 1;
             var->data.xfb.buffer = output->output_buffer;
-            var->data.xfb.stride = zs->streamout.so_info.stride[output->output_buffer] * 4;
+            var->data.xfb.stride = so_info->stride[output->output_buffer] * 4;
             var->data.offset = output->dst_offset * 4;
             var->data.stream = output->stream;
             zs->streamout.skip[i] = true;
@@ -693,9 +693,10 @@ zink_shader_create(struct zink_screen *screen, struct nir_shader *nir,
    ret->nir = nir;
    if (so_info) {
       memcpy(&ret->streamout.so_info, so_info, sizeof(struct pipe_stream_output_info));
-      update_so_info(ret, nir->info.outputs_written, have_psiz);
+      update_so_info(ret, so_info, nir->info.outputs_written, have_psiz);
    }
 
+
    return ret;
 }
 



More information about the mesa-commit mailing list