Mesa (main): radv: Implement task shader intrinsics in the ABI.

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Thu May 12 00:59:26 UTC 2022


Module: Mesa
Branch: main
Commit: a8bdcf3c92b12bb551e11bebaf23fa7802f01075
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=a8bdcf3c92b12bb551e11bebaf23fa7802f01075

Author: Timur Kristóf <timur.kristof at gmail.com>
Date:   Wed May 11 12:38:02 2022 +0200

radv: Implement task shader intrinsics in the ABI.

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/14929>

---

 src/amd/vulkan/radv_nir_lower_abi.c | 22 +++++++++++++++++++++-
 1 file changed, 21 insertions(+), 1 deletion(-)

diff --git a/src/amd/vulkan/radv_nir_lower_abi.c b/src/amd/vulkan/radv_nir_lower_abi.c
index 60c5fe5fc5b..fd32c353514 100644
--- a/src/amd/vulkan/radv_nir_lower_abi.c
+++ b/src/amd/vulkan/radv_nir_lower_abi.c
@@ -161,6 +161,21 @@ lower_abi_instr(nir_builder *b, nir_instr *instr, void *state)
    case nir_intrinsic_load_viewport_y_offset:
       return ac_nir_load_arg(b, &s->args->ac, s->args->ngg_viewport_translate[1]);
 
+   case nir_intrinsic_load_ring_task_draw_amd:
+      return load_ring(b, RING_TS_DRAW, s);
+
+   case nir_intrinsic_load_ring_task_payload_amd:
+      return load_ring(b, RING_TS_PAYLOAD, s);
+
+   case nir_intrinsic_load_task_ring_entry_amd:
+      return ac_nir_load_arg(b, &s->args->ac, s->args->ac.task_ring_entry);
+
+   case nir_intrinsic_load_task_ib_addr:
+      return ac_nir_load_arg(b, &s->args->ac, s->args->task_ib_addr);
+
+   case nir_intrinsic_load_task_ib_stride:
+      return ac_nir_load_arg(b, &s->args->ac, s->args->task_ib_stride);
+
    default:
       unreachable("invalid NIR RADV ABI intrinsic.");
    }
@@ -197,7 +212,12 @@ filter_abi_instr(const nir_instr *instr,
           intrin->intrinsic == nir_intrinsic_load_viewport_x_scale ||
           intrin->intrinsic == nir_intrinsic_load_viewport_x_offset ||
           intrin->intrinsic == nir_intrinsic_load_viewport_y_scale ||
-          intrin->intrinsic == nir_intrinsic_load_viewport_y_offset;
+          intrin->intrinsic == nir_intrinsic_load_viewport_y_offset ||
+          intrin->intrinsic == nir_intrinsic_load_ring_task_draw_amd ||
+          intrin->intrinsic == nir_intrinsic_load_ring_task_payload_amd ||
+          intrin->intrinsic == nir_intrinsic_load_task_ring_entry_amd ||
+          intrin->intrinsic == nir_intrinsic_load_task_ib_addr ||
+          intrin->intrinsic == nir_intrinsic_load_task_ib_stride;
 }
 
 void



More information about the mesa-commit mailing list