diff options
author | Mark Michelson <mmichelson@digium.com> | 2009-06-12 15:37:30 +0000 |
---|---|---|
committer | Mark Michelson <mmichelson@digium.com> | 2009-06-12 15:37:30 +0000 |
commit | e1c03cbf1a699ce759337283e52e5e0e2ef9ac18 (patch) | |
tree | 4150e6da4fdbdf4c1e2b9b5a73756cb8df77c635 /channels/chan_local.c | |
parent | d222361a29a78a23f7e465c4a4271318fd61386d (diff) |
Fix some bad locking stemming from trying to forward a call to a non-existent
extension from a queue.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@200326 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels/chan_local.c')
-rw-r--r-- | channels/chan_local.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/channels/chan_local.c b/channels/chan_local.c index 5eba90f4b..329b9828e 100644 --- a/channels/chan_local.c +++ b/channels/chan_local.c @@ -571,6 +571,8 @@ start_over: */ if (p->owner->cid.cid_rdnis) { if (!(p->chan->cid.cid_rdnis = ast_strdup(p->owner->cid.cid_rdnis))) { + ast_mutex_unlock(&p->lock); + ast_channel_unlock(p->chan); return -1; } } @@ -578,6 +580,8 @@ start_over: if (p->owner->cid.cid_dnid) { if (!(p->chan->cid.cid_dnid = ast_strdup(p->owner->cid.cid_dnid))) { + ast_mutex_unlock(&p->lock); + ast_channel_unlock(p->chan); return -1; } } @@ -595,6 +599,7 @@ start_over: if (!ast_exists_extension(NULL, p->chan->context, p->chan->exten, 1, p->owner->cid.cid_num)) { ast_log(LOG_NOTICE, "No such extension/context %s@%s while calling Local channel\n", p->chan->exten, p->chan->context); ast_mutex_unlock(&p->lock); + ast_channel_unlock(p->chan); return -1; } |