summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Gmeiner <christian.gmeiner@gmail.com>2020-06-29 12:10:55 +0200
committerMarge Bot <eric+marge@anholt.net>2020-07-24 20:01:04 +0000
commit7ee146aad49bc9e724cc93033298195ad1d9e162 (patch)
treea2a70b673a62d75353d542ace2fbc95d506ab56b
parent5839a7d64a21a1bfb7425895f793d1fbb52a4e12 (diff)
etnaviv: move shader_count to etna_compiler
Also fix data race on making the shader's id. Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com> Reviewed-by: Lucas Stach <l.stach@pengutronix.de> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5996>
-rw-r--r--src/gallium/drivers/etnaviv/etnaviv_compiler.h1
-rw-r--r--src/gallium/drivers/etnaviv/etnaviv_shader.c5
2 files changed, 4 insertions, 2 deletions
diff --git a/src/gallium/drivers/etnaviv/etnaviv_compiler.h b/src/gallium/drivers/etnaviv/etnaviv_compiler.h
index 40409c68d34..af979766ef3 100644
--- a/src/gallium/drivers/etnaviv/etnaviv_compiler.h
+++ b/src/gallium/drivers/etnaviv/etnaviv_compiler.h
@@ -49,6 +49,7 @@
* setup.
*/
struct etna_compiler {
+ uint32_t shader_count;
};
/* compiler output per input/output */
diff --git a/src/gallium/drivers/etnaviv/etnaviv_shader.c b/src/gallium/drivers/etnaviv/etnaviv_shader.c
index 173a4681cb2..44ab8eda363 100644
--- a/src/gallium/drivers/etnaviv/etnaviv_shader.c
+++ b/src/gallium/drivers/etnaviv/etnaviv_shader.c
@@ -34,6 +34,7 @@
#include "tgsi/tgsi_parse.h"
#include "nir/tgsi_to_nir.h"
+#include "util/u_atomic.h"
#include "util/u_math.h"
#include "util/u_memory.h"
@@ -395,13 +396,13 @@ etna_create_shader_state(struct pipe_context *pctx,
{
struct etna_context *ctx = etna_context(pctx);
struct etna_screen *screen = ctx->screen;
+ struct etna_compiler *compiler = screen->compiler;
struct etna_shader *shader = CALLOC_STRUCT(etna_shader);
if (!shader)
return NULL;
- static uint32_t id;
- shader->id = id++;
+ shader->id = p_atomic_inc_return(&compiler->shader_count);
shader->specs = &screen->specs;
if (DBG_ENABLED(ETNA_DBG_NIR))