diff options
author | Mark Michelson <mmichelson@digium.com> | 2007-09-10 19:10:46 +0000 |
---|---|---|
committer | Mark Michelson <mmichelson@digium.com> | 2007-09-10 19:10:46 +0000 |
commit | ef2856adf0ba699f3347778d9c1441eb1009cbe0 (patch) | |
tree | a8220484f33f4bbfc63d9ba73eae9152770b6c09 /apps | |
parent | e5582607460aa9fe8312bdf5b184160b92d90f7b (diff) |
Fixing a problem where NULL channels would cause a crash when calling indisposed queue members (i.e. paused, wrapup time not completed, etc.)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@82185 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps')
-rw-r--r-- | apps/app_queue.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/apps/app_queue.c b/apps/app_queue.c index 5848bb2e1..d0b6affc0 100644 --- a/apps/app_queue.c +++ b/apps/app_queue.c @@ -2079,8 +2079,10 @@ static struct callattempt *wait_for_answer(struct queue_ent *qe, struct callatte starttime = (long) time(NULL); #ifdef HAVE_EPOLL - for (epollo = outgoing; epollo; epollo = epollo->q_next) - ast_poll_channel_add(in, epollo->chan); + for (epollo = outgoing; epollo; epollo = epollo->q_next) { + if(epollo->chan) + ast_poll_channel_add(in, epollo->chan); + } #endif while (*to && !peer) { @@ -2287,8 +2289,10 @@ static struct callattempt *wait_for_answer(struct queue_ent *qe, struct callatte } #ifdef HAVE_EPOLL - for(epollo = outgoing; epollo; epollo = epollo->q_next) - ast_poll_channel_del(in, epollo->chan); + for(epollo = outgoing; epollo; epollo = epollo->q_next) { + if(epollo->chan) + ast_poll_channel_del(in, epollo->chan); + } #endif return peer; |