From: Jason Ekstrand Date: Tue, 24 Mar 2015 01:20:21 +0000 (-0700) Subject: nir/print: Don't print extra swizzzle components X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=793a94d6b5fc589ca8d7475347def4e222cd3d7c;p=mesa.git nir/print: Don't print extra swizzzle components Previously, NIR would just print 4 swizzle components if the swizzle was anything other than foo.xyzw. This creates lots of noise if, for example, you have a one-component element with a swizzle of foo.xxxx. Reviewed-by: Kenneth Grunke --- diff --git a/src/glsl/nir/nir_print.c b/src/glsl/nir/nir_print.c index fa11a312e51..53fada8eb95 100644 --- a/src/glsl/nir/nir_print.c +++ b/src/glsl/nir/nir_print.c @@ -137,7 +137,7 @@ print_dest(nir_dest *dest, FILE *fp) } static void -print_alu_src(nir_alu_src *src, FILE *fp) +print_alu_src(nir_alu_src *src, uint8_t read_mask, FILE *fp) { if (src->negate) fprintf(fp, "-"); @@ -146,13 +146,25 @@ print_alu_src(nir_alu_src *src, FILE *fp) print_src(&src->src, fp); - if (src->swizzle[0] != 0 || - src->swizzle[1] != 1 || - src->swizzle[2] != 2 || - src->swizzle[3] != 3) { + bool print_swizzle = false; + for (unsigned i = 0; i < 4; i++) { + if (read_mask >> i == 0) + break; + + if (src->swizzle[i] != i) { + print_swizzle = true; + break; + } + } + + if (print_swizzle) { fprintf(fp, "."); - for (unsigned i = 0; i < 4; i++) + for (unsigned i = 0; i < 4; i++) { + if (read_mask >> i == 0) + break; + fprintf(fp, "%c", "xyzw"[src->swizzle[i]]); + } } if (src->abs) @@ -189,7 +201,7 @@ print_alu_instr(nir_alu_instr *instr, FILE *fp) if (i != 0) fprintf(fp, ", "); - print_alu_src(&instr->src[i], fp); + print_alu_src(&instr->src[i], instr->dest.write_mask, fp); } }