diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 4421debd4d7420d04b87830d9007802aa112ce7e..40a29ee2663228b3d16f721c84c927511b4aeedd 100755 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -561,6 +561,10 @@ static int agent_hangup(struct ast_channel *ast) * as in apps/app_chanisavail.c:chanavail_exec() */ + ast_mutex_lock(&usecnt_lock); + usecnt--; + ast_mutex_unlock(&usecnt_lock); + ast_log(LOG_DEBUG, "Hangup called for state %s\n", ast_state2str(ast->_state)); if (p->start && (ast->_state != AST_STATE_UP)) { howlong = time(NULL) - p->start; diff --git a/channels/chan_local.c b/channels/chan_local.c index fc5c74fea0cbadb03cf95787a17d976dda0438e5..b1998f1c8a2caff4d6b87f82a9d756f37d663e6c 100755 --- a/channels/chan_local.c +++ b/channels/chan_local.c @@ -312,6 +312,10 @@ static int local_hangup(struct ast_channel *ast) p->owner = NULL; ast->pvt->pvt = NULL; + ast_mutex_lock(&usecnt_lock); + usecnt--; + ast_mutex_unlock(&usecnt_lock); + if (!p->owner && !p->chan) { /* Okay, done with the private part now, too. */ glaredetect = p->glaredetect; @@ -452,6 +456,7 @@ static struct ast_channel *local_new(struct local_pvt *p, int state) p->chan = tmp2; ast_mutex_lock(&usecnt_lock); usecnt++; + usecnt++; ast_mutex_unlock(&usecnt_lock); ast_update_use_count(); strncpy(tmp->context, p->context, sizeof(tmp->context)-1);