pan/mdg: Add disassembly for shadow gathers
authorAlyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Fri, 28 Aug 2020 12:53:44 +0000 (08:53 -0400)
committerAlyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Mon, 31 Aug 2020 11:46:32 +0000 (07:46 -0400)
By applying `textureGather` to a `sampler2DShadow`, the blob produces
(under the old disassembly):

   tex_22.vtx.2d.shadow.cont.last r29, texture0, fsampler0.zwyx, r29,

The op 0x22 is 10|0010 in binary, the old shadow parameter is 1, and old
gather parameter is 0, so we get 0110|0010 in binary, or an op of
textureLod with a mod of 0110 = 6.

Signed-off-by: Alyssa Rosenzweig <alyssa.rosenzweig@collabora.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6516>

src/panfrost/midgard/disassemble.c
src/panfrost/midgard/midgard.h

index 5568fa03663f8e7998def57e4563faf58eddca03..e872ea9923cf5a6f99beab8362bb2ad0af36b5ef 100644 (file)
@@ -1385,6 +1385,7 @@ texture_mode(enum mali_texture_mode mode)
         switch (mode) {
         case TEXTURE_NORMAL: return "";
         case TEXTURE_SHADOW: return ".shadow";
+        case TEXTURE_GATHER_SHADOW: return ".gather.shadow";
         case TEXTURE_GATHER_X: return ".gatherX";
         case TEXTURE_GATHER_Y: return ".gatherY";
         case TEXTURE_GATHER_Z: return ".gatherZ";
index 6308e89e916f7e389127bbfdb30b4342448f88aa..656881c7ff3efd1495864c5b0e2ed6d881fe2a27 100644 (file)
@@ -651,6 +651,7 @@ enum mali_sampler_type {
 enum mali_texture_mode {
         TEXTURE_NORMAL = 1,
         TEXTURE_SHADOW = 5,
+        TEXTURE_GATHER_SHADOW = 6,
         TEXTURE_GATHER_X = 8,
         TEXTURE_GATHER_Y = 9,
         TEXTURE_GATHER_Z = 10,