summaryrefslogtreecommitdiff
path: root/src/gallium
diff options
context:
space:
mode:
authorMike Blumenkrantz <michael.blumenkrantz@gmail.com>2022-06-26 09:06:26 -0400
committerMike Blumenkrantz <michael.blumenkrantz@gmail.com>2022-07-05 16:01:01 -0400
commitac2141a5b2f6270cf0a766254d321657d502d872 (patch)
treee2f38cbef0f74cdc16b6f74d0e0f14f3228afc3e /src/gallium
parent58780b3aa651b0d498c1829248fd28114d7ec7bd (diff)
zink: handle bitsizes in get_bo_vars() analysis
this allows it to be run repeatedly Reviewed-by: Dave Airlie <airlied@redhat.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/17239>
Diffstat (limited to 'src/gallium')
-rw-r--r--src/gallium/drivers/zink/zink_compiler.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/src/gallium/drivers/zink/zink_compiler.c b/src/gallium/drivers/zink/zink_compiler.c
index 9ab94efabf2..8427ba44b09 100644
--- a/src/gallium/drivers/zink/zink_compiler.c
+++ b/src/gallium/drivers/zink/zink_compiler.c
@@ -485,16 +485,17 @@ get_bo_vars(struct zink_shader *zs, nir_shader *shader)
bo.first_ssbo = ffs(zs->ssbos_used) - 1;
assert(bo.first_ssbo < PIPE_MAX_SHADER_BUFFERS);
nir_foreach_variable_with_modes(var, shader, nir_var_mem_ssbo | nir_var_mem_ubo) {
+ unsigned idx = glsl_get_explicit_stride(glsl_get_struct_field(glsl_without_array(var->type), 0)) >> 1;
if (var->data.mode == nir_var_mem_ssbo) {
- assert(!bo.ssbo[32 >> 4]);
- bo.ssbo[32 >> 4] = var;
+ assert(!bo.ssbo[idx]);
+ bo.ssbo[idx] = var;
} else {
if (var->data.driver_location) {
- assert(!bo.ubo[32 >> 4]);
- bo.ubo[32 >> 4] = var;
+ assert(!bo.ubo[idx]);
+ bo.ubo[idx] = var;
} else {
- assert(!bo.uniforms[32 >> 4]);
- bo.uniforms[32 >> 4] = var;
+ assert(!bo.uniforms[idx]);
+ bo.uniforms[idx] = var;
}
}
}