[vlc-commits] interrupt: voidify vlc_interrupt_prepare and simplify
    Rémi Denis-Courmont 
    git at videolan.org
       
    Sun Sep 27 21:55:00 CEST 2015
    
    
  
vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Sat Sep 26 20:09:38 2015 +0300| [3ccd91d3f654d4d19c4d6c28d8efaab42b21a420] | committer: Rémi Denis-Courmont
interrupt: voidify vlc_interrupt_prepare and simplify
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=3ccd91d3f654d4d19c4d6c28d8efaab42b21a420
---
 include/vlc_interrupt.h          |   11 ++-----
 modules/stream_filter/prefetch.c |    3 +-
 src/misc/interrupt.c             |   64 ++++++++++----------------------------
 3 files changed, 22 insertions(+), 56 deletions(-)
diff --git a/include/vlc_interrupt.h b/include/vlc_interrupt.h
index 46c4195..84e4585 100644
--- a/include/vlc_interrupt.h
+++ b/include/vlc_interrupt.h
@@ -196,17 +196,12 @@ VLC_API bool vlc_killed(void) VLC_USED;
  * it will be forwarded to the specified other context. This is used to cross
  * thread boundaries.
  *
- * If the calling thread already has an interruption pending, this function
- * dequeues the interrupt, return an error code and does not enable forwarding.
- *
- * If the calling thread has no interrupt context, this function does nothing
- * and returns zero.
+ * If the calling thread has no interrupt context, this function does nothing.
  *
  * @param to context to forward to
- * @return 0 on success, or EINTR on error
  */
-VLC_API int vlc_interrupt_forward_start(vlc_interrupt_t *to,
-                                        void *data[2]) VLC_USED;
+VLC_API void vlc_interrupt_forward_start(vlc_interrupt_t *to,
+                                         void *data[2]);
 
 /**
  * Undoes vlc_interrupt_forward_start().
diff --git a/modules/stream_filter/prefetch.c b/modules/stream_filter/prefetch.c
index 42085c3..16f102c 100644
--- a/modules/stream_filter/prefetch.c
+++ b/modules/stream_filter/prefetch.c
@@ -323,12 +323,13 @@ static ssize_t Read(stream_t *stream, void *buf, size_t buflen)
     {
         void *data[2];
 
-        if (sys->error || vlc_interrupt_forward_start(sys->interrupt, data))
+        if (sys->error)
         {
             vlc_mutex_unlock(&sys->lock);
             return -1;
         }
 
+        vlc_interrupt_forward_start(sys->interrupt, data);
         vlc_cond_wait(&sys->wait_data, &sys->lock);
         vlc_interrupt_forward_stop(data);
     }
diff --git a/src/misc/interrupt.c b/src/misc/interrupt.c
index c2a07d2..68c0364 100644
--- a/src/misc/interrupt.c
+++ b/src/misc/interrupt.c
@@ -154,33 +154,23 @@ vlc_interrupt_t *vlc_interrupt_set(vlc_interrupt_t *newctx)
  * Prepares to enter interruptible wait.
  * @param cb callback to interrupt the wait (i.e. wake up the thread)
  * @param data opaque data pointer for the callback
- * @return 0 on success or EINTR if an interruption is already pending
  * @note Any <b>succesful</b> call <b>must</b> be paired with a call to
  * vlc_interrupt_finish().
  */
