if (ast_call(o->chan, tmpchan, 0)) {
ast_log(LOG_NOTICE, "Failed to dial on local channel for call forward to '%s'\n", tmpchan);
+ ast_channel_unlock(o->chan);
do_hang(o);
numnochan++;
+ } else {
+ ast_channel_unlock(o->chan);
}
ast_channel_unlock(in);
- ast_channel_unlock(o->chan);
}
/* Hangup the original channel now, in case we needed it */
ast_hangup(winner);
*/
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;
}
}
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;
}
}
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;
}