gallium/tgsi_to_nir: Set nir_intrinsic_align_mul to 16 and offset to 0
authorGert Wollny <gert.wollny@collabora.com>
Mon, 13 Apr 2020 17:51:42 +0000 (19:51 +0200)
committerMarge Bot <eric+marge@anholt.net>
Tue, 14 Apr 2020 18:47:09 +0000 (18:47 +0000)
Since the alignment is now checked in the validator we must set it.

v2: Use alignement of 4, i.e. dest bit size by eight.
v3: Use alignment 16 (Rhys Perry & Jason Ekstand)
v4: Use nir_intrinsic_set_align to make it clear that align offset is 0
    (Jason)

Fixes: e78a7a182524f091e2d77ba97bfbe057c3975cab
    nir: Assert memory loads are aligned

Signed-off-by: Gert Wollny <gert.wollny@collabora.com>
Reviewed-by: Jason Ekstrand <jason@jlekstrand.net>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4544>

src/gallium/auxiliary/nir/tgsi_to_nir.c

index 6ac894c85bb1fc660cd4a83f965183be269f80c7..0b96a3e707d6388e25cba4a30369c602d0b7e3a7 100644 (file)
@@ -736,6 +736,7 @@ ttn_src_for_file_and_index(struct ttn_compile *c, unsigned file, unsigned index,
          }
          /* UBO offsets are in bytes, but TGSI gives them to us in vec4's */
          offset = nir_ishl(b, offset, nir_imm_int(b, 4));
+         nir_intrinsic_set_align(load, 16, 0);
       } else {
          nir_intrinsic_set_base(load, index);
          if (indirect) {