]> code.delx.au - pulseaudio/blobdiff - src/pulsecore/semaphore-posix.c
Merge remote branch 'mkbosmans/rate-adjustment'
[pulseaudio] / src / pulsecore / semaphore-posix.c
index 616d897d0fd2176de52d2c5968029e3ba963462e..2aa1bce906fe0634136b9fcc724dfc854e71ccc4 100644 (file)
@@ -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;
+}