From: Mike Blumenkrantz Date: Sun, 26 Jun 2022 13:06:26 +0000 (-0400) Subject: zink: handle bitsizes in get_bo_vars() analysis X-Git-Tag: upstream/22.3.5~6615 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ac2141a5b2f6270cf0a766254d321657d502d872;p=platform%2Fupstream%2Fmesa.git zink: handle bitsizes in get_bo_vars() analysis this allows it to be run repeatedly Reviewed-by: Dave Airlie Part-of: --- diff --git a/src/gallium/drivers/zink/zink_compiler.c b/src/gallium/drivers/zink/zink_compiler.c index 9ab94ef..8427ba4 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; } } }