From: Alyssa Rosenzweig Date: Wed, 31 Jul 2019 18:52:52 +0000 (-0700) Subject: pan/decode: Use max varying index as varying buffer count X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=9e66ff3ea9a83d202c5b98f5d953fe21fe9d17eb;p=mesa.git pan/decode: Use max varying index as varying buffer count This allows us to decode asymmetric varyings correctly, which occurs with e.g. gl_FrontFacing. Signed-off-by: Alyssa Rosenzweig --- diff --git a/src/panfrost/pandecode/decode.c b/src/panfrost/pandecode/decode.c index 2df3cbdc986..a44c3732477 100644 --- a/src/panfrost/pandecode/decode.c +++ b/src/panfrost/pandecode/decode.c @@ -1253,7 +1253,7 @@ pandecode_attribute_meta(int job_no, int count, const struct mali_vertex_tiler_p pandecode_indent--; pandecode_log("};\n"); - return max_index; + return count ? (max_index + 1) : 0; } static void @@ -1666,17 +1666,17 @@ pandecode_vertex_tiler_postfix_pre(const struct mali_vertex_tiler_postfix *p, * pass a zero buffer with the right stride/size set, (or whatever) * since the GPU will write to it itself */ + if (p->varying_meta) { + varying_count = pandecode_attribute_meta(job_no, varying_count, p, true, suffix); + } + if (p->varyings) { attr_mem = pandecode_find_mapped_gpu_mem_containing(p->varyings); /* Number of descriptors depends on whether there are * non-internal varyings */ - pandecode_attributes(attr_mem, p->varyings, job_no, suffix, varying_count > 1 ? 4 : 1, true); - } - - if (p->varying_meta) { - pandecode_attribute_meta(job_no, varying_count, p, true, suffix); + pandecode_attributes(attr_mem, p->varyings, job_no, suffix, varying_count, true); } bool is_compute = job_type == JOB_TYPE_COMPUTE;