broadcom/genxml: Fix decoding of groups with small fields.
authorKenneth Graunke <kenneth@whitecape.org>
Thu, 26 Oct 2017 04:17:14 +0000 (21:17 -0700)
committerEric Anholt <eric@anholt.net>
Tue, 7 Nov 2017 17:19:48 +0000 (09:19 -0800)
Groups containing fields smaller than a byte probably not being decoded
correctly.  For example:

    <group count="32" start="32" size="4">
      <field name="Vertex Element Enables" start="0" end="3" type="uint"/>
    </group>

gen_field_iterator_next would properly walk over each element of the
array, incrementing group_iter.  However, the code to print the actual
values only considered iter->field->start/end, which are 0 and 3 in the
above example.  So it would always fetch bits 3:0 of the current byte,
printing the same value over and over.

Cc: Eric Anholt <eric@anholt.net>
src/broadcom/cle/v3d_decoder.c

index 4ac40af05e8658f97d81476aac535788ceb336fe..9c457b76068154e90b8016791bfa213ed35af717 100644 (file)
@@ -781,8 +781,10 @@ v3d_field_iterator_next(struct v3d_field_iterator *iter)
 
         const char *enum_name = NULL;
 
-        int s = iter->field->start;
-        int e = iter->field->end;
+        int group_member_offset =
+                iter_group_offset_bits(iter, iter->group_iter);
+        int s = group_member_offset + iter->field->start;
+        int e = group_member_offset + iter->field->end;
 
         switch (iter->field->type.kind) {
         case V3D_TYPE_UNKNOWN: