From bd77d1e39b0c7bd9bef384e8e66a099697e753c5 Mon Sep 17 00:00:00 2001 From: markster Date: Fri, 21 Nov 2003 22:05:08 +0000 Subject: Unlock while processing schedule queue git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1779 f38db490-d61c-443f-a65b-d21fe96a405b --- sched.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'sched.c') diff --git a/sched.c b/sched.c index 391a627c5..b8c494015 100755 --- 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. -- cgit v1.2.3