summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Anholt <[email protected]>2019-06-05 11:29:19 -0700
committerEric Anholt <[email protected]>2019-06-21 17:14:43 -0700
commitee2e1e85d4df83efeae0c2f47a1eb44da2a088a1 (patch)
tree988c6ae1e858002c556ced0689c61b2ffbfc691f
parent8ab9f3a857317b6556d4d58cfe9bf4e04192ebf2 (diff)
freedreno: Include binning shaders in shader-db.
We want to see if we've improved our binning VS output, as well as the render VS. Reviewed-by: Rob Clark <[email protected]>
-rw-r--r--src/freedreno/ir3/ir3_shader.c4
-rw-r--r--src/gallium/drivers/freedreno/ir3/ir3_gallium.c11
2 files changed, 11 insertions, 4 deletions
diff --git a/src/freedreno/ir3/ir3_shader.c b/src/freedreno/ir3/ir3_shader.c
index 952ac9e1b2f..610ae655a83 100644
--- a/src/freedreno/ir3/ir3_shader.c
+++ b/src/freedreno/ir3/ir3_shader.c
@@ -243,8 +243,10 @@ ir3_shader_get_variant(struct ir3_shader *shader, struct ir3_shader_key *key,
shader_variant(shader, key, created);
if (v && binning_pass) {
- if (!v->binning)
+ if (!v->binning) {
v->binning = create_variant(shader, key, true);
+ *created = true;
+ }
return v->binning;
}
diff --git a/src/gallium/drivers/freedreno/ir3/ir3_gallium.c b/src/gallium/drivers/freedreno/ir3/ir3_gallium.c
index 9fd84899b36..4a7d3e8dbfd 100644
--- a/src/gallium/drivers/freedreno/ir3/ir3_gallium.c
+++ b/src/gallium/drivers/freedreno/ir3/ir3_gallium.c
@@ -44,15 +44,17 @@
#include "ir3/ir3_nir.h"
static void
-dump_shader_info(struct ir3_shader_variant *v, struct pipe_debug_callback *debug)
+dump_shader_info(struct ir3_shader_variant *v, bool binning_pass,
+ struct pipe_debug_callback *debug)
{
if (!unlikely(fd_mesa_debug & FD_DBG_SHADERDB))
return;
pipe_debug_message(debug, SHADER_INFO,
- "%s shader: %u inst, %u dwords, "
+ "%s%s shader: %u inst, %u dwords, "
"%u half, %u full, %u const, %u constlen, "
"%u (ss), %u (sy), %d max_sun, %d loops\n",
+ binning_pass ? "B" : "",
ir3_shader_stage(v->shader),
v->info.instrs_count,
v->info.sizedwords,
@@ -80,7 +82,7 @@ ir3_shader_variant(struct ir3_shader *shader, struct ir3_shader_key key,
v = ir3_shader_get_variant(shader, &key, binning_pass, &created);
if (created) {
- dump_shader_info(v, debug);
+ dump_shader_info(v, binning_pass, debug);
}
return v;
@@ -137,6 +139,9 @@ ir3_shader_create(struct ir3_compiler *compiler,
static struct ir3_shader_key key;
memset(&key, 0, sizeof(key));
ir3_shader_variant(shader, key, false, debug);
+
+ if (nir->info.stage != MESA_SHADER_FRAGMENT)
+ ir3_shader_variant(shader, key, true, debug);
}
return shader;
}