Unlock while processing schedule queue
authorMark Spencer <markster@digium.com>
Fri, 21 Nov 2003 22:05:08 +0000 (22:05 +0000)
committerMark Spencer <markster@digium.com>
Fri, 21 Nov 2003 22:05:08 +0000 (22:05 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1779 65c4cc65-6c06-0410-ace0-fbb531ad65f3

sched.c

diff --git a/sched.c b/sched.c
index 391a627..b8c4940 100755 (executable)
--- a/sched.c
+++ b/sched.c
@@ -342,6 +342,7 @@ int ast_sched_runq(struct sched_context *con)
        struct sched *current;
        struct timeval tv;
        int x=0;
+       int res;
        DEBUG(ast_log(LOG_DEBUG, "ast_sched_runq()\n"));
                
        ast_mutex_lock(&con->lock);
@@ -370,7 +371,12 @@ int ast_sched_runq(struct sched_context *con)
                         * the schedule queue.  If that's what it wants to do, it 
                         * should return 0.
                         */
-                       if (current->callback(current->data)) {
+                       
+                       ast_mutex_unlock(&con->lock);
+                       res = current->callback(current->data);
+                       ast_mutex_lock(&con->lock);
+                       
+                       if (res) {
                                /*
                                 * If they return non-zero, we should schedule them to be
                                 * run again.