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

Author: Alyssa Rosenzweig <aly...@rosenzweig.io>
Date:   Tue May  4 22:42:07 2021 -0400

agx: Return agx_instr* from emit_intrinsic

Aesthetically useful.

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

---

 src/asahi/compiler/agx_compile.c | 42 +++++++++++++++++++---------------------
 1 file changed, 20 insertions(+), 22 deletions(-)

diff --git a/src/asahi/compiler/agx_compile.c b/src/asahi/compiler/agx_compile.c
index f1631ae0e2b..dd9b6320d48 100644
--- a/src/asahi/compiler/agx_compile.c
+++ b/src/asahi/compiler/agx_compile.c
@@ -63,7 +63,7 @@ agx_emit_load_const(agx_builder *b, nir_load_const_instr 
*instr)
 }
 
 /* AGX appears to lack support for vertex attributes. Lower to global loads. */
-static void
+static agx_instr *
 agx_emit_load_attr(agx_builder *b, nir_intrinsic_instr *instr)
 {
    nir_src *offset_src = nir_get_io_offset_src(instr);
@@ -109,9 +109,11 @@ agx_emit_load_attr(agx_builder *b, nir_intrinsic_instr 
*instr)
          channels[i] = agx_null();
       agx_p_combine_to(b, real_dest, channels[0], channels[1], channels[2], 
channels[3]);
    }
+
+   return NULL;
 }
 
-static void
+static agx_instr *
 agx_emit_load_vary(agx_builder *b, nir_intrinsic_instr *instr)
 {
    unsigned components = instr->num_components;
@@ -135,11 +137,11 @@ agx_emit_load_vary(agx_builder *b, nir_intrinsic_instr 
*instr)
    unsigned imm_index = (4 * nir_intrinsic_base(instr)) + 
nir_src_as_uint(*offset);
    imm_index += 1;
 
-   agx_ld_vary_to(b, agx_dest_index(&instr->dest),
+   return agx_ld_vary_to(b, agx_dest_index(&instr->dest),
          agx_immediate(imm_index), components);
 }
 
-static void
+static agx_instr *
 agx_emit_store_vary(agx_builder *b, nir_intrinsic_instr *instr)
 {
    nir_src *offset = nir_get_io_offset_src(instr);
@@ -151,12 +153,12 @@ agx_emit_store_vary(agx_builder *b, nir_intrinsic_instr 
*instr)
    /* nir_lower_io_to_scalar */
    assert(nir_intrinsic_write_mask(instr) == 0x1);
 
-   agx_st_vary(b,
+   return agx_st_vary(b,
                agx_immediate(imm_index),
                agx_src_index(&instr->src[0]));
 }
 
-static void
+static agx_instr *
 agx_emit_fragment_out(agx_builder *b, nir_intrinsic_instr *instr)
 {
    const nir_variable *var =
@@ -175,7 +177,7 @@ agx_emit_fragment_out(agx_builder *b, nir_intrinsic_instr 
*instr)
    agx_writeout(b, 0x000C);
 
    /* Emit the blend op itself */
-   agx_blend(b, agx_src_index(&instr->src[0]),
+   return agx_blend(b, agx_src_index(&instr->src[0]),
              b->shader->key->fs.tib_formats[rt]);
 }
 
@@ -190,7 +192,7 @@ agx_format_for_bits(unsigned bits)
    }
 }
 
-static void
+static agx_instr *
 agx_emit_load_ubo(agx_builder *b, nir_intrinsic_instr *instr)
 {
    bool kernel_input = (instr->intrinsic == nir_intrinsic_load_kernel_input);
@@ -231,10 +233,10 @@ agx_emit_load_ubo(agx_builder *b, nir_intrinsic_instr 
*instr)
                       agx_format_for_bits(nir_dest_bit_size(instr->dest)),
                       BITFIELD_MASK(instr->num_components), 0);
 
-   agx_wait(b, 0);
+   return agx_wait(b, 0);
 }
 
-static void
+static agx_instr *
 agx_emit_intrinsic(agx_builder *b, nir_intrinsic_instr *instr)
 {
   agx_index dst = nir_intrinsic_infos[instr->intrinsic].has_dest ?
@@ -248,38 +250,34 @@ agx_emit_intrinsic(agx_builder *b, nir_intrinsic_instr 
*instr)
   case nir_intrinsic_load_barycentric_at_sample:
   case nir_intrinsic_load_barycentric_at_offset:
      /* handled later via load_vary */
-     break;
+     return NULL;
   case nir_intrinsic_load_interpolated_input:
   case nir_intrinsic_load_input:
      if (stage == MESA_SHADER_FRAGMENT)
-        agx_emit_load_vary(b, instr);
+        return agx_emit_load_vary(b, instr);
      else if (stage == MESA_SHADER_VERTEX)
-        agx_emit_load_attr(b, instr);
+        return agx_emit_load_attr(b, instr);
      else
         unreachable("Unsupported shader stage");
-     break;
 
   case nir_intrinsic_store_output:
      if (stage == MESA_SHADER_FRAGMENT)
-        agx_emit_fragment_out(b, instr);
+        return agx_emit_fragment_out(b, instr);
      else if (stage == MESA_SHADER_VERTEX)
-        agx_emit_store_vary(b, instr);
+        return agx_emit_store_vary(b, instr);
      else
         unreachable("Unsupported shader stage");
-     break;
 
   case nir_intrinsic_load_ubo:
   case nir_intrinsic_load_kernel_input:
-     agx_emit_load_ubo(b, instr);
-     break;
+     return agx_emit_load_ubo(b, instr);
 
   case nir_intrinsic_load_vertex_id:
-     agx_mov_to(b, dst, agx_abs(agx_register(10, AGX_SIZE_32))); /* TODO: RA */
-     break;
+     return agx_mov_to(b, dst, agx_abs(agx_register(10, AGX_SIZE_32))); /* 
TODO: RA */
 
   default:
        fprintf(stderr, "Unhandled intrinsic %s\n", 
nir_intrinsic_infos[instr->intrinsic].name);
-       assert(0);
+       unreachable("Unhandled intrinsic");
   }
 }
 

_______________________________________________
mesa-commit mailing list
mesa-commit@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-commit

Reply via email to