layers: MR159/LX309/LX310/LX304, Fix handling of OpTypeArray size in DrawState
authorChris Forbes <chrisforbes@google.com>
Tue, 26 Jan 2016 01:08:53 +0000 (14:08 +1300)
committerMark Lobodzinski <mark@lunarg.com>
Wed, 27 Jan 2016 22:53:00 +0000 (15:53 -0700)
Array size is specified via a constant instruction, not a literal.

layers/draw_state.cpp

index 4ec408ae3af2dc82ae307eb123e0f6bee4a49fa6..d265a62cf6fdd8c670e94d6ea71961f5748db6e1 100644 (file)
@@ -446,7 +446,7 @@ describe_type(char *dst, shader_module const *src, unsigned type)
             dst += sprintf(dst, "mat%d of ", insn.word(3));
             return describe_type(dst, src, insn.word(2));
         case spv::OpTypeArray:
-            dst += sprintf(dst, "arr[%d] of ", insn.word(3));
+            dst += sprintf(dst, "arr[%d] of ", get_constant_value(src, insn.word(3)));
             return describe_type(dst, src, insn.word(2));
         case spv::OpTypePointer:
             dst += sprintf(dst, "ptr to %s ", storage_class_name(insn.word(2)));
@@ -497,10 +497,18 @@ types_match(shader_module const *a, shader_module const *b, unsigned a_type, uns
             return a_insn.word(2) == b_insn.word(2) && !b_arrayed;
         case spv::OpTypeVector:
         case spv::OpTypeMatrix:
-        case spv::OpTypeArray:
             /* match on element type, count. these all have the same layout. we don't get here if
              * b_arrayed -- that is handled above. */
-            return !b_arrayed && types_match(a, b, a_insn.word(2), b_insn.word(2), b_arrayed) && a_insn.word(3) == b_insn.word(3);
+            return !b_arrayed &&
+                types_match(a, b, a_insn.word(2), b_insn.word(2), b_arrayed) &&
+                a_insn.word(3) == b_insn.word(3);
+        case spv::OpTypeArray:
+            /* match on element type, count. these all have the same layout. we don't get here if
+             * b_arrayed. This differs from vector & matrix types in that the array size is the id of a constant instruction,
+             * not a literal within OpTypeArray */
+            return !b_arrayed &&
+                types_match(a, b, a_insn.word(2), b_insn.word(2), b_arrayed) &&
+                get_constant_value(a, a_insn.word(3)) == get_constant_value(b, b_insn.word(3));
         case spv::OpTypeStruct:
             /* match on all element types */
             {
@@ -561,7 +569,7 @@ get_locations_consumed_by_type(shader_module const *src, unsigned type, bool str
                 return get_locations_consumed_by_type(src, insn.word(2), false);
             }
             else {
-                return insn.word(3) * get_locations_consumed_by_type(src, insn.word(2), false);
+                return get_constant_value(src, insn.word(3)) * get_locations_consumed_by_type(src, insn.word(2), false);
             }
         case spv::OpTypeMatrix:
             /* num locations is the dimension * element size */