summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/asahi/compiler/agx_compile.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/asahi/compiler/agx_compile.c b/src/asahi/compiler/agx_compile.c
index 997d7f9a277..8a354b1835b 100644
--- a/src/asahi/compiler/agx_compile.c
+++ b/src/asahi/compiler/agx_compile.c
@@ -491,6 +491,35 @@ agx_emit_alu(agx_builder *b, nir_alu_instr *instr)
}
}
+static enum agx_dim
+agx_tex_dim(enum glsl_sampler_dim dim, bool array)
+{
+ switch (dim) {
+ case GLSL_SAMPLER_DIM_1D:
+ case GLSL_SAMPLER_DIM_BUF:
+ return array ? AGX_DIM_TEX_1D_ARRAY : AGX_DIM_TEX_1D;
+
+ case GLSL_SAMPLER_DIM_2D:
+ case GLSL_SAMPLER_DIM_RECT:
+ case GLSL_SAMPLER_DIM_EXTERNAL:
+ return array ? AGX_DIM_TEX_2D_ARRAY : AGX_DIM_TEX_2D;
+
+ case GLSL_SAMPLER_DIM_MS:
+ assert(!array && "multisampled arrays unsupported");
+ return AGX_DIM_TEX_2D_MS;
+
+ case GLSL_SAMPLER_DIM_3D:
+ assert(!array && "3D arrays unsupported");
+ return AGX_DIM_TEX_3D;
+
+ case GLSL_SAMPLER_DIM_CUBE:
+ return array ? AGX_DIM_TEX_CUBE_ARRAY : AGX_DIM_TEX_CUBE;
+
+ default:
+ unreachable("Invalid sampler dim\n");
+ }
+}
+
static void
agx_emit_tex(agx_builder *b, nir_tex_instr *instr)
{