summaryrefslogtreecommitdiff
path: root/include/drm/spsc_queue.h
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2025-07-07 21:02:59 +0100
committerMark Brown <broonie@kernel.org>2025-07-07 21:02:59 +0100
commitbb96a315b4d84904edd2dae17910f10022ab71d5 (patch)
treee858237bd1335da828da7611979931fe890e33e6 /include/drm/spsc_queue.h
parent12826a49f029cd7ed794b1973ee31922f0e08e6f (diff)
parent08dc0f5cc26a203e8008c38d9b436c079e7dbb45 (diff)
ASoC: soc-dapm: cleanups
Merge series from Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>: This is prepare to hiding snd_soc_dapm_context inside soc-dapm.c
Diffstat (limited to 'include/drm/spsc_queue.h')
-rw-r--r--include/drm/spsc_queue.h4
1 files changed, 3 insertions, 1 deletions
diff --git a/include/drm/spsc_queue.h b/include/drm/spsc_queue.h
index 125f096c88cb..ee9df8cc67b7 100644
--- a/include/drm/spsc_queue.h
+++ b/include/drm/spsc_queue.h
@@ -70,9 +70,11 @@ static inline bool spsc_queue_push(struct spsc_queue *queue, struct spsc_node *n
preempt_disable();
+ atomic_inc(&queue->job_count);
+ smp_mb__after_atomic();
+
tail = (struct spsc_node **)atomic_long_xchg(&queue->tail, (long)&node->next);
WRITE_ONCE(*tail, node);
- atomic_inc(&queue->job_count);
/*
* In case of first element verify new node will be visible to the consumer