<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Fri, May 13, 2016 at 1:02 PM, Rob Clark <span dir="ltr"><<a href="mailto:robdclark@gmail.com" target="_blank">robdclark@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">From: Rob Clark <<a href="mailto:robclark@freedesktop.org">robclark@freedesktop.org</a>><br>
<br>
If we assert in nir_validate_shader(), print the shader with the<br>
offending instruction prefixed with "=>" to make it easier to find what<br>
part of the shader nir_validate is complaining about.<br>
<br>
Macro funny-business in nir_validate() was just to avoid changing a<br>
bazillion assert() lines to validate_assert() (or similar) for the point<br>
of an RFC ;-)<br></blockquote><div><br></div><div>I love this idea. I just wish it worked for more than just instructions. It would also be fantastic if it were somehow able to print more than one error. Maybe something where we tie printing and validation together somehow? Just a thought.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Example output: <a href="http://hastebin.com/raw/qorirayazu" rel="noreferrer" target="_blank">http://hastebin.com/raw/qorirayazu</a><br>
---<br>
src/compiler/nir/nir.h | 1 +<br>
src/compiler/nir/nir_print.c | 14 +++++++++++++-<br>
src/compiler/nir/nir_validate.c | 15 +++++++++++++++<br>
3 files changed, 29 insertions(+), 1 deletion(-)<br>
<br>
diff --git a/src/compiler/nir/nir.h b/src/compiler/nir/nir.h<br>
index ade584c..6bb9fbe 100644<br>
--- a/src/compiler/nir/nir.h<br>
+++ b/src/compiler/nir/nir.h<br>
@@ -2196,6 +2196,7 @@ unsigned nir_index_instrs(nir_function_impl *impl);<br>
void nir_index_blocks(nir_function_impl *impl);<br>
<br>
void nir_print_shader(nir_shader *shader, FILE *fp);<br>
+void nir_print_shader_err(nir_shader *shader, FILE *fp, nir_instr *instr);<br>
void nir_print_instr(const nir_instr *instr, FILE *fp);<br>
<br>
nir_shader *nir_shader_clone(void *mem_ctx, const nir_shader *s);<br>
diff --git a/src/compiler/nir/nir_print.c b/src/compiler/nir/nir_print.c<br>
index a36561e..3b25a49 100644<br>
--- a/src/compiler/nir/nir_print.c<br>
+++ b/src/compiler/nir/nir_print.c<br>
@@ -53,6 +53,8 @@ typedef struct {<br>
<br>
/* an index used to make new non-conflicting names */<br>
unsigned index;<br>
+<br>
+ nir_instr *err_instr;<br>
} print_state;<br>
<br>
static void<br>
@@ -916,6 +918,8 @@ print_block(nir_block *block, print_state *state, unsigned tabs)<br>
free(preds);<br>
<br>
nir_foreach_instr(instr, block) {<br>
+ if (instr == state->err_instr)<br>
+ fprintf(fp, "=>");<br>
print_instr(instr, state, tabs);<br>
fprintf(fp, "\n");<br>
}<br>
@@ -1090,11 +1094,13 @@ destroy_print_state(print_state *state)<br>
}<br>
<br>
void<br>
-nir_print_shader(nir_shader *shader, FILE *fp)<br>
+nir_print_shader_err(nir_shader *shader, FILE *fp, nir_instr *instr)<br>
{<br>
print_state state;<br>
init_print_state(&state, shader, fp);<br>
<br>
+ state.err_instr = instr;<br>
+<br>
fprintf(fp, "shader: %s\n", gl_shader_stage_name(shader->stage));<br>
<br>
if (shader-><a href="http://info.name" rel="noreferrer" target="_blank">info.name</a>)<br>
@@ -1144,6 +1150,12 @@ nir_print_shader(nir_shader *shader, FILE *fp)<br>
}<br>
<br>
void<br>
+nir_print_shader(nir_shader *shader, FILE *fp)<br>
+{<br>
+ nir_print_shader_err(shader, fp, NULL);<br>
+}<br>
+<br>
+void<br>
nir_print_instr(const nir_instr *instr, FILE *fp)<br>
{<br>
print_state state = {<br>
diff --git a/src/compiler/nir/nir_validate.c b/src/compiler/nir/nir_validate.c<br>
index 84334d4..b47087f 100644<br>
--- a/src/compiler/nir/nir_validate.c<br>
+++ b/src/compiler/nir/nir_validate.c<br>
@@ -97,6 +97,21 @@ typedef struct {<br>
struct hash_table *var_defs;<br>
} validate_state;<br>
<br>
+<br>
+<br>
+static void<br>
+dump_assert(validate_state *state, const char *failed)<br>
+{<br>
+ fprintf(stderr, "validate failed: %s\n", failed);<br>
+ if (state->instr)<br>
+ nir_print_shader_err(state->shader, stderr, state->instr);<br>
+}<br>
+<br>
+#define __assert assert<br>
+#undef assert<br>
+#define assert(x) do { if (!(x)) { dump_assert(state, #x); __assert_fail(#x, __FILE__, __LINE__, __func__); } } while (0)<br>
+<br>
+<br>
static void validate_src(nir_src *src, validate_state *state);<br>
<br>
static void<br>
<span class="HOEnZb"><font color="#888888">--<br>
2.5.5<br>
<br>
</font></span></blockquote></div><br></div></div>