Mesa (master): aco: Set config->lds_size when TES or VS is running on HW ESGS.

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Wed Apr 29 12:18:35 UTC 2020


Module: Mesa
Branch: master
Commit: 7056714f5039e8f4302075677d962b5dd925e107
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=7056714f5039e8f4302075677d962b5dd925e107

Author: Timur Kristóf <timur.kristof at gmail.com>
Date:   Thu Apr 23 14:02:47 2020 +0200

aco: Set config->lds_size when TES or VS is running on HW ESGS.

This doesn't fix anything, just reports the LDS size used by
merged ESGS shaders, such as vertex_geometry_gs and
tess_eval_geometry_gs.

Signed-off-by: Timur Kristóf <timur.kristof at gmail.com>
Reviewed-by: Rhys Perry <pendingchaos02 at gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4388>

---

 src/amd/compiler/aco_instruction_selection_setup.cpp | 1 +
 1 file changed, 1 insertion(+)

diff --git a/src/amd/compiler/aco_instruction_selection_setup.cpp b/src/amd/compiler/aco_instruction_selection_setup.cpp
index bf4b34c6e3e..dee86585c8e 100644
--- a/src/amd/compiler/aco_instruction_selection_setup.cpp
+++ b/src/amd/compiler/aco_instruction_selection_setup.cpp
@@ -835,6 +835,7 @@ void setup_gs_variables(isel_context *ctx, nir_shader *nir)
       nir_foreach_variable(variable, &nir->inputs) {
          variable->data.driver_location = util_bitcount64(ctx->input_masks[nir->info.stage] & ((1ull << variable->data.location) - 1ull)) * 4;
       }
+      ctx->program->config->lds_size = ctx->program->info->gs_ring_info.lds_size; /* Already in units of the alloc granularity */
    } else if (ctx->stage == geometry_gs) {
       //TODO: make this more compact
       nir_foreach_variable(variable, &nir->inputs) {



More information about the mesa-commit mailing list