summaryrefslogtreecommitdiffstats
path: root/src/pulsecore/semaphore-posix.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2009-04-21 21:25:27 +0200
committerLennart Poettering <lennart@poettering.net>2009-04-21 21:25:27 +0200
commitfbbcfae769770ca1191e0610ad43722a5768aa40 (patch)
treef8fdb9502a89ecbe703c333d5e033cc0d1e4661b /src/pulsecore/semaphore-posix.c
parent391d50cd26a57b36deee48da1548aa7da88d1a1d (diff)
semaphore: introduce static semaphores
Diffstat (limited to 'src/pulsecore/semaphore-posix.c')
-rw-r--r--src/pulsecore/semaphore-posix.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/pulsecore/semaphore-posix.c b/src/pulsecore/semaphore-posix.c
index 616d897d..2aa1bce9 100644
--- a/src/pulsecore/semaphore-posix.c
+++ b/src/pulsecore/semaphore-posix.c
@@ -65,3 +65,25 @@ void pa_semaphore_wait(pa_semaphore *s) {
pa_assert(ret == 0);
}
+
+pa_semaphore* pa_static_semaphore_get(pa_static_semaphore *s, unsigned value) {
+ pa_semaphore *m;
+
+ pa_assert(s);
+
+ /* First, check if already initialized and short cut */
+ if ((m = pa_atomic_ptr_load(&s->ptr)))
+ return m;
+
+ /* OK, not initialized, so let's allocate, and fill in */
+ m = pa_semaphore_new(value);
+ if ((pa_atomic_ptr_cmpxchg(&s->ptr, NULL, m)))
+ return m;
+
+ pa_semaphore_free(m);
+
+ /* Him, filling in failed, so someone else must have filled in
+ * already */
+ pa_assert_se(m = pa_atomic_ptr_load(&s->ptr));
+ return m;
+}