diff options
author | kpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-03-23 23:57:18 +0000 |
---|---|---|
committer | kpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-03-23 23:57:18 +0000 |
commit | 88ad15bc6f5270cd963ca9e9dda250997323500a (patch) | |
tree | 43394995549022aacb3f80b277132e6bd6af7b3a | |
parent | 402c85f9c8836964840d929e491a1b3bd37911b5 (diff) |
compute scheduler thread timeout properly
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@14573 f38db490-d61c-443f-a65b-d21fe96a405b
-rw-r--r-- | channels/chan_iax2.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c index 042dbf4b1..d8995c696 100644 --- a/channels/chan_iax2.c +++ b/channels/chan_iax2.c @@ -8264,13 +8264,16 @@ static void *sched_thread(void *ignore) { int count; int res; + struct timeval tv; struct timespec ts; for (;;) { res = ast_sched_wait(sched); if ((res > 1000) || (res < 0)) res = 1000; - ts.tv_sec = res; + tv = ast_tvadd(ast_tvnow(), ast_samp2tv(res, 1000)); + ts.tv_sec = tv.tv_sec; + ts.tv_nsec = tv.tv_usec * 1000; ast_mutex_lock(&sched_lock); ast_cond_timedwait(&sched_cond, &sched_lock, &ts); |