diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-05-24 20:42:44 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-05-24 20:42:44 +0000 |
commit | 8e0a5bd38896731c6b25a9752db2f8b2125623af (patch) | |
tree | c620ca668d3a960a7118fbfacc218e1f8338fbde /channels/chan_sip.c | |
parent | 858771a1c097f8142bf5bba59d95b518f6000927 (diff) |
Restart faster on checking NOTIFY messages on mailboxes
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1053 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_sip.c')
-rwxr-xr-x | channels/chan_sip.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c index e4bd5af94..a46c8e56b 100755 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -4616,6 +4616,7 @@ static void *do_monitor(void *data) struct sip_pvt *sip; struct sip_peer *peer; time_t t; + int fastrestart =0; /* Add an I/O event to our UDP socket */ if (sipsock > -1) ast_io_add(io, sipsock, sipsock_read, AST_IO_IN, NULL); @@ -4653,6 +4654,9 @@ restartsearch: res = ast_sched_wait(sched); if ((res < 0) || (res > 1000)) res = 1000; + /* If we might need to send more mailboxes, don't wait long at all.*/ + if (fastrestart) + res = 1; res = ast_io_wait(io, res); ast_pthread_mutex_lock(&monlock); if (res >= 0) @@ -4660,9 +4664,11 @@ restartsearch: ast_pthread_mutex_lock(&peerl.lock); peer = peerl.peers; time(&t); + fastrestart = 0; while(peer) { if (strlen(peer->mailbox) && ((t - peer->lastmsgcheck) > 10)) { sip_send_mwi_to_peer(peer); + fastrestart = 1; break; } peer = peer->next; |