agx: Implement compute ID intrinsics
authorAlyssa Rosenzweig <alyssa@rosenzweig.io>
Sat, 3 Dec 2022 02:32:14 +0000 (21:32 -0500)
committerMarge Bot <emma+marge@anholt.net>
Sat, 4 Feb 2023 17:10:15 +0000 (17:10 +0000)
These NIR intrinsics map to vectors of special registers.

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

src/asahi/compiler/agx_compile.c

index 399de7c..69b39cc 100644 (file)
@@ -671,6 +671,23 @@ agx_emit_discard(agx_builder *b)
 }
 
 static agx_instr *
+agx_load_compute_dimension(agx_builder *b, agx_index dst,
+                           nir_intrinsic_instr *instr, enum agx_sr base)
+{
+   unsigned dim = nir_dest_num_components(instr->dest);
+   unsigned size = nir_dest_bit_size(instr->dest);
+   assert(size == 16 || size == 32);
+
+   agx_index srcs[] = {
+      agx_get_sr(b, size, base + 0),
+      agx_get_sr(b, size, base + 1),
+      agx_get_sr(b, size, base + 2),
+   };
+
+   return agx_emit_collect_to(b, dst, dim, srcs);
+}
+
+static agx_instr *
 agx_emit_intrinsic(agx_builder *b, nir_intrinsic_instr *instr)
 {
    agx_index dst = nir_intrinsic_infos[instr->intrinsic].has_dest
@@ -747,6 +764,18 @@ agx_emit_intrinsic(agx_builder *b, nir_intrinsic_instr *instr)
    case nir_intrinsic_block_image_store_agx:
       return agx_emit_block_image_store(b, instr);
 
+   case nir_intrinsic_load_workgroup_id:
+      return agx_load_compute_dimension(b, dst, instr,
+                                        AGX_SR_THREADGROUP_POSITION_IN_GRID_X);
+
+   case nir_intrinsic_load_global_invocation_id:
+      return agx_load_compute_dimension(b, dst, instr,
+                                        AGX_SR_THREAD_POSITION_IN_GRID_X);
+
+   case nir_intrinsic_load_local_invocation_id:
+      return agx_load_compute_dimension(
+         b, dst, instr, AGX_SR_THREAD_POSITION_IN_THREADGROUP_X);
+
    default:
       fprintf(stderr, "Unhandled intrinsic %s\n",
               nir_intrinsic_infos[instr->intrinsic].name);