Mesa (master): nir: Add some sanity assertions in opt_large_constants

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Thu Apr 16 17:23:42 UTC 2020


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

Author: Jason Ekstrand <jason at jlekstrand.net>
Date:   Wed Apr  8 15:11:57 2020 -0500

nir: Add some sanity assertions in opt_large_constants

We make some assumptions in opt_large_constants such as the size_align
function returning the obvious sizes for vectors.  Now that we've got
the deref_size lying around, we may as well assert it's consistent with
our assumptions.  In particular, we now assert that it really claims
booleans are 32-bit.  If anyone's driver ever decides to be clever and
change this, we'll now catch the breakage earlier.

Reviewed-by: Eric Anholt <eric at anholt.net>
Reviewed-by: Ian Romanick <ian.d.romanick at intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4468>

---

 src/compiler/nir/nir_opt_large_constants.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/src/compiler/nir/nir_opt_large_constants.c b/src/compiler/nir/nir_opt_large_constants.c
index 7e293ba2c5e..7ed26f51127 100644
--- a/src/compiler/nir/nir_opt_large_constants.c
+++ b/src/compiler/nir/nir_opt_large_constants.c
@@ -92,9 +92,11 @@ build_constant_load(nir_builder *b, nir_deref_instr *deref,
    if (load->dest.ssa.bit_size < 8) {
       /* Booleans are special-cased to be 32-bit */
       assert(glsl_type_is_boolean(deref->type));
+      assert(deref_size == num_components * 4);
       load->dest.ssa.bit_size = 32;
       return nir_b2b1(b, &load->dest.ssa);
    } else {
+      assert(deref_size == num_components * bit_size / 8);
       return &load->dest.ssa;
    }
 }



More information about the mesa-commit mailing list