-static int vlc_interrupt_prepare(vlc_interrupt_t *ctx,
-                                 void (*cb)(void *), void *data)
+static void vlc_interrupt_prepare(vlc_interrupt_t *ctx,
+                                  void (*cb)(void *), void *data)
 {
-    int ret = 0;
-
     assert(ctx != NULL);
     assert(ctx == vlc_threadvar_get(vlc_interrupt_var));
 
     vlc_mutex_lock(&ctx->lock);
     assert(ctx->callback == NULL);
-    if (ctx->interrupted)
-    {
-        ret = EINTR;
-        ctx->interrupted = false;
-    }
-    else
-    {
-        ret = 0;
-        ctx->callback = cb;
-        ctx->data = data;
-    }
+    ctx->callback = cb;
+    ctx->data = data;
+
+    if (unlikely(ctx->interrupted))
+        cb(data);
     vlc_mutex_unlock(&ctx->lock);
-    return ret;
 }
 
 /**
@@ -244,12 +234,7 @@ int vlc_sem_wait_i11e(vlc_sem_t *sem)
     if (ctx == NULL)
         return vlc_sem_wait(sem), 0;
 
-    int ret = vlc_interrupt_prepare(ctx, vlc_interrupt_sem, sem);
-    if (ret)
-    {
-        vlc_testcancel();
-        return ret;
-    }
+    vlc_interrupt_prepare(ctx, vlc_interrupt_sem, sem);
 
     vlc_cleanup_push(vlc_interrupt_cleanup, ctx);
     vlc_sem_wait(sem);
@@ -282,13 +267,7 @@ int vlc_mwait_i11e(mtime_t deadline)
     vlc_cond_t wait;
     vlc_cond_init(&wait);
 
-    int ret = vlc_interrupt_prepare(ctx, vlc_mwait_i11e_wake, &wait);
-    if (ret)
-    {
-        vlc_cond_destroy(&wait);
-        vlc_testcancel();
-        return ret;
-    }
+    vlc_interrupt_prepare(ctx, vlc_mwait_i11e_wake, &wait);
 
     vlc_mutex_lock(&ctx->lock);
     vlc_cleanup_push(vlc_mwait_i11e_cleanup, ctx);
@@ -297,7 +276,7 @@ int vlc_mwait_i11e(mtime_t deadline)
     vlc_cleanup_pop();
     vlc_mutex_unlock(&ctx->lock);
 
-    ret = vlc_interrupt_finish(ctx);
+    int ret = vlc_interrupt_finish(ctx);
     vlc_cond_destroy(&wait);
     return ret;
 }
@@ -312,18 +291,18 @@ static void vlc_interrupt_forward_wake(void *opaque)
                                 : vlc_interrupt_raise)(to);
 }
 
-int vlc_interrupt_forward_start(vlc_interrupt_t *to, void *data[2])
+void vlc_interrupt_forward_start(vlc_interrupt_t *to, void *data[2])
 {
     data[0] = data[1] = NULL;
 
     vlc_interrupt_t *from = vlc_threadvar_get(vlc_interrupt_var);
     if (from == NULL)
-        return 0;
+        return;
 
     assert(from != to);
     data[0] = to;
     data[1] = from;
-    return vlc_interrupt_prepare(from, vlc_interrupt_forward_wake, data);
+    vlc_interrupt_prepare(from, vlc_interrupt_forward_wake, data);
 }
 
 int vlc_interrupt_forward_stop(void *const data[2])
@@ -392,12 +371,7 @@ static int vlc_poll_i11e_inner(struct pollfd *restrict fds, unsigned nfds,
     ufd[nfds].fd = fd[0];
     ufd[nfds].events = POLLIN;
 
-    if (vlc_interrupt_prepare(ctx, vlc_poll_i11e_wake, fd))
-    {
-        vlc_testcancel();
-        errno = EINTR;
-        goto out;
-    }
+    vlc_interrupt_prepare(ctx, vlc_poll_i11e_wake, fd);
 
     vlc_cleanup_push(vlc_poll_i11e_cleanup, ctx);
     ret = poll(ufd, nfds + 1, timeout);
@@ -419,7 +393,7 @@ static int vlc_poll_i11e_inner(struct pollfd *restrict fds, unsigned nfds,
         errno = EINTR;
         ret = -1;
     }
-out:
+
     canc = vlc_savecancel();
     if (fd[1] != fd[0])
         close(fd[1]);
@@ -642,11 +616,7 @@ int vlc_poll_i11e(struct pollfd *fds, unsigned nfds, int timeout)
         return -1;
     }
 
-    if (vlc_interrupt_prepare(ctx, vlc_poll_i11e_wake, th))
-    {
-        errno = EINTR;
-        goto out;
-    }
+    vlc_interrupt_prepare(ctx, vlc_poll_i11e_wake, th);
 
     vlc_cleanup_push(vlc_poll_i11e_cleanup, th);
     ret = vlc_poll(fds, nfds, timeout);
@@ -657,7 +627,7 @@ int vlc_poll_i11e(struct pollfd *fds, unsigned nfds, int timeout)
         errno = EINTR;
         ret = -1;
     }
-out:
+
     CloseHandle(th);
     return ret;
 }
    
    
More information about the vlc-commits
mailing list