[Mesa-dev] Mesa (master): glsl: Make sure fields after small structs have correct padding
Ian Romanick
idr at freedesktop.org
Fri Sep 26 08:02:22 PDT 2014
Okay... I screwed up this morning. I pushed a set of four patches
without adding Jordan's Reviewed-by. Realizing the error, I quickly
added the R-b to each commit and force-pushed the changes.
If you pushed something in the intervening 2 minutes, it got lost.
On 09/26/2014 08:00 AM, Ian Romanick wrote:
> Module: Mesa
> Branch: master
> Commit: 8e01c66da6c780601f941aa5b9939962c219fdbd
> URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=8e01c66da6c780601f941aa5b9939962c219fdbd
>
> Author: Ian Romanick <ian.d.romanick at intel.com>
> Date: Mon Sep 8 12:23:39 2014 -0700
>
> glsl: Make sure fields after small structs have correct padding
>
> Previously the linker would correctly calculate the layout, but the
> lower_ubo_reference pass would not apply correct alignment to fields
> following small (less than 16-byte) nested structures.
>
> Signed-off-by: Ian Romanick <ian.d.romanick at intel.com>
> Reviewed-by: Jordan Justen <jordan.l.justen at intel.com>
> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=83533
> Cc: mesa-stable at lists.freedesktop.org
>
> ---
>
> src/glsl/lower_ubo_reference.cpp | 22 ++++++++++++++++++++++
> 1 file changed, 22 insertions(+)
>
> diff --git a/src/glsl/lower_ubo_reference.cpp b/src/glsl/lower_ubo_reference.cpp
> index 3cdfc04..4ae1aac 100644
> --- a/src/glsl/lower_ubo_reference.cpp
> +++ b/src/glsl/lower_ubo_reference.cpp
> @@ -327,6 +327,15 @@ lower_ubo_reference_visitor::handle_rvalue(ir_rvalue **rvalue)
> const glsl_type *struct_type = deref_record->record->type;
> unsigned intra_struct_offset = 0;
>
> + /* glsl_type::std140_base_alignment doesn't grok interfaces. Use
> + * 16-bytes for the alignment because that is the general minimum of
> + * std140.
> + */
> + const unsigned struct_alignment = struct_type->is_interface()
> + ? 16
> + : struct_type->std140_base_alignment(row_major);
> +
> +
> for (unsigned int i = 0; i < struct_type->length; i++) {
> const glsl_type *type = struct_type->fields.structure[i].type;
>
> @@ -346,6 +355,19 @@ lower_ubo_reference_visitor::handle_rvalue(ir_rvalue **rvalue)
> deref_record->field) == 0)
> break;
> intra_struct_offset += type->std140_size(field_row_major);
> +
> + /* If the field just examined was itself a structure, apply rule
> + * #9:
> + *
> + * "The structure may have padding at the end; the base offset
> + * of the member following the sub-structure is rounded up to
> + * the next multiple of the base alignment of the structure."
> + */
> + if (type->without_array()->is_record()) {
> + intra_struct_offset = glsl_align(intra_struct_offset,
> + struct_alignment);
> +
> + }
> }
>
> const_offset += intra_struct_offset;
>
> _______________________________________________
> mesa-commit mailing list
> mesa-commit at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-commit
>
More information about the mesa-dev
mailing list