aco/isel: Always export position data from VS/NGG
authorTony Wasserka <tony.wasserka@gmx.de>
Mon, 12 Oct 2020 17:05:14 +0000 (19:05 +0200)
committerMarge Bot <eric+marge@anholt.net>
Wed, 14 Oct 2020 16:22:51 +0000 (16:22 +0000)
AMD ISA docs explicitly require this for VS, and this likely extends to
NGG too.

Cc: mesa-stable
Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/3615
Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7102>

src/amd/compiler/aco_instruction_selection.cpp

index 0ebb753..54bf8b4 100644 (file)
@@ -10203,6 +10203,11 @@ static void create_vs_exports(isel_context *ctx)
       ctx->outputs.temps[VARYING_SLOT_LAYER * 4u] = as_vgpr(ctx, get_arg(ctx, ctx->args->ac.view_index));
    }
 
+   /* Hardware requires position data to always be exported, even if the
+    * application did not write gl_Position.
+    */
+   ctx->outputs.mask[VARYING_SLOT_POS] = 0xf;
+
    /* the order these position exports are created is important */
    int next_pos = 0;
    bool exported_pos = export_vs_varying(ctx, VARYING_SLOT_POS, true, &next_pos);