Mesa (master): vtn/opencl: Fix alignment for half vload/vstore

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Wed Nov 18 04:25:33 UTC 2020


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

Author: Jesse Natalie <jenatali at microsoft.com>
Date:   Wed Nov 11 14:24:02 2020 -0800

vtn/opencl: Fix alignment for half vload/vstore

Reviewed-by: Jason Ekstrand <jason at jlekstrand.net>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7565>

---

 src/compiler/spirv/vtn_opencl.c | 21 ++++++++++++---------
 1 file changed, 12 insertions(+), 9 deletions(-)

diff --git a/src/compiler/spirv/vtn_opencl.c b/src/compiler/spirv/vtn_opencl.c
index 127fc9e9a85..9a1b052cd92 100644
--- a/src/compiler/spirv/vtn_opencl.c
+++ b/src/compiler/spirv/vtn_opencl.c
@@ -632,6 +632,15 @@ _handle_v_load_store(struct vtn_builder *b, enum OpenCLstd_Entrypoints opcode,
    nir_ssa_def *offset = vtn_get_nir_ssa(b, w[5 + a]);
    struct vtn_value *p = vtn_value(b, w[6 + a], vtn_value_type_pointer);
 
+   struct vtn_ssa_value *comps[NIR_MAX_VEC_COMPONENTS];
+   nir_ssa_def *ncomps[NIR_MAX_VEC_COMPONENTS];
+
+   nir_ssa_def *moffset = nir_imul_imm(&b->nb, offset,
+      (vec_aligned && components == 3) ? 4 : components);
+   nir_deref_instr *deref = vtn_pointer_to_deref(b, p->pointer);
+
+   unsigned alignment = vec_aligned ? glsl_get_cl_alignment(type->type) :
+                                      glsl_get_bit_size(type->type) / 8;
    enum glsl_base_type ptr_base_type =
       glsl_get_base_type(p->pointer->type->type);
    if (base_type != ptr_base_type) {
@@ -641,17 +650,11 @@ _handle_v_load_store(struct vtn_builder *b, enum OpenCLstd_Entrypoints opcode,
                   "vload/vstore cannot do type conversion. "
                   "vload/vstore_half can only convert from half to other "
                   "floating-point types.");
-   }
 
-   struct vtn_ssa_value *comps[NIR_MAX_VEC_COMPONENTS];
-   nir_ssa_def *ncomps[NIR_MAX_VEC_COMPONENTS];
-
-   nir_ssa_def *moffset = nir_imul_imm(&b->nb, offset,
-      (vec_aligned && components == 3) ? 4 : components);
-   nir_deref_instr *deref = vtn_pointer_to_deref(b, p->pointer);
+      /* Above-computed alignment was for floats/doubles, not halves */
+      alignment /= glsl_get_bit_size(type->type) / glsl_base_type_get_bit_size(ptr_base_type);
+   }
 
-   unsigned alignment = vec_aligned ? glsl_get_cl_alignment(type->type) :
-                                      glsl_get_bit_size(type->type) / 8;
    deref = nir_alignment_deref_cast(&b->nb, deref, alignment, 0);
 
    for (int i = 0; i < components; i++) {



More information about the mesa-commit mailing list